{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training examples\n",
    "For showcasing and debugging model implementations."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from benchmarking.benchmarking import get_configs\n",
    "model_config = get_configs(\n",
    "    [\"StandardAE\", \"ConvAE\", \"TransformerAE\", \"DeepCAE\", \"JointVAE\", \"StackedCAE\"],\n",
    "    [\"TeaRetail\"],\n",
    "    max_epochs=200\n",
    ")\n",
    "# NOTE: Remove this as soon as we have tuned Hyperparameters.\n",
    "model_config[\"TeaRetail\"][\"StackedCAE\"] = {\n",
    "    'epochs': 2,\n",
    "    'hidden_spec': [24, 16],\n",
    "    'lr': 1e-4,\n",
    "    'lambda_c': 1.4e-7,\n",
    "}\n",
    "\n",
    "model_configs = model_config['TeaRetail']\n",
    "model_configs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import yaml\n",
    "import logging\n",
    "import matplotlib.pyplot as plt\n",
    "from models.data_utils import get_dataloaders_for_tabular\n",
    "\n",
    "\n",
    "# Setup logging\n",
    "logging.basicConfig(\n",
    "    level=logging.INFO, format=\"%(process)d - %(levelname)s - %(message)s\"\n",
    ")\n",
    "dim_reduction = 0.505"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_name = \"TeaRetail\"\n",
    "data_base_path = f\"artifacts/data/{dataset_name}/\"\n",
    "file_name = \"processed.csv\"\n",
    "data_path = data_base_path + file_name\n",
    "dim_reduction = 0.505"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([64, 31])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "31"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_loader, test_loader = get_dataloaders_for_tabular(path_to_data=data_path)\n",
    "print(next(iter(train_loader)).size())\n",
    "input_dim = next(iter(train_loader)).size()[1]\n",
    "input_dim"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Standard Autoencoder\n",
    "Standard autoencoder with a single linear layer and TanH activation."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[16]\n",
      "StandardAE(\n",
      "  (encoder): Sequential(\n",
      "    (0): Linear(in_features=31, out_features=16, bias=True)\n",
      "    (1): Tanh()\n",
      "  )\n",
      "  (decoder): Sequential(\n",
      "    (0): Linear(in_features=16, out_features=31, bias=True)\n",
      "    (1): Tanh()\n",
      "  )\n",
      ")\n"
     ]
    }
   ],
   "source": [
    "# Model init\n",
    "from models import StandardAE\n",
    "\n",
    "hidden_spec = model_configs['StandardAE']['hidden_spec']\n",
    "hidden_spec[-1] = round(input_dim * dim_reduction)\n",
    "print(hidden_spec)\n",
    "model = StandardAE(input_dim=input_dim, hidden_spec=hidden_spec)\n",
    "print(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "21120 - INFO - Step 50 loss: 0.13564000\n",
      "21120 - INFO - Step 100 loss: 0.11883733\n",
      "21120 - INFO - Step 150 loss: 0.10415686\n",
      "21120 - INFO - Step 200 loss: 0.08973423\n",
      "21120 - INFO - Step 250 loss: 0.07649236\n",
      "21120 - INFO - Step 300 loss: 0.06582922\n",
      "21120 - INFO - Step 350 loss: 0.05584771\n",
      "21120 - INFO - Step 400 loss: 0.04603265\n",
      "21120 - INFO - Epoch [1/200], Train Loss: 0.08939213, Test Loss: 0.04009373\n",
      "\n",
      "21120 - INFO - Step 450 loss: 0.03738628\n",
      "21120 - INFO - Step 500 loss: 0.03167823\n",
      "21120 - INFO - Step 550 loss: 0.02636130\n",
      "21120 - INFO - Step 600 loss: 0.02189437\n",
      "21120 - INFO - Step 650 loss: 0.01840279\n",
      "21120 - INFO - Step 700 loss: 0.01598701\n",
      "21120 - INFO - Step 750 loss: 0.01397304\n",
      "21120 - INFO - Step 800 loss: 0.01287543\n",
      "21120 - INFO - Step 850 loss: 0.01173956\n",
      "21120 - INFO - Epoch [2/200], Train Loss: 0.02108274, Test Loss: 0.01123030\n",
      "\n",
      "21120 - INFO - Step 900 loss: 0.01074279\n",
      "21120 - INFO - Step 950 loss: 0.00989320\n",
      "21120 - INFO - Step 1000 loss: 0.01027938\n",
      "21120 - INFO - Step 1050 loss: 0.00855775\n",
      "21120 - INFO - Step 1100 loss: 0.00859625\n",
      "21120 - INFO - Step 1150 loss: 0.00762556\n",
      "21120 - INFO - Step 1200 loss: 0.00770963\n",
      "21120 - INFO - Step 1250 loss: 0.00702652\n",
      "21120 - INFO - Step 1300 loss: 0.00750157\n",
      "21120 - INFO - Epoch [3/200], Train Loss: 0.00875057, Test Loss: 0.00714142\n",
      "\n",
      "21120 - INFO - Step 1350 loss: 0.00655630\n",
      "21120 - INFO - Step 1400 loss: 0.00648942\n",
      "21120 - INFO - Step 1450 loss: 0.00672856\n",
      "21120 - INFO - Step 1500 loss: 0.00638827\n",
      "21120 - INFO - Step 1550 loss: 0.00547314\n",
      "21120 - INFO - Step 1600 loss: 0.00562723\n",
      "21120 - INFO - Step 1650 loss: 0.00594398\n",
      "21120 - INFO - Step 1700 loss: 0.00576185\n",
      "21120 - INFO - Epoch [4/200], Train Loss: 0.00641493, Test Loss: 0.00584338\n",
      "\n",
      "21120 - INFO - Step 1750 loss: 0.00562153\n",
      "21120 - INFO - Step 1800 loss: 0.00560056\n",
      "21120 - INFO - Step 1850 loss: 0.00545012\n",
      "21120 - INFO - Step 1900 loss: 0.00536612\n",
      "21120 - INFO - Step 1950 loss: 0.00514080\n",
      "21120 - INFO - Step 2000 loss: 0.00517881\n",
      "21120 - INFO - Step 2050 loss: 0.00525813\n",
      "21120 - INFO - Step 2100 loss: 0.00544174\n",
      "21120 - INFO - Step 2150 loss: 0.00503874\n",
      "21120 - INFO - Epoch [5/200], Train Loss: 0.00549036, Test Loss: 0.00516674\n",
      "\n",
      "21120 - INFO - Step 2200 loss: 0.00560453\n",
      "21120 - INFO - Step 2250 loss: 0.00502448\n",
      "21120 - INFO - Step 2300 loss: 0.00515554\n",
      "21120 - INFO - Step 2350 loss: 0.00467181\n",
      "21120 - INFO - Step 2400 loss: 0.00516126\n",
      "21120 - INFO - Step 2450 loss: 0.00465346\n",
      "21120 - INFO - Step 2500 loss: 0.00472049\n",
      "21120 - INFO - Step 2550 loss: 0.00501841\n",
      "21120 - INFO - Step 2600 loss: 0.00430152\n",
      "21120 - INFO - Epoch [6/200], Train Loss: 0.00497499, Test Loss: 0.00477873\n",
      "\n",
      "21120 - INFO - Step 2650 loss: 0.00427250\n",
      "21120 - INFO - Step 2700 loss: 0.00447594\n",
      "21120 - INFO - Step 2750 loss: 0.00495277\n",
      "21120 - INFO - Step 2800 loss: 0.00485476\n",
      "21120 - INFO - Step 2850 loss: 0.00430443\n",
      "21120 - INFO - Step 2900 loss: 0.00462853\n",
      "21120 - INFO - Step 2950 loss: 0.00449491\n",
      "21120 - INFO - Step 3000 loss: 0.00474805\n",
      "21120 - INFO - Epoch [7/200], Train Loss: 0.00458423, Test Loss: 0.00438959\n",
      "\n",
      "21120 - INFO - Step 3050 loss: 0.00443713\n",
      "21120 - INFO - Step 3100 loss: 0.00477417\n",
      "21120 - INFO - Step 3150 loss: 0.00438854\n",
      "21120 - INFO - Step 3200 loss: 0.00450466\n",
      "21120 - INFO - Step 3250 loss: 0.00406517\n",
      "21120 - INFO - Step 3300 loss: 0.00391929\n",
      "21120 - INFO - Step 3350 loss: 0.00446345\n",
      "21120 - INFO - Step 3400 loss: 0.00439304\n",
      "21120 - INFO - Step 3450 loss: 0.00393381\n",
      "21120 - INFO - Epoch [8/200], Train Loss: 0.00421751, Test Loss: 0.00401594\n",
      "\n",
      "21120 - INFO - Step 3500 loss: 0.00399922\n",
      "21120 - INFO - Step 3550 loss: 0.00429936\n",
      "21120 - INFO - Step 3600 loss: 0.00479371\n",
      "21120 - INFO - Step 3650 loss: 0.00405605\n",
      "21120 - INFO - Step 3700 loss: 0.00369727\n",
      "21120 - INFO - Step 3750 loss: 0.00383799\n",
      "21120 - INFO - Step 3800 loss: 0.00361839\n",
      "21120 - INFO - Step 3850 loss: 0.00361128\n",
      "21120 - INFO - Step 3900 loss: 0.00351312\n",
      "21120 - INFO - Epoch [9/200], Train Loss: 0.00382962, Test Loss: 0.00361361\n",
      "\n",
      "21120 - INFO - Step 3950 loss: 0.00319741\n",
      "21120 - INFO - Step 4000 loss: 0.00343425\n",
      "21120 - INFO - Step 4050 loss: 0.00363038\n",
      "21120 - INFO - Step 4100 loss: 0.00351372\n",
      "21120 - INFO - Step 4150 loss: 0.00308943\n",
      "21120 - INFO - Step 4200 loss: 0.00375570\n",
      "21120 - INFO - Step 4250 loss: 0.00318368\n",
      "21120 - INFO - Step 4300 loss: 0.00343969\n",
      "21120 - INFO - Epoch [10/200], Train Loss: 0.00342052, Test Loss: 0.00321788\n",
      "\n",
      "21120 - INFO - Step 4350 loss: 0.00294612\n",
      "21120 - INFO - Step 4400 loss: 0.00311946\n",
      "21120 - INFO - Step 4450 loss: 0.00309827\n",
      "21120 - INFO - Step 4500 loss: 0.00322809\n",
      "21120 - INFO - Step 4550 loss: 0.00325919\n",
      "21120 - INFO - Step 4600 loss: 0.00292166\n",
      "21120 - INFO - Step 4650 loss: 0.00311195\n",
      "21120 - INFO - Step 4700 loss: 0.00278438\n",
      "21120 - INFO - Step 4750 loss: 0.00298139\n",
      "21120 - INFO - Epoch [11/200], Train Loss: 0.00302742, Test Loss: 0.00284892\n",
      "\n",
      "21120 - INFO - Step 4800 loss: 0.00293680\n",
      "21120 - INFO - Step 4850 loss: 0.00271257\n",
      "21120 - INFO - Step 4900 loss: 0.00266105\n",
      "21120 - INFO - Step 4950 loss: 0.00255497\n",
      "21120 - INFO - Step 5000 loss: 0.00268708\n",
      "21120 - INFO - Step 5050 loss: 0.00231931\n",
      "21120 - INFO - Step 5100 loss: 0.00261330\n",
      "21120 - INFO - Step 5150 loss: 0.00267190\n",
      "21120 - INFO - Step 5200 loss: 0.00245520\n",
      "21120 - INFO - Epoch [12/200], Train Loss: 0.00269502, Test Loss: 0.00255656\n",
      "\n",
      "21120 - INFO - Step 5250 loss: 0.00249096\n",
      "21120 - INFO - Step 5300 loss: 0.00239241\n",
      "21120 - INFO - Step 5350 loss: 0.00271991\n",
      "21120 - INFO - Step 5400 loss: 0.00235625\n",
      "21120 - INFO - Step 5450 loss: 0.00267064\n",
      "21120 - INFO - Step 5500 loss: 0.00252467\n",
      "21120 - INFO - Step 5550 loss: 0.00229297\n",
      "21120 - INFO - Step 5600 loss: 0.00256803\n",
      "21120 - INFO - Epoch [13/200], Train Loss: 0.00243156, Test Loss: 0.00231540\n",
      "\n",
      "21120 - INFO - Step 5650 loss: 0.00213955\n",
      "21120 - INFO - Step 5700 loss: 0.00237143\n",
      "21120 - INFO - Step 5750 loss: 0.00243411\n",
      "21120 - INFO - Step 5800 loss: 0.00207742\n",
      "21120 - INFO - Step 5850 loss: 0.00240401\n",
      "21120 - INFO - Step 5900 loss: 0.00222353\n",
      "21120 - INFO - Step 5950 loss: 0.00222737\n",
      "21120 - INFO - Step 6000 loss: 0.00220487\n",
      "21120 - INFO - Step 6050 loss: 0.00190589\n",
      "21120 - INFO - Epoch [14/200], Train Loss: 0.00221919, Test Loss: 0.00212377\n",
      "\n",
      "21120 - INFO - Step 6100 loss: 0.00218089\n",
      "21120 - INFO - Step 6150 loss: 0.00209969\n",
      "21120 - INFO - Step 6200 loss: 0.00199868\n",
      "21120 - INFO - Step 6250 loss: 0.00204834\n",
      "21120 - INFO - Step 6300 loss: 0.00203157\n",
      "21120 - INFO - Step 6350 loss: 0.00179266\n",
      "21120 - INFO - Step 6400 loss: 0.00189775\n",
      "21120 - INFO - Step 6450 loss: 0.00202915\n",
      "21120 - INFO - Step 6500 loss: 0.00208398\n",
      "21120 - INFO - Epoch [15/200], Train Loss: 0.00203016, Test Loss: 0.00196719\n",
      "\n",
      "21120 - INFO - Step 6550 loss: 0.00190249\n",
      "21120 - INFO - Step 6600 loss: 0.00214236\n",
      "21120 - INFO - Step 6650 loss: 0.00169690\n",
      "21120 - INFO - Step 6700 loss: 0.00189774\n",
      "21120 - INFO - Step 6750 loss: 0.00187886\n",
      "21120 - INFO - Step 6800 loss: 0.00176041\n",
      "21120 - INFO - Step 6850 loss: 0.00166432\n",
      "21120 - INFO - Step 6900 loss: 0.00211767\n",
      "21120 - INFO - Epoch [16/200], Train Loss: 0.00185142, Test Loss: 0.00176176\n",
      "\n",
      "21120 - INFO - Step 6950 loss: 0.00185584\n",
      "21120 - INFO - Step 7000 loss: 0.00176035\n",
      "21120 - INFO - Step 7050 loss: 0.00151682\n",
      "21120 - INFO - Step 7100 loss: 0.00160545\n",
      "21120 - INFO - Step 7150 loss: 0.00186688\n",
      "21120 - INFO - Step 7200 loss: 0.00164807\n",
      "21120 - INFO - Step 7250 loss: 0.00160734\n",
      "21120 - INFO - Step 7300 loss: 0.00176206\n",
      "21120 - INFO - Step 7350 loss: 0.00167027\n",
      "21120 - INFO - Epoch [17/200], Train Loss: 0.00167891, Test Loss: 0.00160552\n",
      "\n",
      "21120 - INFO - Step 7400 loss: 0.00157879\n",
      "21120 - INFO - Step 7450 loss: 0.00158983\n",
      "21120 - INFO - Step 7500 loss: 0.00147986\n",
      "21120 - INFO - Step 7550 loss: 0.00150341\n",
      "21120 - INFO - Step 7600 loss: 0.00157273\n",
      "21120 - INFO - Step 7650 loss: 0.00147669\n",
      "21120 - INFO - Step 7700 loss: 0.00148831\n",
      "21120 - INFO - Step 7750 loss: 0.00173616\n",
      "21120 - INFO - Step 7800 loss: 0.00125433\n",
      "21120 - INFO - Epoch [18/200], Train Loss: 0.00151704, Test Loss: 0.00145571\n",
      "\n",
      "21120 - INFO - Step 7850 loss: 0.00141090\n",
      "21120 - INFO - Step 7900 loss: 0.00121636\n",
      "21120 - INFO - Step 7950 loss: 0.00143829\n",
      "21120 - INFO - Step 8000 loss: 0.00145947\n",
      "21120 - INFO - Step 8050 loss: 0.00129822\n",
      "21120 - INFO - Step 8100 loss: 0.00133456\n",
      "21120 - INFO - Step 8150 loss: 0.00124163\n",
      "21120 - INFO - Step 8200 loss: 0.00133382\n",
      "21120 - INFO - Epoch [19/200], Train Loss: 0.00136635, Test Loss: 0.00130091\n",
      "\n",
      "21120 - INFO - Step 8250 loss: 0.00136631\n",
      "21120 - INFO - Step 8300 loss: 0.00126514\n",
      "21120 - INFO - Step 8350 loss: 0.00123679\n",
      "21120 - INFO - Step 8400 loss: 0.00115525\n",
      "21120 - INFO - Step 8450 loss: 0.00139973\n",
      "21120 - INFO - Step 8500 loss: 0.00126082\n",
      "21120 - INFO - Step 8550 loss: 0.00125454\n",
      "21120 - INFO - Step 8600 loss: 0.00111589\n",
      "21120 - INFO - Step 8650 loss: 0.00110440\n",
      "21120 - INFO - Epoch [20/200], Train Loss: 0.00123156, Test Loss: 0.00117893\n",
      "\n",
      "21120 - INFO - Step 8700 loss: 0.00115949\n",
      "21120 - INFO - Step 8750 loss: 0.00104132\n",
      "21120 - INFO - Step 8800 loss: 0.00092879\n",
      "21120 - INFO - Step 8850 loss: 0.00105608\n",
      "21120 - INFO - Step 8900 loss: 0.00133947\n",
      "21120 - INFO - Step 8950 loss: 0.00105124\n",
      "21120 - INFO - Step 9000 loss: 0.00128222\n",
      "21120 - INFO - Step 9050 loss: 0.00108305\n",
      "21120 - INFO - Step 9100 loss: 0.00104900\n",
      "21120 - INFO - Epoch [21/200], Train Loss: 0.00111563, Test Loss: 0.00107040\n",
      "\n",
      "21120 - INFO - Step 9150 loss: 0.00104797\n",
      "21120 - INFO - Step 9200 loss: 0.00113079\n",
      "21120 - INFO - Step 9250 loss: 0.00092883\n",
      "21120 - INFO - Step 9300 loss: 0.00118379\n",
      "21120 - INFO - Step 9350 loss: 0.00098940\n",
      "21120 - INFO - Step 9400 loss: 0.00116941\n",
      "21120 - INFO - Step 9450 loss: 0.00092194\n",
      "21120 - INFO - Step 9500 loss: 0.00101321\n",
      "21120 - INFO - Epoch [22/200], Train Loss: 0.00101853, Test Loss: 0.00097976\n",
      "\n",
      "21120 - INFO - Step 9550 loss: 0.00099416\n",
      "21120 - INFO - Step 9600 loss: 0.00093292\n",
      "21120 - INFO - Step 9650 loss: 0.00086770\n",
      "21120 - INFO - Step 9700 loss: 0.00098479\n",
      "21120 - INFO - Step 9750 loss: 0.00100111\n",
      "21120 - INFO - Step 9800 loss: 0.00109227\n",
      "21120 - INFO - Step 9850 loss: 0.00086039\n",
      "21120 - INFO - Step 9900 loss: 0.00083373\n",
      "21120 - INFO - Step 9950 loss: 0.00089991\n",
      "21120 - INFO - Epoch [23/200], Train Loss: 0.00093983, Test Loss: 0.00091221\n",
      "\n",
      "21120 - INFO - Step 10000 loss: 0.00101163\n",
      "21120 - INFO - Step 10050 loss: 0.00077071\n",
      "21120 - INFO - Step 10100 loss: 0.00092141\n",
      "21120 - INFO - Step 10150 loss: 0.00081809\n",
      "21120 - INFO - Step 10200 loss: 0.00084419\n",
      "21120 - INFO - Step 10250 loss: 0.00081787\n",
      "21120 - INFO - Step 10300 loss: 0.00098481\n",
      "21120 - INFO - Step 10350 loss: 0.00081034\n",
      "21120 - INFO - Step 10400 loss: 0.00078633\n",
      "21120 - INFO - Epoch [24/200], Train Loss: 0.00087246, Test Loss: 0.00085516\n",
      "\n",
      "21120 - INFO - Step 10450 loss: 0.00079989\n",
      "21120 - INFO - Step 10500 loss: 0.00087853\n",
      "21120 - INFO - Step 10550 loss: 0.00077374\n",
      "21120 - INFO - Step 10600 loss: 0.00092243\n",
      "21120 - INFO - Step 10650 loss: 0.00085878\n",
      "21120 - INFO - Step 10700 loss: 0.00077799\n",
      "21120 - INFO - Step 10750 loss: 0.00082387\n",
      "21120 - INFO - Step 10800 loss: 0.00081815\n",
      "21120 - INFO - Step 10850 loss: 0.00080723\n",
      "21120 - INFO - Epoch [25/200], Train Loss: 0.00081603, Test Loss: 0.00079803\n",
      "\n",
      "21120 - INFO - Step 10900 loss: 0.00081372\n",
      "21120 - INFO - Step 10950 loss: 0.00071642\n",
      "21120 - INFO - Step 11000 loss: 0.00079980\n",
      "21120 - INFO - Step 11050 loss: 0.00074016\n",
      "21120 - INFO - Step 11100 loss: 0.00077024\n",
      "21120 - INFO - Step 11150 loss: 0.00078767\n",
      "21120 - INFO - Step 11200 loss: 0.00069884\n",
      "21120 - INFO - Step 11250 loss: 0.00086367\n",
      "21120 - INFO - Epoch [26/200], Train Loss: 0.00076511, Test Loss: 0.00075291\n",
      "\n",
      "21120 - INFO - Step 11300 loss: 0.00075478\n",
      "21120 - INFO - Step 11350 loss: 0.00083294\n",
      "21120 - INFO - Step 11400 loss: 0.00086417\n",
      "21120 - INFO - Step 11450 loss: 0.00080744\n",
      "21120 - INFO - Step 11500 loss: 0.00067538\n",
      "21120 - INFO - Step 11550 loss: 0.00074013\n",
      "21120 - INFO - Step 11600 loss: 0.00082483\n",
      "21120 - INFO - Step 11650 loss: 0.00066598\n",
      "21120 - INFO - Step 11700 loss: 0.00067265\n",
      "21120 - INFO - Epoch [27/200], Train Loss: 0.00071795, Test Loss: 0.00070910\n",
      "\n",
      "21120 - INFO - Step 11750 loss: 0.00079116\n",
      "21120 - INFO - Step 11800 loss: 0.00071408\n",
      "21120 - INFO - Step 11850 loss: 0.00069945\n",
      "21120 - INFO - Step 11900 loss: 0.00071792\n",
      "21120 - INFO - Step 11950 loss: 0.00060276\n",
      "21120 - INFO - Step 12000 loss: 0.00063106\n",
      "21120 - INFO - Step 12050 loss: 0.00075893\n",
      "21120 - INFO - Step 12100 loss: 0.00075020\n",
      "21120 - INFO - Step 12150 loss: 0.00070990\n",
      "21120 - INFO - Epoch [28/200], Train Loss: 0.00067474, Test Loss: 0.00066367\n",
      "\n",
      "21120 - INFO - Step 12200 loss: 0.00071017\n",
      "21120 - INFO - Step 12250 loss: 0.00067050\n",
      "21120 - INFO - Step 12300 loss: 0.00071093\n",
      "21120 - INFO - Step 12350 loss: 0.00057730\n",
      "21120 - INFO - Step 12400 loss: 0.00058547\n",
      "21120 - INFO - Step 12450 loss: 0.00061437\n",
      "21120 - INFO - Step 12500 loss: 0.00061078\n",
      "21120 - INFO - Step 12550 loss: 0.00060227\n",
      "21120 - INFO - Epoch [29/200], Train Loss: 0.00063452, Test Loss: 0.00062575\n",
      "\n",
      "21120 - INFO - Step 12600 loss: 0.00050815\n",
      "21120 - INFO - Step 12650 loss: 0.00067529\n",
      "21120 - INFO - Step 12700 loss: 0.00049971\n",
      "21120 - INFO - Step 12750 loss: 0.00051084\n",
      "21120 - INFO - Step 12800 loss: 0.00053234\n",
      "21120 - INFO - Step 12850 loss: 0.00065956\n",
      "21120 - INFO - Step 12900 loss: 0.00062906\n",
      "21120 - INFO - Step 12950 loss: 0.00048057\n",
      "21120 - INFO - Step 13000 loss: 0.00055202\n",
      "21120 - INFO - Epoch [30/200], Train Loss: 0.00059781, Test Loss: 0.00059000\n",
      "\n",
      "21120 - INFO - Step 13050 loss: 0.00051273\n",
      "21120 - INFO - Step 13100 loss: 0.00059818\n",
      "21120 - INFO - Step 13150 loss: 0.00053581\n",
      "21120 - INFO - Step 13200 loss: 0.00053474\n",
      "21120 - INFO - Step 13250 loss: 0.00052026\n",
      "21120 - INFO - Step 13300 loss: 0.00052373\n",
      "21120 - INFO - Step 13350 loss: 0.00066983\n",
      "21120 - INFO - Step 13400 loss: 0.00057417\n",
      "21120 - INFO - Step 13450 loss: 0.00052043\n",
      "21120 - INFO - Epoch [31/200], Train Loss: 0.00056352, Test Loss: 0.00055325\n",
      "\n",
      "21120 - INFO - Step 13500 loss: 0.00048743\n",
      "21120 - INFO - Step 13550 loss: 0.00045448\n",
      "21120 - INFO - Step 13600 loss: 0.00051914\n",
      "21120 - INFO - Step 13650 loss: 0.00053540\n",
      "21120 - INFO - Step 13700 loss: 0.00045406\n",
      "21120 - INFO - Step 13750 loss: 0.00052226\n",
      "21120 - INFO - Step 13800 loss: 0.00048594\n",
      "21120 - INFO - Step 13850 loss: 0.00045322\n",
      "21120 - INFO - Epoch [32/200], Train Loss: 0.00053275, Test Loss: 0.00052408\n",
      "\n",
      "21120 - INFO - Step 13900 loss: 0.00042435\n",
      "21120 - INFO - Step 13950 loss: 0.00046514\n",
      "21120 - INFO - Step 14000 loss: 0.00053946\n",
      "21120 - INFO - Step 14050 loss: 0.00048320\n",
      "21120 - INFO - Step 14100 loss: 0.00053355\n",
      "21120 - INFO - Step 14150 loss: 0.00050513\n",
      "21120 - INFO - Step 14200 loss: 0.00041337\n",
      "21120 - INFO - Step 14250 loss: 0.00044211\n",
      "21120 - INFO - Step 14300 loss: 0.00049257\n",
      "21120 - INFO - Epoch [33/200], Train Loss: 0.00050358, Test Loss: 0.00049760\n",
      "\n",
      "21120 - INFO - Step 14350 loss: 0.00051438\n",
      "21120 - INFO - Step 14400 loss: 0.00045971\n",
      "21120 - INFO - Step 14450 loss: 0.00043648\n",
      "21120 - INFO - Step 14500 loss: 0.00044296\n",
      "21120 - INFO - Step 14550 loss: 0.00049286\n",
      "21120 - INFO - Step 14600 loss: 0.00046530\n",
      "21120 - INFO - Step 14650 loss: 0.00052195\n",
      "21120 - INFO - Step 14700 loss: 0.00044589\n",
      "21120 - INFO - Step 14750 loss: 0.00050811\n",
      "21120 - INFO - Epoch [34/200], Train Loss: 0.00047722, Test Loss: 0.00047182\n",
      "\n",
      "21120 - INFO - Step 14800 loss: 0.00048368\n",
      "21120 - INFO - Step 14850 loss: 0.00047910\n",
      "21120 - INFO - Step 14900 loss: 0.00035234\n",
      "21120 - INFO - Step 14950 loss: 0.00039189\n",
      "21120 - INFO - Step 15000 loss: 0.00052616\n",
      "21120 - INFO - Step 15050 loss: 0.00042374\n",
      "21120 - INFO - Step 15100 loss: 0.00041661\n",
      "21120 - INFO - Step 15150 loss: 0.00043086\n",
      "21120 - INFO - Epoch [35/200], Train Loss: 0.00045372, Test Loss: 0.00045061\n",
      "\n",
      "21120 - INFO - Step 15200 loss: 0.00039866\n",
      "21120 - INFO - Step 15250 loss: 0.00040347\n",
      "21120 - INFO - Step 15300 loss: 0.00042866\n",
      "21120 - INFO - Step 15350 loss: 0.00042088\n",
      "21120 - INFO - Step 15400 loss: 0.00049940\n",
      "21120 - INFO - Step 15450 loss: 0.00043959\n",
      "21120 - INFO - Step 15500 loss: 0.00039488\n",
      "21120 - INFO - Step 15550 loss: 0.00052712\n",
      "21120 - INFO - Step 15600 loss: 0.00042764\n",
      "21120 - INFO - Epoch [36/200], Train Loss: 0.00043239, Test Loss: 0.00043075\n",
      "\n",
      "21120 - INFO - Step 15650 loss: 0.00045595\n",
      "21120 - INFO - Step 15700 loss: 0.00035452\n",
      "21120 - INFO - Step 15750 loss: 0.00038369\n",
      "21120 - INFO - Step 15800 loss: 0.00044996\n",
      "21120 - INFO - Step 15850 loss: 0.00037433\n",
      "21120 - INFO - Step 15900 loss: 0.00033593\n",
      "21120 - INFO - Step 15950 loss: 0.00047958\n",
      "21120 - INFO - Step 16000 loss: 0.00037367\n",
      "21120 - INFO - Step 16050 loss: 0.00043180\n",
      "21120 - INFO - Epoch [37/200], Train Loss: 0.00041434, Test Loss: 0.00041323\n",
      "\n",
      "21120 - INFO - Step 16100 loss: 0.00042056\n",
      "21120 - INFO - Step 16150 loss: 0.00044256\n",
      "21120 - INFO - Step 16200 loss: 0.00036892\n",
      "21120 - INFO - Step 16250 loss: 0.00038106\n",
      "21120 - INFO - Step 16300 loss: 0.00036756\n",
      "21120 - INFO - Step 16350 loss: 0.00034894\n",
      "21120 - INFO - Step 16400 loss: 0.00042276\n",
      "21120 - INFO - Step 16450 loss: 0.00046121\n",
      "21120 - INFO - Epoch [38/200], Train Loss: 0.00039839, Test Loss: 0.00040064\n",
      "\n",
      "21120 - INFO - Step 16500 loss: 0.00034921\n",
      "21120 - INFO - Step 16550 loss: 0.00033756\n",
      "21120 - INFO - Step 16600 loss: 0.00036025\n",
      "21120 - INFO - Step 16650 loss: 0.00047098\n",
      "21120 - INFO - Step 16700 loss: 0.00034704\n",
      "21120 - INFO - Step 16750 loss: 0.00034382\n",
      "21120 - INFO - Step 16800 loss: 0.00033696\n",
      "21120 - INFO - Step 16850 loss: 0.00045320\n",
      "21120 - INFO - Step 16900 loss: 0.00034555\n",
      "21120 - INFO - Epoch [39/200], Train Loss: 0.00038457, Test Loss: 0.00038229\n",
      "\n",
      "21120 - INFO - Step 16950 loss: 0.00031915\n",
      "21120 - INFO - Step 17000 loss: 0.00044187\n",
      "21120 - INFO - Step 17050 loss: 0.00034241\n",
      "21120 - INFO - Step 17100 loss: 0.00029765\n",
      "21120 - INFO - Step 17150 loss: 0.00040023\n",
      "21120 - INFO - Step 17200 loss: 0.00032882\n",
      "21120 - INFO - Step 17250 loss: 0.00036572\n",
      "21120 - INFO - Step 17300 loss: 0.00038119\n",
      "21120 - INFO - Step 17350 loss: 0.00034201\n",
      "21120 - INFO - Epoch [40/200], Train Loss: 0.00037181, Test Loss: 0.00037398\n",
      "\n",
      "21120 - INFO - Step 17400 loss: 0.00037735\n",
      "21120 - INFO - Step 17450 loss: 0.00036165\n",
      "21120 - INFO - Step 17500 loss: 0.00038365\n",
      "21120 - INFO - Step 17550 loss: 0.00034271\n",
      "21120 - INFO - Step 17600 loss: 0.00037348\n",
      "21120 - INFO - Step 17650 loss: 0.00033920\n",
      "21120 - INFO - Step 17700 loss: 0.00038281\n",
      "21120 - INFO - Step 17750 loss: 0.00037922\n",
      "21120 - INFO - Epoch [41/200], Train Loss: 0.00036040, Test Loss: 0.00035945\n",
      "\n",
      "21120 - INFO - Step 17800 loss: 0.00035241\n",
      "21120 - INFO - Step 17850 loss: 0.00033880\n",
      "21120 - INFO - Step 17900 loss: 0.00034100\n",
      "21120 - INFO - Step 17950 loss: 0.00034960\n",
      "21120 - INFO - Step 18000 loss: 0.00037398\n",
      "21120 - INFO - Step 18050 loss: 0.00040456\n",
      "21120 - INFO - Step 18100 loss: 0.00029058\n",
      "21120 - INFO - Step 18150 loss: 0.00030236\n",
      "21120 - INFO - Step 18200 loss: 0.00038271\n",
      "21120 - INFO - Epoch [42/200], Train Loss: 0.00035025, Test Loss: 0.00035109\n",
      "\n",
      "21120 - INFO - Step 18250 loss: 0.00037992\n",
      "21120 - INFO - Step 18300 loss: 0.00038638\n",
      "21120 - INFO - Step 18350 loss: 0.00027303\n",
      "21120 - INFO - Step 18400 loss: 0.00038176\n",
      "21120 - INFO - Step 18450 loss: 0.00031293\n",
      "21120 - INFO - Step 18500 loss: 0.00034662\n",
      "21120 - INFO - Step 18550 loss: 0.00033794\n",
      "21120 - INFO - Step 18600 loss: 0.00039340\n",
      "21120 - INFO - Step 18650 loss: 0.00031610\n",
      "21120 - INFO - Epoch [43/200], Train Loss: 0.00034057, Test Loss: 0.00033865\n",
      "\n",
      "21120 - INFO - Step 18700 loss: 0.00031591\n",
      "21120 - INFO - Step 18750 loss: 0.00033844\n",
      "21120 - INFO - Step 18800 loss: 0.00036670\n",
      "21120 - INFO - Step 18850 loss: 0.00028529\n",
      "21120 - INFO - Step 18900 loss: 0.00033783\n",
      "21120 - INFO - Step 18950 loss: 0.00028174\n",
      "21120 - INFO - Step 19000 loss: 0.00036991\n",
      "21120 - INFO - Step 19050 loss: 0.00033724\n",
      "21120 - INFO - Epoch [44/200], Train Loss: 0.00033087, Test Loss: 0.00033014\n",
      "\n",
      "21120 - INFO - Step 19100 loss: 0.00031801\n",
      "21120 - INFO - Step 19150 loss: 0.00031673\n",
      "21120 - INFO - Step 19200 loss: 0.00032578\n",
      "21120 - INFO - Step 19250 loss: 0.00032042\n",
      "21120 - INFO - Step 19300 loss: 0.00032561\n",
      "21120 - INFO - Step 19350 loss: 0.00030776\n",
      "21120 - INFO - Step 19400 loss: 0.00030774\n",
      "21120 - INFO - Step 19450 loss: 0.00033330\n",
      "21120 - INFO - Step 19500 loss: 0.00036320\n",
      "21120 - INFO - Epoch [45/200], Train Loss: 0.00032259, Test Loss: 0.00032170\n",
      "\n",
      "21120 - INFO - Step 19550 loss: 0.00040032\n",
      "21120 - INFO - Step 19600 loss: 0.00033895\n",
      "21120 - INFO - Step 19650 loss: 0.00032802\n",
      "21120 - INFO - Step 19700 loss: 0.00029759\n",
      "21120 - INFO - Step 19750 loss: 0.00033002\n",
      "21120 - INFO - Step 19800 loss: 0.00026174\n",
      "21120 - INFO - Step 19850 loss: 0.00031460\n",
      "21120 - INFO - Step 19900 loss: 0.00028913\n",
      "21120 - INFO - Step 19950 loss: 0.00031045\n",
      "21120 - INFO - Epoch [46/200], Train Loss: 0.00031403, Test Loss: 0.00031699\n",
      "\n",
      "21120 - INFO - Step 20000 loss: 0.00035527\n",
      "21120 - INFO - Step 20050 loss: 0.00038230\n",
      "21120 - INFO - Step 20100 loss: 0.00033941\n",
      "21120 - INFO - Step 20150 loss: 0.00031452\n",
      "21120 - INFO - Step 20200 loss: 0.00037880\n",
      "21120 - INFO - Step 20250 loss: 0.00027227\n",
      "21120 - INFO - Step 20300 loss: 0.00035906\n",
      "21120 - INFO - Step 20350 loss: 0.00035015\n",
      "21120 - INFO - Epoch [47/200], Train Loss: 0.00030670, Test Loss: 0.00030796\n",
      "\n",
      "21120 - INFO - Step 20400 loss: 0.00030916\n",
      "21120 - INFO - Step 20450 loss: 0.00029471\n",
      "21120 - INFO - Step 20500 loss: 0.00027645\n",
      "21120 - INFO - Step 20550 loss: 0.00034359\n",
      "21120 - INFO - Step 20600 loss: 0.00030497\n",
      "21120 - INFO - Step 20650 loss: 0.00024945\n",
      "21120 - INFO - Step 20700 loss: 0.00025407\n",
      "21120 - INFO - Step 20750 loss: 0.00027934\n",
      "21120 - INFO - Step 20800 loss: 0.00032460\n",
      "21120 - INFO - Epoch [48/200], Train Loss: 0.00029920, Test Loss: 0.00030280\n",
      "\n",
      "21120 - INFO - Step 20850 loss: 0.00023959\n",
      "21120 - INFO - Step 20900 loss: 0.00022786\n",
      "21120 - INFO - Step 20950 loss: 0.00029642\n",
      "21120 - INFO - Step 21000 loss: 0.00026005\n",
      "21120 - INFO - Step 21050 loss: 0.00027663\n",
      "21120 - INFO - Step 21100 loss: 0.00026217\n",
      "21120 - INFO - Step 21150 loss: 0.00028773\n",
      "21120 - INFO - Step 21200 loss: 0.00026255\n",
      "21120 - INFO - Step 21250 loss: 0.00032041\n",
      "21120 - INFO - Epoch [49/200], Train Loss: 0.00029247, Test Loss: 0.00029226\n",
      "\n",
      "21120 - INFO - Step 21300 loss: 0.00026084\n",
      "21120 - INFO - Step 21350 loss: 0.00029852\n",
      "21120 - INFO - Step 21400 loss: 0.00023598\n",
      "21120 - INFO - Step 21450 loss: 0.00029272\n",
      "21120 - INFO - Step 21500 loss: 0.00035143\n",
      "21120 - INFO - Step 21550 loss: 0.00026349\n",
      "21120 - INFO - Step 21600 loss: 0.00029396\n",
      "21120 - INFO - Step 21650 loss: 0.00027343\n",
      "21120 - INFO - Step 21700 loss: 0.00030138\n",
      "21120 - INFO - Epoch [50/200], Train Loss: 0.00028653, Test Loss: 0.00028472\n",
      "\n",
      "21120 - INFO - Step 21750 loss: 0.00026435\n",
      "21120 - INFO - Step 21800 loss: 0.00029091\n",
      "21120 - INFO - Step 21850 loss: 0.00026846\n",
      "21120 - INFO - Step 21900 loss: 0.00028832\n",
      "21120 - INFO - Step 21950 loss: 0.00032495\n",
      "21120 - INFO - Step 22000 loss: 0.00030680\n",
      "21120 - INFO - Step 22050 loss: 0.00034188\n",
      "21120 - INFO - Step 22100 loss: 0.00027757\n",
      "21120 - INFO - Epoch [51/200], Train Loss: 0.00028079, Test Loss: 0.00028012\n",
      "\n",
      "21120 - INFO - Step 22150 loss: 0.00023705\n",
      "21120 - INFO - Step 22200 loss: 0.00028511\n",
      "21120 - INFO - Step 22250 loss: 0.00027081\n",
      "21120 - INFO - Step 22300 loss: 0.00026450\n",
      "21120 - INFO - Step 22350 loss: 0.00031273\n",
      "21120 - INFO - Step 22400 loss: 0.00025831\n",
      "21120 - INFO - Step 22450 loss: 0.00024573\n",
      "21120 - INFO - Step 22500 loss: 0.00025175\n",
      "21120 - INFO - Step 22550 loss: 0.00033333\n",
      "21120 - INFO - Epoch [52/200], Train Loss: 0.00027650, Test Loss: 0.00027610\n",
      "\n",
      "21120 - INFO - Step 22600 loss: 0.00026045\n",
      "21120 - INFO - Step 22650 loss: 0.00026943\n",
      "21120 - INFO - Step 22700 loss: 0.00030110\n",
      "21120 - INFO - Step 22750 loss: 0.00025779\n",
      "21120 - INFO - Step 22800 loss: 0.00026276\n",
      "21120 - INFO - Step 22850 loss: 0.00025498\n",
      "21120 - INFO - Step 22900 loss: 0.00023373\n",
      "21120 - INFO - Step 22950 loss: 0.00029909\n",
      "21120 - INFO - Step 23000 loss: 0.00026833\n",
      "21120 - INFO - Epoch [53/200], Train Loss: 0.00027212, Test Loss: 0.00027015\n",
      "\n",
      "21120 - INFO - Step 23050 loss: 0.00025315\n",
      "21120 - INFO - Step 23100 loss: 0.00029808\n",
      "21120 - INFO - Step 23150 loss: 0.00026215\n",
      "21120 - INFO - Step 23200 loss: 0.00028385\n",
      "21120 - INFO - Step 23250 loss: 0.00027315\n",
      "21120 - INFO - Step 23300 loss: 0.00032086\n",
      "21120 - INFO - Step 23350 loss: 0.00025950\n",
      "21120 - INFO - Step 23400 loss: 0.00026579\n",
      "21120 - INFO - Epoch [54/200], Train Loss: 0.00026864, Test Loss: 0.00026778\n",
      "\n",
      "21120 - INFO - Step 23450 loss: 0.00031357\n",
      "21120 - INFO - Step 23500 loss: 0.00025609\n",
      "21120 - INFO - Step 23550 loss: 0.00025895\n",
      "21120 - INFO - Step 23600 loss: 0.00029954\n",
      "21120 - INFO - Step 23650 loss: 0.00027887\n",
      "21120 - INFO - Step 23700 loss: 0.00026371\n",
      "21120 - INFO - Step 23750 loss: 0.00027775\n",
      "21120 - INFO - Step 23800 loss: 0.00025683\n",
      "21120 - INFO - Step 23850 loss: 0.00025989\n",
      "21120 - INFO - Epoch [55/200], Train Loss: 0.00026569, Test Loss: 0.00026412\n",
      "\n",
      "21120 - INFO - Step 23900 loss: 0.00023472\n",
      "21120 - INFO - Step 23950 loss: 0.00030507\n",
      "21120 - INFO - Step 24000 loss: 0.00023514\n",
      "21120 - INFO - Step 24050 loss: 0.00024819\n",
      "21120 - INFO - Step 24100 loss: 0.00028348\n",
      "21120 - INFO - Step 24150 loss: 0.00022384\n",
      "21120 - INFO - Step 24200 loss: 0.00031146\n",
      "21120 - INFO - Step 24250 loss: 0.00026735\n",
      "21120 - INFO - Step 24300 loss: 0.00024117\n",
      "21120 - INFO - Epoch [56/200], Train Loss: 0.00026250, Test Loss: 0.00026361\n",
      "\n",
      "21120 - INFO - Step 24350 loss: 0.00026102\n",
      "21120 - INFO - Step 24400 loss: 0.00022357\n",
      "21120 - INFO - Step 24450 loss: 0.00024687\n",
      "21120 - INFO - Step 24500 loss: 0.00028199\n",
      "21120 - INFO - Step 24550 loss: 0.00028379\n",
      "21120 - INFO - Step 24600 loss: 0.00025685\n",
      "21120 - INFO - Step 24650 loss: 0.00026844\n",
      "21120 - INFO - Step 24700 loss: 0.00029249\n",
      "21120 - INFO - Epoch [57/200], Train Loss: 0.00026015, Test Loss: 0.00026036\n",
      "\n",
      "21120 - INFO - Step 24750 loss: 0.00027793\n",
      "21120 - INFO - Step 24800 loss: 0.00030551\n",
      "21120 - INFO - Step 24850 loss: 0.00028867\n",
      "21120 - INFO - Step 24900 loss: 0.00025767\n",
      "21120 - INFO - Step 24950 loss: 0.00024103\n",
      "21120 - INFO - Step 25000 loss: 0.00024600\n",
      "21120 - INFO - Step 25050 loss: 0.00025691\n",
      "21120 - INFO - Step 25100 loss: 0.00023654\n",
      "21120 - INFO - Step 25150 loss: 0.00027414\n",
      "21120 - INFO - Epoch [58/200], Train Loss: 0.00025794, Test Loss: 0.00025810\n",
      "\n",
      "21120 - INFO - Step 25200 loss: 0.00024240\n",
      "21120 - INFO - Step 25250 loss: 0.00021677\n",
      "21120 - INFO - Step 25300 loss: 0.00025853\n",
      "21120 - INFO - Step 25350 loss: 0.00027971\n",
      "21120 - INFO - Step 25400 loss: 0.00024220\n",
      "21120 - INFO - Step 25450 loss: 0.00022437\n",
      "21120 - INFO - Step 25500 loss: 0.00023966\n",
      "21120 - INFO - Step 25550 loss: 0.00024356\n",
      "21120 - INFO - Step 25600 loss: 0.00022620\n",
      "21120 - INFO - Epoch [59/200], Train Loss: 0.00025565, Test Loss: 0.00025858\n",
      "\n",
      "21120 - INFO - Step 25650 loss: 0.00031115\n",
      "21120 - INFO - Step 25700 loss: 0.00027232\n",
      "21120 - INFO - Step 25750 loss: 0.00027662\n",
      "21120 - INFO - Step 25800 loss: 0.00024728\n",
      "21120 - INFO - Step 25850 loss: 0.00020188\n",
      "21120 - INFO - Step 25900 loss: 0.00024367\n",
      "21120 - INFO - Step 25950 loss: 0.00027668\n",
      "21120 - INFO - Step 26000 loss: 0.00027308\n",
      "21120 - INFO - Epoch [60/200], Train Loss: 0.00025379, Test Loss: 0.00025440\n",
      "\n",
      "21120 - INFO - Step 26050 loss: 0.00027369\n",
      "21120 - INFO - Step 26100 loss: 0.00029799\n",
      "21120 - INFO - Step 26150 loss: 0.00024891\n",
      "21120 - INFO - Step 26200 loss: 0.00025129\n",
      "21120 - INFO - Step 26250 loss: 0.00024144\n",
      "21120 - INFO - Step 26300 loss: 0.00025591\n",
      "21120 - INFO - Step 26350 loss: 0.00026181\n",
      "21120 - INFO - Step 26400 loss: 0.00026651\n",
      "21120 - INFO - Step 26450 loss: 0.00027836\n",
      "21120 - INFO - Epoch [61/200], Train Loss: 0.00025237, Test Loss: 0.00025183\n",
      "\n",
      "21120 - INFO - Step 26500 loss: 0.00026458\n",
      "21120 - INFO - Step 26550 loss: 0.00029294\n",
      "21120 - INFO - Step 26600 loss: 0.00026045\n",
      "21120 - INFO - Step 26650 loss: 0.00025824\n",
      "21120 - INFO - Step 26700 loss: 0.00026815\n",
      "21120 - INFO - Step 26750 loss: 0.00028380\n",
      "21120 - INFO - Step 26800 loss: 0.00028879\n",
      "21120 - INFO - Step 26850 loss: 0.00020846\n",
      "21120 - INFO - Step 26900 loss: 0.00023660\n",
      "21120 - INFO - Epoch [62/200], Train Loss: 0.00025110, Test Loss: 0.00025052\n",
      "\n",
      "21120 - INFO - Step 26950 loss: 0.00025126\n",
      "21120 - INFO - Step 27000 loss: 0.00022700\n",
      "21120 - INFO - Step 27050 loss: 0.00021332\n",
      "21120 - INFO - Step 27100 loss: 0.00022228\n",
      "21120 - INFO - Step 27150 loss: 0.00023315\n",
      "21120 - INFO - Step 27200 loss: 0.00026826\n",
      "21120 - INFO - Step 27250 loss: 0.00025980\n",
      "21120 - INFO - Step 27300 loss: 0.00027737\n",
      "21120 - INFO - Epoch [63/200], Train Loss: 0.00024940, Test Loss: 0.00025133\n",
      "\n",
      "21120 - INFO - Step 27350 loss: 0.00027476\n",
      "21120 - INFO - Step 27400 loss: 0.00025608\n",
      "21120 - INFO - Step 27450 loss: 0.00022732\n",
      "21120 - INFO - Step 27500 loss: 0.00023926\n",
      "21120 - INFO - Step 27550 loss: 0.00025002\n",
      "21120 - INFO - Step 27600 loss: 0.00026801\n",
      "21120 - INFO - Step 27650 loss: 0.00025152\n",
      "21120 - INFO - Step 27700 loss: 0.00021832\n",
      "21120 - INFO - Step 27750 loss: 0.00027137\n",
      "21120 - INFO - Epoch [64/200], Train Loss: 0.00024849, Test Loss: 0.00024856\n",
      "\n",
      "21120 - INFO - Step 27800 loss: 0.00022949\n",
      "21120 - INFO - Step 27850 loss: 0.00022849\n",
      "21120 - INFO - Step 27900 loss: 0.00025752\n",
      "21120 - INFO - Step 27950 loss: 0.00024191\n",
      "21120 - INFO - Step 28000 loss: 0.00023667\n",
      "21120 - INFO - Step 28050 loss: 0.00023079\n",
      "21120 - INFO - Step 28100 loss: 0.00022449\n",
      "21120 - INFO - Step 28150 loss: 0.00023400\n",
      "21120 - INFO - Step 28200 loss: 0.00025574\n",
      "21120 - INFO - Epoch [65/200], Train Loss: 0.00024709, Test Loss: 0.00024572\n",
      "\n",
      "21120 - INFO - Step 28250 loss: 0.00024056\n",
      "21120 - INFO - Step 28300 loss: 0.00024745\n",
      "21120 - INFO - Step 28350 loss: 0.00025854\n",
      "21120 - INFO - Step 28400 loss: 0.00022467\n",
      "21120 - INFO - Step 28450 loss: 0.00024630\n",
      "21120 - INFO - Step 28500 loss: 0.00025238\n",
      "21120 - INFO - Step 28550 loss: 0.00020755\n",
      "21120 - INFO - Step 28600 loss: 0.00025195\n",
      "21120 - INFO - Epoch [66/200], Train Loss: 0.00024622, Test Loss: 0.00024621\n",
      "\n",
      "21120 - INFO - Step 28650 loss: 0.00027180\n",
      "21120 - INFO - Step 28700 loss: 0.00029373\n",
      "21120 - INFO - Step 28750 loss: 0.00026112\n",
      "21120 - INFO - Step 28800 loss: 0.00024703\n",
      "21120 - INFO - Step 28850 loss: 0.00024698\n",
      "21120 - INFO - Step 28900 loss: 0.00026529\n",
      "21120 - INFO - Step 28950 loss: 0.00024264\n",
      "21120 - INFO - Step 29000 loss: 0.00019502\n",
      "21120 - INFO - Step 29050 loss: 0.00022853\n",
      "21120 - INFO - Epoch [67/200], Train Loss: 0.00024501, Test Loss: 0.00024479\n",
      "\n",
      "21120 - INFO - Step 29100 loss: 0.00026337\n",
      "21120 - INFO - Step 29150 loss: 0.00025220\n",
      "21120 - INFO - Step 29200 loss: 0.00021892\n",
      "21120 - INFO - Step 29250 loss: 0.00022915\n",
      "21120 - INFO - Step 29300 loss: 0.00021859\n",
      "21120 - INFO - Step 29350 loss: 0.00023572\n",
      "21120 - INFO - Step 29400 loss: 0.00027224\n",
      "21120 - INFO - Step 29450 loss: 0.00023764\n",
      "21120 - INFO - Step 29500 loss: 0.00021452\n",
      "21120 - INFO - Epoch [68/200], Train Loss: 0.00024406, Test Loss: 0.00024454\n",
      "\n",
      "21120 - INFO - Step 29550 loss: 0.00025218\n",
      "21120 - INFO - Step 29600 loss: 0.00024237\n",
      "21120 - INFO - Step 29650 loss: 0.00020141\n",
      "21120 - INFO - Step 29700 loss: 0.00023037\n",
      "21120 - INFO - Step 29750 loss: 0.00023401\n",
      "21120 - INFO - Step 29800 loss: 0.00023961\n",
      "21120 - INFO - Step 29850 loss: 0.00023557\n",
      "21120 - INFO - Step 29900 loss: 0.00026067\n",
      "21120 - INFO - Epoch [69/200], Train Loss: 0.00024331, Test Loss: 0.00024332\n",
      "\n",
      "21120 - INFO - Step 29950 loss: 0.00029446\n",
      "21120 - INFO - Step 30000 loss: 0.00025707\n",
      "21120 - INFO - Step 30050 loss: 0.00022987\n",
      "21120 - INFO - Step 30100 loss: 0.00025256\n",
      "21120 - INFO - Step 30150 loss: 0.00022016\n",
      "21120 - INFO - Step 30200 loss: 0.00022660\n",
      "21120 - INFO - Step 30250 loss: 0.00019811\n",
      "21120 - INFO - Step 30300 loss: 0.00022767\n",
      "21120 - INFO - Step 30350 loss: 0.00024855\n",
      "21120 - INFO - Epoch [70/200], Train Loss: 0.00024280, Test Loss: 0.00024173\n",
      "\n",
      "21120 - INFO - Step 30400 loss: 0.00026016\n",
      "21120 - INFO - Step 30450 loss: 0.00021762\n",
      "21120 - INFO - Step 30500 loss: 0.00028325\n",
      "21120 - INFO - Step 30550 loss: 0.00023875\n",
      "21120 - INFO - Step 30600 loss: 0.00025541\n",
      "21120 - INFO - Step 30650 loss: 0.00021814\n",
      "21120 - INFO - Step 30700 loss: 0.00022003\n",
      "21120 - INFO - Step 30750 loss: 0.00026101\n",
      "21120 - INFO - Step 30800 loss: 0.00019182\n",
      "21120 - INFO - Epoch [71/200], Train Loss: 0.00024187, Test Loss: 0.00024120\n",
      "\n",
      "21120 - INFO - Step 30850 loss: 0.00023502\n",
      "21120 - INFO - Step 30900 loss: 0.00024498\n",
      "21120 - INFO - Step 30950 loss: 0.00023583\n",
      "21120 - INFO - Step 31000 loss: 0.00020034\n",
      "21120 - INFO - Step 31050 loss: 0.00023506\n",
      "21120 - INFO - Step 31100 loss: 0.00025681\n",
      "21120 - INFO - Step 31150 loss: 0.00025227\n",
      "21120 - INFO - Step 31200 loss: 0.00023285\n",
      "21120 - INFO - Epoch [72/200], Train Loss: 0.00024098, Test Loss: 0.00024027\n",
      "\n",
      "21120 - INFO - Step 31250 loss: 0.00022182\n",
      "21120 - INFO - Step 31300 loss: 0.00022354\n",
      "21120 - INFO - Step 31350 loss: 0.00020635\n",
      "21120 - INFO - Step 31400 loss: 0.00023624\n",
      "21120 - INFO - Step 31450 loss: 0.00025609\n",
      "21120 - INFO - Step 31500 loss: 0.00024011\n",
      "21120 - INFO - Step 31550 loss: 0.00022516\n",
      "21120 - INFO - Step 31600 loss: 0.00024092\n",
      "21120 - INFO - Step 31650 loss: 0.00020379\n",
      "21120 - INFO - Epoch [73/200], Train Loss: 0.00024064, Test Loss: 0.00023941\n",
      "\n",
      "21120 - INFO - Step 31700 loss: 0.00022290\n",
      "21120 - INFO - Step 31750 loss: 0.00028594\n",
      "21120 - INFO - Step 31800 loss: 0.00022780\n",
      "21120 - INFO - Step 31850 loss: 0.00025941\n",
      "21120 - INFO - Step 31900 loss: 0.00021900\n",
      "21120 - INFO - Step 31950 loss: 0.00022159\n",
      "21120 - INFO - Step 32000 loss: 0.00021649\n",
      "21120 - INFO - Step 32050 loss: 0.00024465\n",
      "21120 - INFO - Step 32100 loss: 0.00024653\n",
      "21120 - INFO - Epoch [74/200], Train Loss: 0.00023977, Test Loss: 0.00024003\n",
      "\n",
      "21120 - INFO - Step 32150 loss: 0.00024608\n",
      "21120 - INFO - Step 32200 loss: 0.00023896\n",
      "21120 - INFO - Step 32250 loss: 0.00026293\n",
      "21120 - INFO - Step 32300 loss: 0.00020372\n",
      "21120 - INFO - Step 32350 loss: 0.00024727\n",
      "21120 - INFO - Step 32400 loss: 0.00022561\n",
      "21120 - INFO - Step 32450 loss: 0.00027153\n",
      "21120 - INFO - Step 32500 loss: 0.00022494\n",
      "21120 - INFO - Step 32550 loss: 0.00018988\n",
      "21120 - INFO - Epoch [75/200], Train Loss: 0.00023922, Test Loss: 0.00023965\n",
      "\n",
      "21120 - INFO - Step 32600 loss: 0.00022105\n",
      "21120 - INFO - Step 32650 loss: 0.00025517\n",
      "21120 - INFO - Step 32700 loss: 0.00022569\n",
      "21120 - INFO - Step 32750 loss: 0.00026213\n",
      "21120 - INFO - Step 32800 loss: 0.00024729\n",
      "21120 - INFO - Step 32850 loss: 0.00029761\n",
      "21120 - INFO - Step 32900 loss: 0.00023503\n",
      "21120 - INFO - Step 32950 loss: 0.00022885\n",
      "21120 - INFO - Epoch [76/200], Train Loss: 0.00023855, Test Loss: 0.00023897\n",
      "\n",
      "21120 - INFO - Step 33000 loss: 0.00026319\n",
      "21120 - INFO - Step 33050 loss: 0.00023080\n",
      "21120 - INFO - Step 33100 loss: 0.00023767\n",
      "21120 - INFO - Step 33150 loss: 0.00025927\n",
      "21120 - INFO - Step 33200 loss: 0.00022804\n",
      "21120 - INFO - Step 33250 loss: 0.00025254\n",
      "21120 - INFO - Step 33300 loss: 0.00028177\n",
      "21120 - INFO - Step 33350 loss: 0.00021767\n",
      "21120 - INFO - Step 33400 loss: 0.00022412\n",
      "21120 - INFO - Epoch [77/200], Train Loss: 0.00023821, Test Loss: 0.00023749\n",
      "\n",
      "21120 - INFO - Step 33450 loss: 0.00025001\n",
      "21120 - INFO - Step 33500 loss: 0.00023707\n",
      "21120 - INFO - Step 33550 loss: 0.00023342\n",
      "21120 - INFO - Step 33600 loss: 0.00023379\n",
      "21120 - INFO - Step 33650 loss: 0.00021859\n",
      "21120 - INFO - Step 33700 loss: 0.00022596\n",
      "21120 - INFO - Step 33750 loss: 0.00018842\n",
      "21120 - INFO - Step 33800 loss: 0.00021085\n",
      "21120 - INFO - Step 33850 loss: 0.00025994\n",
      "21120 - INFO - Epoch [78/200], Train Loss: 0.00023773, Test Loss: 0.00023935\n",
      "\n",
      "21120 - INFO - Step 33900 loss: 0.00023104\n",
      "21120 - INFO - Step 33950 loss: 0.00020935\n",
      "21120 - INFO - Step 34000 loss: 0.00021266\n",
      "21120 - INFO - Step 34050 loss: 0.00023427\n",
      "21120 - INFO - Step 34100 loss: 0.00027209\n",
      "21120 - INFO - Step 34150 loss: 0.00023706\n",
      "21120 - INFO - Step 34200 loss: 0.00029135\n",
      "21120 - INFO - Step 34250 loss: 0.00028414\n",
      "21120 - INFO - Epoch [79/200], Train Loss: 0.00023726, Test Loss: 0.00023675\n",
      "\n",
      "21120 - INFO - Step 34300 loss: 0.00021160\n",
      "21120 - INFO - Step 34350 loss: 0.00026374\n",
      "21120 - INFO - Step 34400 loss: 0.00020119\n",
      "21120 - INFO - Step 34450 loss: 0.00024079\n",
      "21120 - INFO - Step 34500 loss: 0.00022850\n",
      "21120 - INFO - Step 34550 loss: 0.00026095\n",
      "21120 - INFO - Step 34600 loss: 0.00025659\n",
      "21120 - INFO - Step 34650 loss: 0.00025567\n",
      "21120 - INFO - Step 34700 loss: 0.00022288\n",
      "21120 - INFO - Epoch [80/200], Train Loss: 0.00023709, Test Loss: 0.00023745\n",
      "\n",
      "21120 - INFO - Step 34750 loss: 0.00024759\n",
      "21120 - INFO - Step 34800 loss: 0.00023380\n",
      "21120 - INFO - Step 34850 loss: 0.00024424\n",
      "21120 - INFO - Step 34900 loss: 0.00023947\n",
      "21120 - INFO - Step 34950 loss: 0.00024514\n",
      "21120 - INFO - Step 35000 loss: 0.00024153\n",
      "21120 - INFO - Step 35050 loss: 0.00024619\n",
      "21120 - INFO - Step 35100 loss: 0.00021531\n",
      "21120 - INFO - Step 35150 loss: 0.00026519\n",
      "21120 - INFO - Epoch [81/200], Train Loss: 0.00023641, Test Loss: 0.00023617\n",
      "\n",
      "21120 - INFO - Step 35200 loss: 0.00024903\n",
      "21120 - INFO - Step 35250 loss: 0.00021805\n",
      "21120 - INFO - Step 35300 loss: 0.00026974\n",
      "21120 - INFO - Step 35350 loss: 0.00029005\n",
      "21120 - INFO - Step 35400 loss: 0.00021153\n",
      "21120 - INFO - Step 35450 loss: 0.00020624\n",
      "21120 - INFO - Step 35500 loss: 0.00023875\n",
      "21120 - INFO - Step 35550 loss: 0.00021854\n",
      "21120 - INFO - Epoch [82/200], Train Loss: 0.00023600, Test Loss: 0.00023516\n",
      "\n",
      "21120 - INFO - Step 35600 loss: 0.00022171\n",
      "21120 - INFO - Step 35650 loss: 0.00025910\n",
      "21120 - INFO - Step 35700 loss: 0.00021809\n",
      "21120 - INFO - Step 35750 loss: 0.00026627\n",
      "21120 - INFO - Step 35800 loss: 0.00023474\n",
      "21120 - INFO - Step 35850 loss: 0.00022681\n",
      "21120 - INFO - Step 35900 loss: 0.00020285\n",
      "21120 - INFO - Step 35950 loss: 0.00020558\n",
      "21120 - INFO - Step 36000 loss: 0.00021624\n",
      "21120 - INFO - Epoch [83/200], Train Loss: 0.00023564, Test Loss: 0.00023740\n",
      "\n",
      "21120 - INFO - Step 36050 loss: 0.00024142\n",
      "21120 - INFO - Step 36100 loss: 0.00023962\n",
      "21120 - INFO - Step 36150 loss: 0.00023211\n",
      "21120 - INFO - Step 36200 loss: 0.00020811\n",
      "21120 - INFO - Step 36250 loss: 0.00023167\n",
      "21120 - INFO - Step 36300 loss: 0.00023352\n",
      "21120 - INFO - Step 36350 loss: 0.00027431\n",
      "21120 - INFO - Step 36400 loss: 0.00023346\n",
      "21120 - INFO - Step 36450 loss: 0.00022431\n",
      "21120 - INFO - Epoch [84/200], Train Loss: 0.00023527, Test Loss: 0.00023701\n",
      "\n",
      "21120 - INFO - Step 36500 loss: 0.00024142\n",
      "21120 - INFO - Step 36550 loss: 0.00021604\n",
      "21120 - INFO - Step 36600 loss: 0.00023754\n",
      "21120 - INFO - Step 36650 loss: 0.00027077\n",
      "21120 - INFO - Step 36700 loss: 0.00022514\n",
      "21120 - INFO - Step 36750 loss: 0.00020555\n",
      "21120 - INFO - Step 36800 loss: 0.00023420\n",
      "21120 - INFO - Step 36850 loss: 0.00022427\n",
      "21120 - INFO - Epoch [85/200], Train Loss: 0.00023495, Test Loss: 0.00023676\n",
      "\n",
      "21120 - INFO - Step 36900 loss: 0.00022580\n",
      "21120 - INFO - Step 36950 loss: 0.00020900\n",
      "21120 - INFO - Step 37000 loss: 0.00018926\n",
      "21120 - INFO - Step 37050 loss: 0.00022418\n",
      "21120 - INFO - Step 37100 loss: 0.00023727\n",
      "21120 - INFO - Step 37150 loss: 0.00025330\n",
      "21120 - INFO - Step 37200 loss: 0.00025339\n",
      "21120 - INFO - Step 37250 loss: 0.00024432\n",
      "21120 - INFO - Step 37300 loss: 0.00024376\n",
      "21120 - INFO - Epoch [86/200], Train Loss: 0.00023488, Test Loss: 0.00023621\n",
      "\n",
      "21120 - INFO - Step 37350 loss: 0.00023938\n",
      "21120 - INFO - Step 37400 loss: 0.00020049\n",
      "21120 - INFO - Step 37450 loss: 0.00024271\n",
      "21120 - INFO - Step 37500 loss: 0.00025985\n",
      "21120 - INFO - Step 37550 loss: 0.00026786\n",
      "21120 - INFO - Step 37600 loss: 0.00025114\n",
      "21120 - INFO - Step 37650 loss: 0.00021863\n",
      "21120 - INFO - Step 37700 loss: 0.00018557\n",
      "21120 - INFO - Step 37750 loss: 0.00024894\n",
      "21120 - INFO - Epoch [87/200], Train Loss: 0.00023449, Test Loss: 0.00023669\n",
      "\n",
      "21120 - INFO - Step 37800 loss: 0.00021956\n",
      "21120 - INFO - Step 37850 loss: 0.00022442\n",
      "21120 - INFO - Step 37900 loss: 0.00026026\n",
      "21120 - INFO - Step 37950 loss: 0.00021223\n",
      "21120 - INFO - Step 38000 loss: 0.00021806\n",
      "21120 - INFO - Step 38050 loss: 0.00023111\n",
      "21120 - INFO - Step 38100 loss: 0.00020666\n",
      "21120 - INFO - Step 38150 loss: 0.00021429\n",
      "21120 - INFO - Epoch [88/200], Train Loss: 0.00023426, Test Loss: 0.00023414\n",
      "\n",
      "21120 - INFO - Step 38200 loss: 0.00023754\n",
      "21120 - INFO - Step 38250 loss: 0.00022701\n",
      "21120 - INFO - Step 38300 loss: 0.00025230\n",
      "21120 - INFO - Step 38350 loss: 0.00023609\n",
      "21120 - INFO - Step 38400 loss: 0.00021599\n",
      "21120 - INFO - Step 38450 loss: 0.00023119\n",
      "21120 - INFO - Step 38500 loss: 0.00023525\n",
      "21120 - INFO - Step 38550 loss: 0.00021442\n",
      "21120 - INFO - Step 38600 loss: 0.00026427\n",
      "21120 - INFO - Epoch [89/200], Train Loss: 0.00023402, Test Loss: 0.00023308\n",
      "\n",
      "21120 - INFO - Step 38650 loss: 0.00024698\n",
      "21120 - INFO - Step 38700 loss: 0.00021977\n",
      "21120 - INFO - Step 38750 loss: 0.00019324\n",
      "21120 - INFO - Step 38800 loss: 0.00025906\n",
      "21120 - INFO - Step 38850 loss: 0.00026813\n",
      "21120 - INFO - Step 38900 loss: 0.00024530\n",
      "21120 - INFO - Step 38950 loss: 0.00021503\n",
      "21120 - INFO - Step 39000 loss: 0.00026267\n",
      "21120 - INFO - Step 39050 loss: 0.00022129\n",
      "21120 - INFO - Epoch [90/200], Train Loss: 0.00023353, Test Loss: 0.00023254\n",
      "\n",
      "21120 - INFO - Step 39100 loss: 0.00019576\n",
      "21120 - INFO - Step 39150 loss: 0.00023804\n",
      "21120 - INFO - Step 39200 loss: 0.00024427\n",
      "21120 - INFO - Step 39250 loss: 0.00021566\n",
      "21120 - INFO - Step 39300 loss: 0.00023653\n",
      "21120 - INFO - Step 39350 loss: 0.00023594\n",
      "21120 - INFO - Step 39400 loss: 0.00024607\n",
      "21120 - INFO - Step 39450 loss: 0.00025612\n",
      "21120 - INFO - Epoch [91/200], Train Loss: 0.00023309, Test Loss: 0.00023430\n",
      "\n",
      "21120 - INFO - Step 39500 loss: 0.00024922\n",
      "21120 - INFO - Step 39550 loss: 0.00018953\n",
      "21120 - INFO - Step 39600 loss: 0.00024277\n",
      "21120 - INFO - Step 39650 loss: 0.00024627\n",
      "21120 - INFO - Step 39700 loss: 0.00024515\n",
      "21120 - INFO - Step 39750 loss: 0.00022777\n",
      "21120 - INFO - Step 39800 loss: 0.00027998\n",
      "21120 - INFO - Step 39850 loss: 0.00028604\n",
      "21120 - INFO - Step 39900 loss: 0.00024392\n",
      "21120 - INFO - Epoch [92/200], Train Loss: 0.00023302, Test Loss: 0.00023381\n",
      "\n",
      "21120 - INFO - Step 39950 loss: 0.00027103\n",
      "21120 - INFO - Step 40000 loss: 0.00022607\n",
      "21120 - INFO - Step 40050 loss: 0.00024662\n",
      "21120 - INFO - Step 40100 loss: 0.00024035\n",
      "21120 - INFO - Step 40150 loss: 0.00021412\n",
      "21120 - INFO - Step 40200 loss: 0.00019973\n",
      "21120 - INFO - Step 40250 loss: 0.00022948\n",
      "21120 - INFO - Step 40300 loss: 0.00022809\n",
      "21120 - INFO - Step 40350 loss: 0.00020933\n",
      "21120 - INFO - Epoch [93/200], Train Loss: 0.00023278, Test Loss: 0.00023343\n",
      "\n",
      "21120 - INFO - Step 40400 loss: 0.00027071\n",
      "21120 - INFO - Step 40450 loss: 0.00021478\n",
      "21120 - INFO - Step 40500 loss: 0.00025983\n",
      "21120 - INFO - Step 40550 loss: 0.00022329\n",
      "21120 - INFO - Step 40600 loss: 0.00023815\n",
      "21120 - INFO - Step 40650 loss: 0.00021462\n",
      "21120 - INFO - Step 40700 loss: 0.00021232\n",
      "21120 - INFO - Step 40750 loss: 0.00022234\n",
      "21120 - INFO - Epoch [94/200], Train Loss: 0.00023255, Test Loss: 0.00023270\n",
      "\n",
      "21120 - INFO - Step 40800 loss: 0.00020818\n",
      "21120 - INFO - Step 40850 loss: 0.00017003\n",
      "21120 - INFO - Step 40900 loss: 0.00024978\n",
      "21120 - INFO - Step 40950 loss: 0.00022818\n",
      "21120 - INFO - Step 41000 loss: 0.00022153\n",
      "21120 - INFO - Step 41050 loss: 0.00024408\n",
      "21120 - INFO - Step 41100 loss: 0.00022054\n",
      "21120 - INFO - Step 41150 loss: 0.00026758\n",
      "21120 - INFO - Step 41200 loss: 0.00024983\n",
      "21120 - INFO - Epoch [95/200], Train Loss: 0.00023217, Test Loss: 0.00023174\n",
      "\n",
      "21120 - INFO - Step 41250 loss: 0.00022710\n",
      "21120 - INFO - Step 41300 loss: 0.00023531\n",
      "21120 - INFO - Step 41350 loss: 0.00022352\n",
      "21120 - INFO - Step 41400 loss: 0.00022585\n",
      "21120 - INFO - Step 41450 loss: 0.00023110\n",
      "21120 - INFO - Step 41500 loss: 0.00020443\n",
      "21120 - INFO - Step 41550 loss: 0.00021469\n",
      "21120 - INFO - Step 41600 loss: 0.00023047\n",
      "21120 - INFO - Step 41650 loss: 0.00020836\n",
      "21120 - INFO - Epoch [96/200], Train Loss: 0.00023203, Test Loss: 0.00023266\n",
      "\n",
      "21120 - INFO - Step 41700 loss: 0.00021049\n",
      "21120 - INFO - Step 41750 loss: 0.00019917\n",
      "21120 - INFO - Step 41800 loss: 0.00025221\n",
      "21120 - INFO - Step 41850 loss: 0.00025303\n",
      "21120 - INFO - Step 41900 loss: 0.00024352\n",
      "21120 - INFO - Step 41950 loss: 0.00024516\n",
      "21120 - INFO - Step 42000 loss: 0.00021276\n",
      "21120 - INFO - Step 42050 loss: 0.00021996\n",
      "21120 - INFO - Epoch [97/200], Train Loss: 0.00023181, Test Loss: 0.00023252\n",
      "\n",
      "21120 - INFO - Step 42100 loss: 0.00024079\n",
      "21120 - INFO - Step 42150 loss: 0.00021659\n",
      "21120 - INFO - Step 42200 loss: 0.00021515\n",
      "21120 - INFO - Step 42250 loss: 0.00023516\n",
      "21120 - INFO - Step 42300 loss: 0.00021505\n",
      "21120 - INFO - Step 42350 loss: 0.00019129\n",
      "21120 - INFO - Step 42400 loss: 0.00024420\n",
      "21120 - INFO - Step 42450 loss: 0.00022318\n",
      "21120 - INFO - Step 42500 loss: 0.00025111\n",
      "21120 - INFO - Epoch [98/200], Train Loss: 0.00023141, Test Loss: 0.00023211\n",
      "\n",
      "21120 - INFO - Step 42550 loss: 0.00018480\n",
      "21120 - INFO - Step 42600 loss: 0.00021117\n",
      "21120 - INFO - Step 42650 loss: 0.00026091\n",
      "21120 - INFO - Step 42700 loss: 0.00028868\n",
      "21120 - INFO - Step 42750 loss: 0.00022501\n",
      "21120 - INFO - Step 42800 loss: 0.00018295\n",
      "21120 - INFO - Step 42850 loss: 0.00022029\n",
      "21120 - INFO - Step 42900 loss: 0.00023370\n",
      "21120 - INFO - Step 42950 loss: 0.00022698\n",
      "21120 - INFO - Epoch [99/200], Train Loss: 0.00023134, Test Loss: 0.00023150\n",
      "\n",
      "21120 - INFO - Step 43000 loss: 0.00027326\n",
      "21120 - INFO - Step 43050 loss: 0.00021989\n",
      "21120 - INFO - Step 43100 loss: 0.00026350\n",
      "21120 - INFO - Step 43150 loss: 0.00026634\n",
      "21120 - INFO - Step 43200 loss: 0.00021314\n",
      "21120 - INFO - Step 43250 loss: 0.00020409\n",
      "21120 - INFO - Step 43300 loss: 0.00023128\n",
      "21120 - INFO - Step 43350 loss: 0.00027840\n",
      "21120 - INFO - Step 43400 loss: 0.00018929\n",
      "21120 - INFO - Epoch [100/200], Train Loss: 0.00023103, Test Loss: 0.00023157\n",
      "\n",
      "21120 - INFO - Step 43450 loss: 0.00022056\n",
      "21120 - INFO - Step 43500 loss: 0.00024981\n",
      "21120 - INFO - Step 43550 loss: 0.00025255\n",
      "21120 - INFO - Step 43600 loss: 0.00020051\n",
      "21120 - INFO - Step 43650 loss: 0.00019231\n",
      "21120 - INFO - Step 43700 loss: 0.00023390\n",
      "21120 - INFO - Step 43750 loss: 0.00023415\n",
      "21120 - INFO - Step 43800 loss: 0.00026232\n",
      "21120 - INFO - Epoch [101/200], Train Loss: 0.00023094, Test Loss: 0.00023120\n",
      "\n",
      "21120 - INFO - Step 43850 loss: 0.00022081\n",
      "21120 - INFO - Step 43900 loss: 0.00020767\n",
      "21120 - INFO - Step 43950 loss: 0.00026026\n",
      "21120 - INFO - Step 44000 loss: 0.00021970\n",
      "21120 - INFO - Step 44050 loss: 0.00020363\n",
      "21120 - INFO - Step 44100 loss: 0.00022943\n",
      "21120 - INFO - Step 44150 loss: 0.00026236\n",
      "21120 - INFO - Step 44200 loss: 0.00020640\n",
      "21120 - INFO - Step 44250 loss: 0.00022749\n",
      "21120 - INFO - Epoch [102/200], Train Loss: 0.00023088, Test Loss: 0.00022955\n",
      "\n",
      "21120 - INFO - Step 44300 loss: 0.00025787\n",
      "21120 - INFO - Step 44350 loss: 0.00022357\n",
      "21120 - INFO - Step 44400 loss: 0.00026599\n",
      "21120 - INFO - Step 44450 loss: 0.00022191\n",
      "21120 - INFO - Step 44500 loss: 0.00025433\n",
      "21120 - INFO - Step 44550 loss: 0.00023783\n",
      "21120 - INFO - Step 44600 loss: 0.00024858\n",
      "21120 - INFO - Step 44650 loss: 0.00024981\n",
      "21120 - INFO - Step 44700 loss: 0.00022213\n",
      "21120 - INFO - Epoch [103/200], Train Loss: 0.00023053, Test Loss: 0.00023034\n",
      "\n",
      "21120 - INFO - Step 44750 loss: 0.00027149\n",
      "21120 - INFO - Step 44800 loss: 0.00020349\n",
      "21120 - INFO - Step 44850 loss: 0.00025655\n",
      "21120 - INFO - Step 44900 loss: 0.00022266\n",
      "21120 - INFO - Step 44950 loss: 0.00022521\n",
      "21120 - INFO - Step 45000 loss: 0.00021583\n",
      "21120 - INFO - Step 45050 loss: 0.00020587\n",
      "21120 - INFO - Step 45100 loss: 0.00019990\n",
      "21120 - INFO - Epoch [104/200], Train Loss: 0.00023056, Test Loss: 0.00023088\n",
      "\n",
      "21120 - INFO - Step 45150 loss: 0.00027538\n",
      "21120 - INFO - Step 45200 loss: 0.00020416\n",
      "21120 - INFO - Step 45250 loss: 0.00022634\n",
      "21120 - INFO - Step 45300 loss: 0.00024884\n",
      "21120 - INFO - Step 45350 loss: 0.00023233\n",
      "21120 - INFO - Step 45400 loss: 0.00020438\n",
      "21120 - INFO - Step 45450 loss: 0.00020802\n",
      "21120 - INFO - Step 45500 loss: 0.00024896\n",
      "21120 - INFO - Step 45550 loss: 0.00020786\n",
      "21120 - INFO - Epoch [105/200], Train Loss: 0.00023014, Test Loss: 0.00022962\n",
      "\n",
      "21120 - INFO - Step 45600 loss: 0.00023490\n",
      "21120 - INFO - Step 45650 loss: 0.00021863\n",
      "21120 - INFO - Step 45700 loss: 0.00020599\n",
      "21120 - INFO - Step 45750 loss: 0.00025039\n",
      "21120 - INFO - Step 45800 loss: 0.00022661\n",
      "21120 - INFO - Step 45850 loss: 0.00024146\n",
      "21120 - INFO - Step 45900 loss: 0.00020175\n",
      "21120 - INFO - Step 45950 loss: 0.00021217\n",
      "21120 - INFO - Step 46000 loss: 0.00019556\n",
      "21120 - INFO - Epoch [106/200], Train Loss: 0.00023020, Test Loss: 0.00023036\n",
      "\n",
      "21120 - INFO - Step 46050 loss: 0.00021103\n",
      "21120 - INFO - Step 46100 loss: 0.00022747\n",
      "21120 - INFO - Step 46150 loss: 0.00022166\n",
      "21120 - INFO - Step 46200 loss: 0.00022866\n",
      "21120 - INFO - Step 46250 loss: 0.00023748\n",
      "21120 - INFO - Step 46300 loss: 0.00025109\n",
      "21120 - INFO - Step 46350 loss: 0.00019326\n",
      "21120 - INFO - Step 46400 loss: 0.00025746\n",
      "21120 - INFO - Epoch [107/200], Train Loss: 0.00022986, Test Loss: 0.00022984\n",
      "\n",
      "21120 - INFO - Step 46450 loss: 0.00022719\n",
      "21120 - INFO - Step 46500 loss: 0.00020478\n",
      "21120 - INFO - Step 46550 loss: 0.00027940\n",
      "21120 - INFO - Step 46600 loss: 0.00022721\n",
      "21120 - INFO - Step 46650 loss: 0.00020692\n",
      "21120 - INFO - Step 46700 loss: 0.00023569\n",
      "21120 - INFO - Step 46750 loss: 0.00026584\n",
      "21120 - INFO - Step 46800 loss: 0.00026330\n",
      "21120 - INFO - Step 46850 loss: 0.00019581\n",
      "21120 - INFO - Epoch [108/200], Train Loss: 0.00022985, Test Loss: 0.00022839\n",
      "\n",
      "21120 - INFO - Step 46900 loss: 0.00026900\n",
      "21120 - INFO - Step 46950 loss: 0.00023480\n",
      "21120 - INFO - Step 47000 loss: 0.00022754\n",
      "21120 - INFO - Step 47050 loss: 0.00017739\n",
      "21120 - INFO - Step 47100 loss: 0.00023048\n",
      "21120 - INFO - Step 47150 loss: 0.00020537\n",
      "21120 - INFO - Step 47200 loss: 0.00022439\n",
      "21120 - INFO - Step 47250 loss: 0.00023781\n",
      "21120 - INFO - Step 47300 loss: 0.00022400\n",
      "21120 - INFO - Epoch [109/200], Train Loss: 0.00022970, Test Loss: 0.00022941\n",
      "\n",
      "21120 - INFO - Step 47350 loss: 0.00021290\n",
      "21120 - INFO - Step 47400 loss: 0.00024794\n",
      "21120 - INFO - Step 47450 loss: 0.00022600\n",
      "21120 - INFO - Step 47500 loss: 0.00021739\n",
      "21120 - INFO - Step 47550 loss: 0.00022843\n",
      "21120 - INFO - Step 47600 loss: 0.00023878\n",
      "21120 - INFO - Step 47650 loss: 0.00024793\n",
      "21120 - INFO - Step 47700 loss: 0.00019316\n",
      "21120 - INFO - Epoch [110/200], Train Loss: 0.00022938, Test Loss: 0.00022984\n",
      "\n",
      "21120 - INFO - Step 47750 loss: 0.00026136\n",
      "21120 - INFO - Step 47800 loss: 0.00020811\n",
      "21120 - INFO - Step 47850 loss: 0.00023545\n",
      "21120 - INFO - Step 47900 loss: 0.00023301\n",
      "21120 - INFO - Step 47950 loss: 0.00025716\n",
      "21120 - INFO - Step 48000 loss: 0.00021479\n",
      "21120 - INFO - Step 48050 loss: 0.00021379\n",
      "21120 - INFO - Step 48100 loss: 0.00023460\n",
      "21120 - INFO - Step 48150 loss: 0.00022342\n",
      "21120 - INFO - Epoch [111/200], Train Loss: 0.00022928, Test Loss: 0.00022955\n",
      "\n",
      "21120 - INFO - Step 48200 loss: 0.00021600\n",
      "21120 - INFO - Step 48250 loss: 0.00023556\n",
      "21120 - INFO - Step 48300 loss: 0.00022694\n",
      "21120 - INFO - Step 48350 loss: 0.00025431\n",
      "21120 - INFO - Step 48400 loss: 0.00021763\n",
      "21120 - INFO - Step 48450 loss: 0.00023151\n",
      "21120 - INFO - Step 48500 loss: 0.00022972\n",
      "21120 - INFO - Step 48550 loss: 0.00023702\n",
      "21120 - INFO - Step 48600 loss: 0.00024104\n",
      "21120 - INFO - Epoch [112/200], Train Loss: 0.00022909, Test Loss: 0.00023053\n",
      "\n",
      "21120 - INFO - Step 48650 loss: 0.00022402\n",
      "21120 - INFO - Step 48700 loss: 0.00021061\n",
      "21120 - INFO - Step 48750 loss: 0.00022272\n",
      "21120 - INFO - Step 48800 loss: 0.00021616\n",
      "21120 - INFO - Step 48850 loss: 0.00023368\n",
      "21120 - INFO - Step 48900 loss: 0.00024538\n",
      "21120 - INFO - Step 48950 loss: 0.00023132\n",
      "21120 - INFO - Step 49000 loss: 0.00026842\n",
      "21120 - INFO - Epoch [113/200], Train Loss: 0.00022920, Test Loss: 0.00023280\n",
      "\n",
      "21120 - INFO - Step 49050 loss: 0.00025948\n",
      "21120 - INFO - Step 49100 loss: 0.00025507\n",
      "21120 - INFO - Step 49150 loss: 0.00019493\n",
      "21120 - INFO - Step 49200 loss: 0.00021883\n",
      "21120 - INFO - Step 49250 loss: 0.00021737\n",
      "21120 - INFO - Step 49300 loss: 0.00023613\n",
      "21120 - INFO - Step 49350 loss: 0.00022648\n",
      "21120 - INFO - Step 49400 loss: 0.00021123\n",
      "21120 - INFO - Step 49450 loss: 0.00024783\n",
      "21120 - INFO - Epoch [114/200], Train Loss: 0.00022896, Test Loss: 0.00023217\n",
      "\n",
      "21120 - INFO - Step 49500 loss: 0.00025388\n",
      "21120 - INFO - Step 49550 loss: 0.00021181\n",
      "21120 - INFO - Step 49600 loss: 0.00021899\n",
      "21120 - INFO - Step 49650 loss: 0.00024400\n",
      "21120 - INFO - Step 49700 loss: 0.00028268\n",
      "21120 - INFO - Step 49750 loss: 0.00024083\n",
      "21120 - INFO - Step 49800 loss: 0.00022374\n",
      "21120 - INFO - Step 49850 loss: 0.00023239\n",
      "21120 - INFO - Step 49900 loss: 0.00022210\n",
      "21120 - INFO - Epoch [115/200], Train Loss: 0.00022878, Test Loss: 0.00022840\n",
      "\n",
      "21120 - INFO - Step 49950 loss: 0.00022669\n",
      "21120 - INFO - Step 50000 loss: 0.00024101\n",
      "21120 - INFO - Step 50050 loss: 0.00020541\n",
      "21120 - INFO - Step 50100 loss: 0.00021677\n",
      "21120 - INFO - Step 50150 loss: 0.00023568\n",
      "21120 - INFO - Step 50200 loss: 0.00020638\n",
      "21120 - INFO - Step 50250 loss: 0.00024059\n",
      "21120 - INFO - Step 50300 loss: 0.00024833\n",
      "21120 - INFO - Epoch [116/200], Train Loss: 0.00022856, Test Loss: 0.00023173\n",
      "\n",
      "21120 - INFO - Step 50350 loss: 0.00022701\n",
      "21120 - INFO - Step 50400 loss: 0.00026115\n",
      "21120 - INFO - Step 50450 loss: 0.00024673\n",
      "21120 - INFO - Step 50500 loss: 0.00022256\n",
      "21120 - INFO - Step 50550 loss: 0.00019701\n",
      "21120 - INFO - Step 50600 loss: 0.00022519\n",
      "21120 - INFO - Step 50650 loss: 0.00020162\n",
      "21120 - INFO - Step 50700 loss: 0.00026015\n",
      "21120 - INFO - Step 50750 loss: 0.00021009\n",
      "21120 - INFO - Epoch [117/200], Train Loss: 0.00022839, Test Loss: 0.00022886\n",
      "\n",
      "21120 - INFO - Step 50800 loss: 0.00023847\n",
      "21120 - INFO - Step 50850 loss: 0.00020549\n",
      "21120 - INFO - Step 50900 loss: 0.00028692\n",
      "21120 - INFO - Step 50950 loss: 0.00026813\n",
      "21120 - INFO - Step 51000 loss: 0.00021275\n",
      "21120 - INFO - Step 51050 loss: 0.00025925\n",
      "21120 - INFO - Step 51100 loss: 0.00020415\n",
      "21120 - INFO - Step 51150 loss: 0.00021395\n",
      "21120 - INFO - Step 51200 loss: 0.00023214\n",
      "21120 - INFO - Epoch [118/200], Train Loss: 0.00022858, Test Loss: 0.00022920\n",
      "\n",
      "21120 - INFO - Step 51250 loss: 0.00023756\n",
      "21120 - INFO - Step 51300 loss: 0.00019534\n",
      "21120 - INFO - Step 51350 loss: 0.00022480\n",
      "21120 - INFO - Step 51400 loss: 0.00022840\n",
      "21120 - INFO - Step 51450 loss: 0.00027050\n",
      "21120 - INFO - Step 51500 loss: 0.00024397\n",
      "21120 - INFO - Step 51550 loss: 0.00017765\n",
      "21120 - INFO - Step 51600 loss: 0.00022982\n",
      "21120 - INFO - Epoch [119/200], Train Loss: 0.00022815, Test Loss: 0.00022792\n",
      "\n",
      "21120 - INFO - Step 51650 loss: 0.00023184\n",
      "21120 - INFO - Step 51700 loss: 0.00025872\n",
      "21120 - INFO - Step 51750 loss: 0.00022626\n",
      "21120 - INFO - Step 51800 loss: 0.00016548\n",
      "21120 - INFO - Step 51850 loss: 0.00022952\n",
      "21120 - INFO - Step 51900 loss: 0.00022276\n",
      "21120 - INFO - Step 51950 loss: 0.00022093\n",
      "21120 - INFO - Step 52000 loss: 0.00018630\n",
      "21120 - INFO - Step 52050 loss: 0.00021554\n",
      "21120 - INFO - Epoch [120/200], Train Loss: 0.00022804, Test Loss: 0.00023000\n",
      "\n",
      "21120 - INFO - Step 52100 loss: 0.00020406\n",
      "21120 - INFO - Step 52150 loss: 0.00020029\n",
      "21120 - INFO - Step 52200 loss: 0.00022333\n",
      "21120 - INFO - Step 52250 loss: 0.00024345\n",
      "21120 - INFO - Step 52300 loss: 0.00029223\n",
      "21120 - INFO - Step 52350 loss: 0.00018826\n",
      "21120 - INFO - Step 52400 loss: 0.00028797\n",
      "21120 - INFO - Step 52450 loss: 0.00020625\n",
      "21120 - INFO - Step 52500 loss: 0.00022664\n",
      "21120 - INFO - Epoch [121/200], Train Loss: 0.00022798, Test Loss: 0.00022784\n",
      "\n",
      "21120 - INFO - Step 52550 loss: 0.00028406\n",
      "21120 - INFO - Step 52600 loss: 0.00016289\n",
      "21120 - INFO - Step 52650 loss: 0.00021824\n",
      "21120 - INFO - Step 52700 loss: 0.00023199\n",
      "21120 - INFO - Step 52750 loss: 0.00023225\n",
      "21120 - INFO - Step 52800 loss: 0.00019861\n",
      "21120 - INFO - Step 52850 loss: 0.00025137\n",
      "21120 - INFO - Step 52900 loss: 0.00024274\n",
      "21120 - INFO - Epoch [122/200], Train Loss: 0.00022790, Test Loss: 0.00022823\n",
      "\n",
      "21120 - INFO - Step 52950 loss: 0.00022429\n",
      "21120 - INFO - Step 53000 loss: 0.00022634\n",
      "21120 - INFO - Step 53050 loss: 0.00023067\n",
      "21120 - INFO - Step 53100 loss: 0.00021113\n",
      "21120 - INFO - Step 53150 loss: 0.00022258\n",
      "21120 - INFO - Step 53200 loss: 0.00023105\n",
      "21120 - INFO - Step 53250 loss: 0.00024907\n",
      "21120 - INFO - Step 53300 loss: 0.00020069\n",
      "21120 - INFO - Step 53350 loss: 0.00025401\n",
      "21120 - INFO - Epoch [123/200], Train Loss: 0.00022797, Test Loss: 0.00022693\n",
      "\n",
      "21120 - INFO - Step 53400 loss: 0.00023611\n",
      "21120 - INFO - Step 53450 loss: 0.00020817\n",
      "21120 - INFO - Step 53500 loss: 0.00021431\n",
      "21120 - INFO - Step 53550 loss: 0.00024364\n",
      "21120 - INFO - Step 53600 loss: 0.00024523\n",
      "21120 - INFO - Step 53650 loss: 0.00023201\n",
      "21120 - INFO - Step 53700 loss: 0.00023016\n",
      "21120 - INFO - Step 53750 loss: 0.00019331\n",
      "21120 - INFO - Step 53800 loss: 0.00024316\n",
      "21120 - INFO - Epoch [124/200], Train Loss: 0.00022780, Test Loss: 0.00022925\n",
      "\n",
      "21120 - INFO - Step 53850 loss: 0.00023256\n",
      "21120 - INFO - Step 53900 loss: 0.00023489\n",
      "21120 - INFO - Step 53950 loss: 0.00022065\n",
      "21120 - INFO - Step 54000 loss: 0.00026596\n",
      "21120 - INFO - Step 54050 loss: 0.00022967\n",
      "21120 - INFO - Step 54100 loss: 0.00023473\n",
      "21120 - INFO - Step 54150 loss: 0.00023455\n",
      "21120 - INFO - Step 54200 loss: 0.00019695\n",
      "21120 - INFO - Step 54250 loss: 0.00029827\n",
      "21120 - INFO - Epoch [125/200], Train Loss: 0.00022781, Test Loss: 0.00022698\n",
      "\n",
      "21120 - INFO - Step 54300 loss: 0.00018851\n",
      "21120 - INFO - Step 54350 loss: 0.00022155\n",
      "21120 - INFO - Step 54400 loss: 0.00023996\n",
      "21120 - INFO - Step 54450 loss: 0.00026075\n",
      "21120 - INFO - Step 54500 loss: 0.00024544\n",
      "21120 - INFO - Step 54550 loss: 0.00023516\n",
      "21120 - INFO - Step 54600 loss: 0.00021760\n",
      "21120 - INFO - Step 54650 loss: 0.00020520\n",
      "21120 - INFO - Epoch [126/200], Train Loss: 0.00022758, Test Loss: 0.00022852\n",
      "\n",
      "21120 - INFO - Step 54700 loss: 0.00014802\n",
      "21120 - INFO - Step 54750 loss: 0.00028877\n",
      "21120 - INFO - Step 54800 loss: 0.00020207\n",
      "21120 - INFO - Step 54850 loss: 0.00021845\n",
      "21120 - INFO - Step 54900 loss: 0.00021886\n",
      "21120 - INFO - Step 54950 loss: 0.00023843\n",
      "21120 - INFO - Step 55000 loss: 0.00021718\n",
      "21120 - INFO - Step 55050 loss: 0.00023066\n",
      "21120 - INFO - Step 55100 loss: 0.00023253\n",
      "21120 - INFO - Epoch [127/200], Train Loss: 0.00022737, Test Loss: 0.00022833\n",
      "\n",
      "21120 - INFO - Step 55150 loss: 0.00024759\n",
      "21120 - INFO - Step 55200 loss: 0.00023182\n",
      "21120 - INFO - Step 55250 loss: 0.00025215\n",
      "21120 - INFO - Step 55300 loss: 0.00019144\n",
      "21120 - INFO - Step 55350 loss: 0.00022691\n",
      "21120 - INFO - Step 55400 loss: 0.00023987\n",
      "21120 - INFO - Step 55450 loss: 0.00022659\n",
      "21120 - INFO - Step 55500 loss: 0.00021405\n",
      "21120 - INFO - Step 55550 loss: 0.00021858\n",
      "21120 - INFO - Epoch [128/200], Train Loss: 0.00022729, Test Loss: 0.00022911\n",
      "\n",
      "21120 - INFO - Step 55600 loss: 0.00018095\n",
      "21120 - INFO - Step 55650 loss: 0.00026487\n",
      "21120 - INFO - Step 55700 loss: 0.00020951\n",
      "21120 - INFO - Step 55750 loss: 0.00023239\n",
      "21120 - INFO - Step 55800 loss: 0.00022178\n",
      "21120 - INFO - Step 55850 loss: 0.00021390\n",
      "21120 - INFO - Step 55900 loss: 0.00022594\n",
      "21120 - INFO - Step 55950 loss: 0.00024641\n",
      "21120 - INFO - Epoch [129/200], Train Loss: 0.00022715, Test Loss: 0.00022669\n",
      "\n",
      "21120 - INFO - Step 56000 loss: 0.00025529\n",
      "21120 - INFO - Step 56050 loss: 0.00022120\n",
      "21120 - INFO - Step 56100 loss: 0.00022554\n",
      "21120 - INFO - Step 56150 loss: 0.00022380\n",
      "21120 - INFO - Step 56200 loss: 0.00025371\n",
      "21120 - INFO - Step 56250 loss: 0.00023884\n",
      "21120 - INFO - Step 56300 loss: 0.00021389\n",
      "21120 - INFO - Step 56350 loss: 0.00016730\n",
      "21120 - INFO - Step 56400 loss: 0.00025428\n",
      "21120 - INFO - Epoch [130/200], Train Loss: 0.00022715, Test Loss: 0.00022623\n",
      "\n",
      "21120 - INFO - Step 56450 loss: 0.00026992\n",
      "21120 - INFO - Step 56500 loss: 0.00022443\n",
      "21120 - INFO - Step 56550 loss: 0.00020330\n",
      "21120 - INFO - Step 56600 loss: 0.00022368\n",
      "21120 - INFO - Step 56650 loss: 0.00023393\n",
      "21120 - INFO - Step 56700 loss: 0.00022493\n",
      "21120 - INFO - Step 56750 loss: 0.00022442\n",
      "21120 - INFO - Step 56800 loss: 0.00018694\n",
      "21120 - INFO - Step 56850 loss: 0.00023126\n",
      "21120 - INFO - Epoch [131/200], Train Loss: 0.00022736, Test Loss: 0.00022640\n",
      "\n",
      "21120 - INFO - Step 56900 loss: 0.00020075\n",
      "21120 - INFO - Step 56950 loss: 0.00025201\n",
      "21120 - INFO - Step 57000 loss: 0.00023589\n",
      "21120 - INFO - Step 57050 loss: 0.00021725\n",
      "21120 - INFO - Step 57100 loss: 0.00019953\n",
      "21120 - INFO - Step 57150 loss: 0.00025775\n",
      "21120 - INFO - Step 57200 loss: 0.00021870\n",
      "21120 - INFO - Step 57250 loss: 0.00021085\n",
      "21120 - INFO - Epoch [132/200], Train Loss: 0.00022712, Test Loss: 0.00022789\n",
      "\n",
      "21120 - INFO - Step 57300 loss: 0.00025092\n",
      "21120 - INFO - Step 57350 loss: 0.00021639\n",
      "21120 - INFO - Step 57400 loss: 0.00019336\n",
      "21120 - INFO - Step 57450 loss: 0.00025858\n",
      "21120 - INFO - Step 57500 loss: 0.00023260\n",
      "21120 - INFO - Step 57550 loss: 0.00023485\n",
      "21120 - INFO - Step 57600 loss: 0.00020499\n",
      "21120 - INFO - Step 57650 loss: 0.00023977\n",
      "21120 - INFO - Step 57700 loss: 0.00018442\n",
      "21120 - INFO - Epoch [133/200], Train Loss: 0.00022705, Test Loss: 0.00022786\n",
      "\n",
      "21120 - INFO - Step 57750 loss: 0.00021055\n",
      "21120 - INFO - Step 57800 loss: 0.00022880\n",
      "21120 - INFO - Step 57850 loss: 0.00023916\n",
      "21120 - INFO - Step 57900 loss: 0.00022109\n",
      "21120 - INFO - Step 57950 loss: 0.00022837\n",
      "21120 - INFO - Step 58000 loss: 0.00023753\n",
      "21120 - INFO - Step 58050 loss: 0.00024653\n",
      "21120 - INFO - Step 58100 loss: 0.00018869\n",
      "21120 - INFO - Step 58150 loss: 0.00024498\n",
      "21120 - INFO - Epoch [134/200], Train Loss: 0.00022672, Test Loss: 0.00022720\n",
      "\n",
      "21120 - INFO - Step 58200 loss: 0.00021530\n",
      "21120 - INFO - Step 58250 loss: 0.00020784\n",
      "21120 - INFO - Step 58300 loss: 0.00022551\n",
      "21120 - INFO - Step 58350 loss: 0.00023927\n",
      "21120 - INFO - Step 58400 loss: 0.00024235\n",
      "21120 - INFO - Step 58450 loss: 0.00022480\n",
      "21120 - INFO - Step 58500 loss: 0.00022298\n",
      "21120 - INFO - Step 58550 loss: 0.00024293\n",
      "21120 - INFO - Epoch [135/200], Train Loss: 0.00022687, Test Loss: 0.00022596\n",
      "\n",
      "21120 - INFO - Step 58600 loss: 0.00020721\n",
      "21120 - INFO - Step 58650 loss: 0.00022982\n",
      "21120 - INFO - Step 58700 loss: 0.00022108\n",
      "21120 - INFO - Step 58750 loss: 0.00020492\n",
      "21120 - INFO - Step 58800 loss: 0.00024016\n",
      "21120 - INFO - Step 58850 loss: 0.00025397\n",
      "21120 - INFO - Step 58900 loss: 0.00026341\n",
      "21120 - INFO - Step 58950 loss: 0.00022004\n",
      "21120 - INFO - Step 59000 loss: 0.00022091\n",
      "21120 - INFO - Epoch [136/200], Train Loss: 0.00022700, Test Loss: 0.00022693\n",
      "\n",
      "21120 - INFO - Step 59050 loss: 0.00022323\n",
      "21120 - INFO - Step 59100 loss: 0.00022053\n",
      "21120 - INFO - Step 59150 loss: 0.00026976\n",
      "21120 - INFO - Step 59200 loss: 0.00023437\n",
      "21120 - INFO - Step 59250 loss: 0.00020901\n",
      "21120 - INFO - Step 59300 loss: 0.00018215\n",
      "21120 - INFO - Step 59350 loss: 0.00020076\n",
      "21120 - INFO - Step 59400 loss: 0.00021722\n",
      "21120 - INFO - Step 59450 loss: 0.00026782\n",
      "21120 - INFO - Epoch [137/200], Train Loss: 0.00022646, Test Loss: 0.00022674\n",
      "\n",
      "21120 - INFO - Step 59500 loss: 0.00022900\n",
      "21120 - INFO - Step 59550 loss: 0.00022433\n",
      "21120 - INFO - Step 59600 loss: 0.00022482\n",
      "21120 - INFO - Step 59650 loss: 0.00021613\n",
      "21120 - INFO - Step 59700 loss: 0.00020411\n",
      "21120 - INFO - Step 59750 loss: 0.00023372\n",
      "21120 - INFO - Step 59800 loss: 0.00020378\n",
      "21120 - INFO - Step 59850 loss: 0.00024328\n",
      "21120 - INFO - Epoch [138/200], Train Loss: 0.00022657, Test Loss: 0.00022805\n",
      "\n",
      "21120 - INFO - Step 59900 loss: 0.00024550\n",
      "21120 - INFO - Step 59950 loss: 0.00024743\n",
      "21120 - INFO - Step 60000 loss: 0.00025926\n",
      "21120 - INFO - Step 60050 loss: 0.00019444\n",
      "21120 - INFO - Step 60100 loss: 0.00022702\n",
      "21120 - INFO - Step 60150 loss: 0.00019565\n",
      "21120 - INFO - Step 60200 loss: 0.00018628\n",
      "21120 - INFO - Step 60250 loss: 0.00019914\n",
      "21120 - INFO - Step 60300 loss: 0.00021575\n",
      "21120 - INFO - Epoch [139/200], Train Loss: 0.00022632, Test Loss: 0.00022931\n",
      "\n",
      "21120 - INFO - Step 60350 loss: 0.00020996\n",
      "21120 - INFO - Step 60400 loss: 0.00023333\n",
      "21120 - INFO - Step 60450 loss: 0.00020379\n",
      "21120 - INFO - Step 60500 loss: 0.00021429\n",
      "21120 - INFO - Step 60550 loss: 0.00020834\n",
      "21120 - INFO - Step 60600 loss: 0.00021396\n",
      "21120 - INFO - Step 60650 loss: 0.00024398\n",
      "21120 - INFO - Step 60700 loss: 0.00026262\n",
      "21120 - INFO - Step 60750 loss: 0.00021892\n",
      "21120 - INFO - Epoch [140/200], Train Loss: 0.00022629, Test Loss: 0.00022715\n",
      "\n",
      "21120 - INFO - Step 60800 loss: 0.00023497\n",
      "21120 - INFO - Step 60850 loss: 0.00020767\n",
      "21120 - INFO - Step 60900 loss: 0.00020818\n",
      "21120 - INFO - Step 60950 loss: 0.00020960\n",
      "21120 - INFO - Step 61000 loss: 0.00019363\n",
      "21120 - INFO - Step 61050 loss: 0.00018720\n",
      "21120 - INFO - Step 61100 loss: 0.00018638\n",
      "21120 - INFO - Step 61150 loss: 0.00022081\n",
      "21120 - INFO - Epoch [141/200], Train Loss: 0.00022630, Test Loss: 0.00022653\n",
      "\n",
      "21120 - INFO - Step 61200 loss: 0.00019896\n",
      "21120 - INFO - Step 61250 loss: 0.00021494\n",
      "21120 - INFO - Step 61300 loss: 0.00023438\n",
      "21120 - INFO - Step 61350 loss: 0.00021944\n",
      "21120 - INFO - Step 61400 loss: 0.00020763\n",
      "21120 - INFO - Step 61450 loss: 0.00020641\n",
      "21120 - INFO - Step 61500 loss: 0.00023472\n",
      "21120 - INFO - Step 61550 loss: 0.00024112\n",
      "21120 - INFO - Step 61600 loss: 0.00022923\n",
      "21120 - INFO - Epoch [142/200], Train Loss: 0.00022623, Test Loss: 0.00022622\n",
      "\n",
      "21120 - INFO - Step 61650 loss: 0.00020039\n",
      "21120 - INFO - Step 61700 loss: 0.00022004\n",
      "21120 - INFO - Step 61750 loss: 0.00019601\n",
      "21120 - INFO - Step 61800 loss: 0.00023741\n",
      "21120 - INFO - Step 61850 loss: 0.00020645\n",
      "21120 - INFO - Step 61900 loss: 0.00023805\n",
      "21120 - INFO - Step 61950 loss: 0.00023437\n",
      "21120 - INFO - Step 62000 loss: 0.00022822\n",
      "21120 - INFO - Step 62050 loss: 0.00024689\n",
      "21120 - INFO - Epoch [143/200], Train Loss: 0.00022615, Test Loss: 0.00022735\n",
      "\n",
      "21120 - INFO - Step 62100 loss: 0.00025616\n",
      "21120 - INFO - Step 62150 loss: 0.00022224\n",
      "21120 - INFO - Step 62200 loss: 0.00021859\n",
      "21120 - INFO - Step 62250 loss: 0.00023134\n",
      "21120 - INFO - Step 62300 loss: 0.00022605\n",
      "21120 - INFO - Step 62350 loss: 0.00025204\n",
      "21120 - INFO - Step 62400 loss: 0.00024676\n",
      "21120 - INFO - Step 62450 loss: 0.00023935\n",
      "21120 - INFO - Epoch [144/200], Train Loss: 0.00022616, Test Loss: 0.00022571\n",
      "\n",
      "21120 - INFO - Step 62500 loss: 0.00021276\n",
      "21120 - INFO - Step 62550 loss: 0.00021451\n",
      "21120 - INFO - Step 62600 loss: 0.00022965\n",
      "21120 - INFO - Step 62650 loss: 0.00019280\n",
      "21120 - INFO - Step 62700 loss: 0.00027244\n",
      "21120 - INFO - Step 62750 loss: 0.00018460\n",
      "21120 - INFO - Step 62800 loss: 0.00021255\n",
      "21120 - INFO - Step 62850 loss: 0.00024690\n",
      "21120 - INFO - Step 62900 loss: 0.00023786\n",
      "21120 - INFO - Epoch [145/200], Train Loss: 0.00022583, Test Loss: 0.00023013\n",
      "\n",
      "21120 - INFO - Step 62950 loss: 0.00021265\n",
      "21120 - INFO - Step 63000 loss: 0.00022236\n",
      "21120 - INFO - Step 63050 loss: 0.00023522\n",
      "21120 - INFO - Step 63100 loss: 0.00022426\n",
      "21120 - INFO - Step 63150 loss: 0.00025281\n",
      "21120 - INFO - Step 63200 loss: 0.00025404\n",
      "21120 - INFO - Step 63250 loss: 0.00020550\n",
      "21120 - INFO - Step 63300 loss: 0.00025196\n",
      "21120 - INFO - Step 63350 loss: 0.00023157\n",
      "21120 - INFO - Epoch [146/200], Train Loss: 0.00022628, Test Loss: 0.00022664\n",
      "\n",
      "21120 - INFO - Step 63400 loss: 0.00022919\n",
      "21120 - INFO - Step 63450 loss: 0.00023345\n",
      "21120 - INFO - Step 63500 loss: 0.00025145\n",
      "21120 - INFO - Step 63550 loss: 0.00022990\n",
      "21120 - INFO - Step 63600 loss: 0.00019893\n",
      "21120 - INFO - Step 63650 loss: 0.00021773\n",
      "21120 - INFO - Step 63700 loss: 0.00026678\n",
      "21120 - INFO - Step 63750 loss: 0.00022899\n",
      "21120 - INFO - Epoch [147/200], Train Loss: 0.00022591, Test Loss: 0.00022593\n",
      "\n",
      "21120 - INFO - Step 63800 loss: 0.00019430\n",
      "21120 - INFO - Step 63850 loss: 0.00020935\n",
      "21120 - INFO - Step 63900 loss: 0.00020699\n",
      "21120 - INFO - Step 63950 loss: 0.00025575\n",
      "21120 - INFO - Step 64000 loss: 0.00019446\n",
      "21120 - INFO - Step 64050 loss: 0.00024033\n",
      "21120 - INFO - Step 64100 loss: 0.00026258\n",
      "21120 - INFO - Step 64150 loss: 0.00021153\n",
      "21120 - INFO - Step 64200 loss: 0.00023438\n",
      "21120 - INFO - Epoch [148/200], Train Loss: 0.00022595, Test Loss: 0.00022513\n",
      "\n",
      "21120 - INFO - Step 64250 loss: 0.00024119\n",
      "21120 - INFO - Step 64300 loss: 0.00021908\n",
      "21120 - INFO - Step 64350 loss: 0.00018840\n",
      "21120 - INFO - Step 64400 loss: 0.00023243\n",
      "21120 - INFO - Step 64450 loss: 0.00021642\n",
      "21120 - INFO - Step 64500 loss: 0.00021637\n",
      "21120 - INFO - Step 64550 loss: 0.00022428\n",
      "21120 - INFO - Step 64600 loss: 0.00021093\n",
      "21120 - INFO - Step 64650 loss: 0.00020361\n",
      "21120 - INFO - Epoch [149/200], Train Loss: 0.00022583, Test Loss: 0.00022586\n",
      "\n",
      "21120 - INFO - Step 64700 loss: 0.00022014\n",
      "21120 - INFO - Step 64750 loss: 0.00022260\n",
      "21120 - INFO - Step 64800 loss: 0.00021316\n",
      "21120 - INFO - Step 64850 loss: 0.00022867\n",
      "21120 - INFO - Step 64900 loss: 0.00020648\n",
      "21120 - INFO - Step 64950 loss: 0.00025577\n",
      "21120 - INFO - Step 65000 loss: 0.00023641\n",
      "21120 - INFO - Step 65050 loss: 0.00021172\n",
      "21120 - INFO - Step 65100 loss: 0.00017503\n",
      "21120 - INFO - Epoch [150/200], Train Loss: 0.00022574, Test Loss: 0.00022507\n",
      "\n",
      "21120 - INFO - Step 65150 loss: 0.00025577\n",
      "21120 - INFO - Step 65200 loss: 0.00019160\n",
      "21120 - INFO - Step 65250 loss: 0.00022803\n",
      "21120 - INFO - Step 65300 loss: 0.00022911\n",
      "21120 - INFO - Step 65350 loss: 0.00021556\n",
      "21120 - INFO - Step 65400 loss: 0.00022904\n",
      "21120 - INFO - Step 65450 loss: 0.00017817\n",
      "21120 - INFO - Step 65500 loss: 0.00020223\n",
      "21120 - INFO - Epoch [151/200], Train Loss: 0.00022570, Test Loss: 0.00022496\n",
      "\n",
      "21120 - INFO - Step 65550 loss: 0.00024616\n",
      "21120 - INFO - Step 65600 loss: 0.00022508\n",
      "21120 - INFO - Step 65650 loss: 0.00020349\n",
      "21120 - INFO - Step 65700 loss: 0.00020188\n",
      "21120 - INFO - Step 65750 loss: 0.00021019\n",
      "21120 - INFO - Step 65800 loss: 0.00019863\n",
      "21120 - INFO - Step 65850 loss: 0.00022095\n",
      "21120 - INFO - Step 65900 loss: 0.00023068\n",
      "21120 - INFO - Step 65950 loss: 0.00020816\n",
      "21120 - INFO - Epoch [152/200], Train Loss: 0.00022570, Test Loss: 0.00022492\n",
      "\n",
      "21120 - INFO - Step 66000 loss: 0.00023958\n",
      "21120 - INFO - Step 66050 loss: 0.00023254\n",
      "21120 - INFO - Step 66100 loss: 0.00022166\n",
      "21120 - INFO - Step 66150 loss: 0.00021863\n",
      "21120 - INFO - Step 66200 loss: 0.00024447\n",
      "21120 - INFO - Step 66250 loss: 0.00017538\n",
      "21120 - INFO - Step 66300 loss: 0.00023890\n",
      "21120 - INFO - Step 66350 loss: 0.00023291\n",
      "21120 - INFO - Step 66400 loss: 0.00022743\n",
      "21120 - INFO - Epoch [153/200], Train Loss: 0.00022570, Test Loss: 0.00022668\n",
      "\n",
      "21120 - INFO - Step 66450 loss: 0.00021626\n",
      "21120 - INFO - Step 66500 loss: 0.00022111\n",
      "21120 - INFO - Step 66550 loss: 0.00024734\n",
      "21120 - INFO - Step 66600 loss: 0.00023830\n",
      "21120 - INFO - Step 66650 loss: 0.00020167\n",
      "21120 - INFO - Step 66700 loss: 0.00021181\n",
      "21120 - INFO - Step 66750 loss: 0.00023113\n",
      "21120 - INFO - Step 66800 loss: 0.00024387\n",
      "21120 - INFO - Epoch [154/200], Train Loss: 0.00022554, Test Loss: 0.00022622\n",
      "\n",
      "21120 - INFO - Step 66850 loss: 0.00024440\n",
      "21120 - INFO - Step 66900 loss: 0.00023462\n",
      "21120 - INFO - Step 66950 loss: 0.00021249\n",
      "21120 - INFO - Step 67000 loss: 0.00024022\n",
      "21120 - INFO - Step 67050 loss: 0.00022255\n",
      "21120 - INFO - Step 67100 loss: 0.00023091\n",
      "21120 - INFO - Step 67150 loss: 0.00019997\n",
      "21120 - INFO - Step 67200 loss: 0.00022274\n",
      "21120 - INFO - Step 67250 loss: 0.00023048\n",
      "21120 - INFO - Epoch [155/200], Train Loss: 0.00022568, Test Loss: 0.00022587\n",
      "\n",
      "21120 - INFO - Step 67300 loss: 0.00022025\n",
      "21120 - INFO - Step 67350 loss: 0.00022838\n",
      "21120 - INFO - Step 67400 loss: 0.00021823\n",
      "21120 - INFO - Step 67450 loss: 0.00023023\n",
      "21120 - INFO - Step 67500 loss: 0.00022013\n",
      "21120 - INFO - Step 67550 loss: 0.00022898\n",
      "21120 - INFO - Step 67600 loss: 0.00019920\n",
      "21120 - INFO - Step 67650 loss: 0.00026147\n",
      "21120 - INFO - Step 67700 loss: 0.00022262\n",
      "21120 - INFO - Epoch [156/200], Train Loss: 0.00022550, Test Loss: 0.00022608\n",
      "\n",
      "21120 - INFO - Step 67750 loss: 0.00025065\n",
      "21120 - INFO - Step 67800 loss: 0.00024937\n",
      "21120 - INFO - Step 67850 loss: 0.00026691\n",
      "21120 - INFO - Step 67900 loss: 0.00019693\n",
      "21120 - INFO - Step 67950 loss: 0.00022984\n",
      "21120 - INFO - Step 68000 loss: 0.00022038\n",
      "21120 - INFO - Step 68050 loss: 0.00021043\n",
      "21120 - INFO - Step 68100 loss: 0.00020871\n",
      "21120 - INFO - Epoch [157/200], Train Loss: 0.00022562, Test Loss: 0.00022650\n",
      "\n",
      "21120 - INFO - Step 68150 loss: 0.00026633\n",
      "21120 - INFO - Step 68200 loss: 0.00022535\n",
      "21120 - INFO - Step 68250 loss: 0.00023032\n",
      "21120 - INFO - Step 68300 loss: 0.00021550\n",
      "21120 - INFO - Step 68350 loss: 0.00021208\n",
      "21120 - INFO - Step 68400 loss: 0.00027298\n",
      "21120 - INFO - Step 68450 loss: 0.00020039\n",
      "21120 - INFO - Step 68500 loss: 0.00025492\n",
      "21120 - INFO - Step 68550 loss: 0.00018915\n",
      "21120 - INFO - Epoch [158/200], Train Loss: 0.00022534, Test Loss: 0.00022883\n",
      "\n",
      "21120 - INFO - Step 68600 loss: 0.00022148\n",
      "21120 - INFO - Step 68650 loss: 0.00016858\n",
      "21120 - INFO - Step 68700 loss: 0.00022516\n",
      "21120 - INFO - Step 68750 loss: 0.00024623\n",
      "21120 - INFO - Step 68800 loss: 0.00024206\n",
      "21120 - INFO - Step 68850 loss: 0.00021461\n",
      "21120 - INFO - Step 68900 loss: 0.00022631\n",
      "21120 - INFO - Step 68950 loss: 0.00025237\n",
      "21120 - INFO - Step 69000 loss: 0.00020884\n",
      "21120 - INFO - Epoch [159/200], Train Loss: 0.00022541, Test Loss: 0.00022541\n",
      "\n",
      "21120 - INFO - Step 69050 loss: 0.00025093\n",
      "21120 - INFO - Step 69100 loss: 0.00023323\n",
      "21120 - INFO - Step 69150 loss: 0.00022789\n",
      "21120 - INFO - Step 69200 loss: 0.00021993\n",
      "21120 - INFO - Step 69250 loss: 0.00019651\n",
      "21120 - INFO - Step 69300 loss: 0.00023167\n",
      "21120 - INFO - Step 69350 loss: 0.00020311\n",
      "21120 - INFO - Step 69400 loss: 0.00023203\n",
      "21120 - INFO - Epoch [160/200], Train Loss: 0.00022523, Test Loss: 0.00022608\n",
      "\n",
      "21120 - INFO - Step 69450 loss: 0.00021703\n",
      "21120 - INFO - Step 69500 loss: 0.00023212\n",
      "21120 - INFO - Step 69550 loss: 0.00024284\n",
      "21120 - INFO - Step 69600 loss: 0.00023784\n",
      "21120 - INFO - Step 69650 loss: 0.00023701\n",
      "21120 - INFO - Step 69700 loss: 0.00020446\n",
      "21120 - INFO - Step 69750 loss: 0.00022538\n",
      "21120 - INFO - Step 69800 loss: 0.00019097\n",
      "21120 - INFO - Step 69850 loss: 0.00025475\n",
      "21120 - INFO - Epoch [161/200], Train Loss: 0.00022517, Test Loss: 0.00022779\n",
      "\n",
      "21120 - INFO - Step 69900 loss: 0.00023309\n",
      "21120 - INFO - Step 69950 loss: 0.00022235\n",
      "21120 - INFO - Step 70000 loss: 0.00021313\n",
      "21120 - INFO - Step 70050 loss: 0.00024785\n",
      "21120 - INFO - Step 70100 loss: 0.00022800\n",
      "21120 - INFO - Step 70150 loss: 0.00020970\n",
      "21120 - INFO - Step 70200 loss: 0.00021479\n",
      "21120 - INFO - Step 70250 loss: 0.00022395\n",
      "21120 - INFO - Step 70300 loss: 0.00024881\n",
      "21120 - INFO - Epoch [162/200], Train Loss: 0.00022555, Test Loss: 0.00022752\n",
      "\n",
      "21120 - INFO - Step 70350 loss: 0.00025159\n",
      "21120 - INFO - Step 70400 loss: 0.00023027\n",
      "21120 - INFO - Step 70450 loss: 0.00020899\n",
      "21120 - INFO - Step 70500 loss: 0.00020704\n",
      "21120 - INFO - Step 70550 loss: 0.00022483\n",
      "21120 - INFO - Step 70600 loss: 0.00023572\n",
      "21120 - INFO - Step 70650 loss: 0.00024196\n",
      "21120 - INFO - Step 70700 loss: 0.00020408\n",
      "21120 - INFO - Epoch [163/200], Train Loss: 0.00022521, Test Loss: 0.00022439\n",
      "\n",
      "21120 - INFO - Step 70750 loss: 0.00023836\n",
      "21120 - INFO - Step 70800 loss: 0.00025571\n",
      "21120 - INFO - Step 70850 loss: 0.00021027\n",
      "21120 - INFO - Step 70900 loss: 0.00023135\n",
      "21120 - INFO - Step 70950 loss: 0.00015689\n",
      "21120 - INFO - Step 71000 loss: 0.00023918\n",
      "21120 - INFO - Step 71050 loss: 0.00020322\n",
      "21120 - INFO - Step 71100 loss: 0.00021001\n",
      "21120 - INFO - Step 71150 loss: 0.00019288\n",
      "21120 - INFO - Epoch [164/200], Train Loss: 0.00022500, Test Loss: 0.00022509\n",
      "\n",
      "21120 - INFO - Step 71200 loss: 0.00019750\n",
      "21120 - INFO - Step 71250 loss: 0.00024020\n",
      "21120 - INFO - Step 71300 loss: 0.00020655\n",
      "21120 - INFO - Step 71350 loss: 0.00024440\n",
      "21120 - INFO - Step 71400 loss: 0.00020218\n",
      "21120 - INFO - Step 71450 loss: 0.00022289\n",
      "21120 - INFO - Step 71500 loss: 0.00023658\n",
      "21120 - INFO - Step 71550 loss: 0.00023985\n",
      "21120 - INFO - Step 71600 loss: 0.00023852\n",
      "21120 - INFO - Epoch [165/200], Train Loss: 0.00022525, Test Loss: 0.00022547\n",
      "\n",
      "21120 - INFO - Step 71650 loss: 0.00024132\n",
      "21120 - INFO - Step 71700 loss: 0.00023346\n",
      "21120 - INFO - Step 71750 loss: 0.00023045\n",
      "21120 - INFO - Step 71800 loss: 0.00023991\n",
      "21120 - INFO - Step 71850 loss: 0.00023505\n",
      "21120 - INFO - Step 71900 loss: 0.00021279\n",
      "21120 - INFO - Step 71950 loss: 0.00023134\n",
      "21120 - INFO - Step 72000 loss: 0.00022869\n",
      "21120 - INFO - Epoch [166/200], Train Loss: 0.00022501, Test Loss: 0.00022480\n",
      "\n",
      "21120 - INFO - Step 72050 loss: 0.00023158\n",
      "21120 - INFO - Step 72100 loss: 0.00024978\n",
      "21120 - INFO - Step 72150 loss: 0.00020348\n",
      "21120 - INFO - Step 72200 loss: 0.00020023\n",
      "21120 - INFO - Step 72250 loss: 0.00024322\n",
      "21120 - INFO - Step 72300 loss: 0.00027440\n",
      "21120 - INFO - Step 72350 loss: 0.00020666\n",
      "21120 - INFO - Step 72400 loss: 0.00023229\n",
      "21120 - INFO - Step 72450 loss: 0.00021711\n",
      "21120 - INFO - Epoch [167/200], Train Loss: 0.00022514, Test Loss: 0.00022657\n",
      "\n",
      "21120 - INFO - Step 72500 loss: 0.00021505\n",
      "21120 - INFO - Step 72550 loss: 0.00019274\n",
      "21120 - INFO - Step 72600 loss: 0.00020712\n",
      "21120 - INFO - Step 72650 loss: 0.00020940\n",
      "21120 - INFO - Step 72700 loss: 0.00022621\n",
      "21120 - INFO - Step 72750 loss: 0.00018618\n",
      "21120 - INFO - Step 72800 loss: 0.00022029\n",
      "21120 - INFO - Step 72850 loss: 0.00019553\n",
      "21120 - INFO - Step 72900 loss: 0.00022110\n",
      "21120 - INFO - Epoch [168/200], Train Loss: 0.00022486, Test Loss: 0.00022468\n",
      "\n",
      "21120 - INFO - Step 72950 loss: 0.00024790\n",
      "21120 - INFO - Step 73000 loss: 0.00023250\n",
      "21120 - INFO - Step 73050 loss: 0.00023362\n",
      "21120 - INFO - Step 73100 loss: 0.00018764\n",
      "21120 - INFO - Step 73150 loss: 0.00025803\n",
      "21120 - INFO - Step 73200 loss: 0.00022727\n",
      "21120 - INFO - Step 73250 loss: 0.00022448\n",
      "21120 - INFO - Step 73300 loss: 0.00024997\n",
      "21120 - INFO - Epoch [169/200], Train Loss: 0.00022494, Test Loss: 0.00022629\n",
      "\n",
      "21120 - INFO - Step 73350 loss: 0.00022787\n",
      "21120 - INFO - Step 73400 loss: 0.00019974\n",
      "21120 - INFO - Step 73450 loss: 0.00026743\n",
      "21120 - INFO - Step 73500 loss: 0.00028409\n",
      "21120 - INFO - Step 73550 loss: 0.00024110\n",
      "21120 - INFO - Step 73600 loss: 0.00023281\n",
      "21120 - INFO - Step 73650 loss: 0.00016096\n",
      "21120 - INFO - Step 73700 loss: 0.00020812\n",
      "21120 - INFO - Step 73750 loss: 0.00023464\n",
      "21120 - INFO - Epoch [170/200], Train Loss: 0.00022493, Test Loss: 0.00022398\n",
      "\n",
      "21120 - INFO - Step 73800 loss: 0.00019561\n",
      "21120 - INFO - Step 73850 loss: 0.00020984\n",
      "21120 - INFO - Step 73900 loss: 0.00026135\n",
      "21120 - INFO - Step 73950 loss: 0.00021598\n",
      "21120 - INFO - Step 74000 loss: 0.00021742\n",
      "21120 - INFO - Step 74050 loss: 0.00021530\n",
      "21120 - INFO - Step 74100 loss: 0.00020612\n",
      "21120 - INFO - Step 74150 loss: 0.00026346\n",
      "21120 - INFO - Step 74200 loss: 0.00018118\n",
      "21120 - INFO - Epoch [171/200], Train Loss: 0.00022502, Test Loss: 0.00022544\n",
      "\n",
      "21120 - INFO - Step 74250 loss: 0.00018828\n",
      "21120 - INFO - Step 74300 loss: 0.00025500\n",
      "21120 - INFO - Step 74350 loss: 0.00021432\n",
      "21120 - INFO - Step 74400 loss: 0.00024532\n",
      "21120 - INFO - Step 74450 loss: 0.00022059\n",
      "21120 - INFO - Step 74500 loss: 0.00022468\n",
      "21120 - INFO - Step 74550 loss: 0.00021392\n",
      "21120 - INFO - Step 74600 loss: 0.00024132\n",
      "21120 - INFO - Epoch [172/200], Train Loss: 0.00022486, Test Loss: 0.00022591\n",
      "\n",
      "21120 - INFO - Step 74650 loss: 0.00022436\n",
      "21120 - INFO - Step 74700 loss: 0.00021785\n",
      "21120 - INFO - Step 74750 loss: 0.00023667\n",
      "21120 - INFO - Step 74800 loss: 0.00021638\n",
      "21120 - INFO - Step 74850 loss: 0.00021010\n",
      "21120 - INFO - Step 74900 loss: 0.00024001\n",
      "21120 - INFO - Step 74950 loss: 0.00023853\n",
      "21120 - INFO - Step 75000 loss: 0.00023809\n",
      "21120 - INFO - Step 75050 loss: 0.00022568\n",
      "21120 - INFO - Epoch [173/200], Train Loss: 0.00022485, Test Loss: 0.00022433\n",
      "\n",
      "21120 - INFO - Step 75100 loss: 0.00026483\n",
      "21120 - INFO - Step 75150 loss: 0.00026985\n",
      "21120 - INFO - Step 75200 loss: 0.00022672\n",
      "21120 - INFO - Step 75250 loss: 0.00020859\n",
      "21120 - INFO - Step 75300 loss: 0.00020277\n",
      "21120 - INFO - Step 75350 loss: 0.00023281\n",
      "21120 - INFO - Step 75400 loss: 0.00020884\n",
      "21120 - INFO - Step 75450 loss: 0.00025003\n",
      "21120 - INFO - Step 75500 loss: 0.00018419\n",
      "21120 - INFO - Epoch [174/200], Train Loss: 0.00022477, Test Loss: 0.00022624\n",
      "\n",
      "21120 - INFO - Step 75550 loss: 0.00019865\n",
      "21120 - INFO - Step 75600 loss: 0.00018608\n",
      "21120 - INFO - Step 75650 loss: 0.00023249\n",
      "21120 - INFO - Step 75700 loss: 0.00019941\n",
      "21120 - INFO - Step 75750 loss: 0.00024447\n",
      "21120 - INFO - Step 75800 loss: 0.00021904\n",
      "21120 - INFO - Step 75850 loss: 0.00021643\n",
      "21120 - INFO - Step 75900 loss: 0.00021668\n",
      "21120 - INFO - Step 75950 loss: 0.00017986\n",
      "21120 - INFO - Epoch [175/200], Train Loss: 0.00022475, Test Loss: 0.00022523\n",
      "\n",
      "21120 - INFO - Step 76000 loss: 0.00024188\n",
      "21120 - INFO - Step 76050 loss: 0.00022836\n",
      "21120 - INFO - Step 76100 loss: 0.00025460\n",
      "21120 - INFO - Step 76150 loss: 0.00023139\n",
      "21120 - INFO - Step 76200 loss: 0.00023038\n",
      "21120 - INFO - Step 76250 loss: 0.00026617\n",
      "21120 - INFO - Step 76300 loss: 0.00021780\n",
      "21120 - INFO - Step 76350 loss: 0.00022901\n",
      "21120 - INFO - Epoch [176/200], Train Loss: 0.00022477, Test Loss: 0.00022503\n",
      "\n",
      "21120 - INFO - Step 76400 loss: 0.00021918\n",
      "21120 - INFO - Step 76450 loss: 0.00022772\n",
      "21120 - INFO - Step 76500 loss: 0.00025609\n",
      "21120 - INFO - Step 76550 loss: 0.00023036\n",
      "21120 - INFO - Step 76600 loss: 0.00026240\n",
      "21120 - INFO - Step 76650 loss: 0.00019517\n",
      "21120 - INFO - Step 76700 loss: 0.00022749\n",
      "21120 - INFO - Step 76750 loss: 0.00023786\n",
      "21120 - INFO - Step 76800 loss: 0.00026135\n",
      "21120 - INFO - Epoch [177/200], Train Loss: 0.00022466, Test Loss: 0.00022413\n",
      "\n",
      "21120 - INFO - Step 76850 loss: 0.00020397\n",
      "21120 - INFO - Step 76900 loss: 0.00024072\n",
      "21120 - INFO - Step 76950 loss: 0.00021851\n",
      "21120 - INFO - Step 77000 loss: 0.00024081\n",
      "21120 - INFO - Step 77050 loss: 0.00021696\n",
      "21120 - INFO - Step 77100 loss: 0.00023130\n",
      "21120 - INFO - Step 77150 loss: 0.00021386\n",
      "21120 - INFO - Step 77200 loss: 0.00020928\n",
      "21120 - INFO - Step 77250 loss: 0.00024243\n",
      "21120 - INFO - Epoch [178/200], Train Loss: 0.00022485, Test Loss: 0.00022566\n",
      "\n",
      "21120 - INFO - Step 77300 loss: 0.00018467\n",
      "21120 - INFO - Step 77350 loss: 0.00022648\n",
      "21120 - INFO - Step 77400 loss: 0.00018052\n",
      "21120 - INFO - Step 77450 loss: 0.00023780\n",
      "21120 - INFO - Step 77500 loss: 0.00025771\n",
      "21120 - INFO - Step 77550 loss: 0.00020944\n",
      "21120 - INFO - Step 77600 loss: 0.00018380\n",
      "21120 - INFO - Step 77650 loss: 0.00021720\n",
      "21120 - INFO - Epoch [179/200], Train Loss: 0.00022469, Test Loss: 0.00022358\n",
      "\n",
      "21120 - INFO - Step 77700 loss: 0.00022277\n",
      "21120 - INFO - Step 77750 loss: 0.00019947\n",
      "21120 - INFO - Step 77800 loss: 0.00020642\n",
      "21120 - INFO - Step 77850 loss: 0.00025843\n",
      "21120 - INFO - Step 77900 loss: 0.00021287\n",
      "21120 - INFO - Step 77950 loss: 0.00024401\n",
      "21120 - INFO - Step 78000 loss: 0.00020384\n",
      "21120 - INFO - Step 78050 loss: 0.00025574\n",
      "21120 - INFO - Step 78100 loss: 0.00022701\n",
      "21120 - INFO - Epoch [180/200], Train Loss: 0.00022478, Test Loss: 0.00022508\n",
      "\n",
      "21120 - INFO - Step 78150 loss: 0.00020707\n",
      "21120 - INFO - Step 78200 loss: 0.00024708\n",
      "21120 - INFO - Step 78250 loss: 0.00027347\n",
      "21120 - INFO - Step 78300 loss: 0.00022952\n",
      "21120 - INFO - Step 78350 loss: 0.00017807\n",
      "21120 - INFO - Step 78400 loss: 0.00022144\n",
      "21120 - INFO - Step 78450 loss: 0.00022327\n",
      "21120 - INFO - Step 78500 loss: 0.00022685\n",
      "21120 - INFO - Step 78550 loss: 0.00020885\n",
      "21120 - INFO - Epoch [181/200], Train Loss: 0.00022477, Test Loss: 0.00022545\n",
      "\n",
      "21120 - INFO - Step 78600 loss: 0.00024281\n",
      "21120 - INFO - Step 78650 loss: 0.00021947\n",
      "21120 - INFO - Step 78700 loss: 0.00024591\n",
      "21120 - INFO - Step 78750 loss: 0.00019512\n",
      "21120 - INFO - Step 78800 loss: 0.00022660\n",
      "21120 - INFO - Step 78850 loss: 0.00020622\n",
      "21120 - INFO - Step 78900 loss: 0.00024944\n",
      "21120 - INFO - Step 78950 loss: 0.00026030\n",
      "21120 - INFO - Epoch [182/200], Train Loss: 0.00022468, Test Loss: 0.00022480\n",
      "\n",
      "21120 - INFO - Step 79000 loss: 0.00022313\n",
      "21120 - INFO - Step 79050 loss: 0.00022095\n",
      "21120 - INFO - Step 79100 loss: 0.00022387\n",
      "21120 - INFO - Step 79150 loss: 0.00022605\n",
      "21120 - INFO - Step 79200 loss: 0.00022666\n",
      "21120 - INFO - Step 79250 loss: 0.00023396\n",
      "21120 - INFO - Step 79300 loss: 0.00023155\n",
      "21120 - INFO - Step 79350 loss: 0.00021562\n",
      "21120 - INFO - Step 79400 loss: 0.00020301\n",
      "21120 - INFO - Epoch [183/200], Train Loss: 0.00022474, Test Loss: 0.00022564\n",
      "\n",
      "21120 - INFO - Step 79450 loss: 0.00019082\n",
      "21120 - INFO - Step 79500 loss: 0.00022315\n",
      "21120 - INFO - Step 79550 loss: 0.00021377\n",
      "21120 - INFO - Step 79600 loss: 0.00023960\n",
      "21120 - INFO - Step 79650 loss: 0.00027279\n",
      "21120 - INFO - Step 79700 loss: 0.00024344\n",
      "21120 - INFO - Step 79750 loss: 0.00021423\n",
      "21120 - INFO - Step 79800 loss: 0.00024165\n",
      "21120 - INFO - Step 79850 loss: 0.00023313\n",
      "21120 - INFO - Epoch [184/200], Train Loss: 0.00022463, Test Loss: 0.00022567\n",
      "\n",
      "21120 - INFO - Step 79900 loss: 0.00025565\n",
      "21120 - INFO - Step 79950 loss: 0.00022275\n",
      "21120 - INFO - Step 80000 loss: 0.00018667\n",
      "21120 - INFO - Step 80050 loss: 0.00027878\n",
      "21120 - INFO - Step 80100 loss: 0.00020832\n",
      "21120 - INFO - Step 80150 loss: 0.00021678\n",
      "21120 - INFO - Step 80200 loss: 0.00023669\n",
      "21120 - INFO - Step 80250 loss: 0.00025032\n",
      "21120 - INFO - Epoch [185/200], Train Loss: 0.00022460, Test Loss: 0.00022430\n",
      "\n",
      "21120 - INFO - Step 80300 loss: 0.00021054\n",
      "21120 - INFO - Step 80350 loss: 0.00023139\n",
      "21120 - INFO - Step 80400 loss: 0.00022364\n",
      "21120 - INFO - Step 80450 loss: 0.00021177\n",
      "21120 - INFO - Step 80500 loss: 0.00024422\n",
      "21120 - INFO - Step 80550 loss: 0.00021975\n",
      "21120 - INFO - Step 80600 loss: 0.00022217\n",
      "21120 - INFO - Step 80650 loss: 0.00017517\n",
      "21120 - INFO - Step 80700 loss: 0.00024092\n",
      "21120 - INFO - Epoch [186/200], Train Loss: 0.00022440, Test Loss: 0.00022770\n",
      "\n",
      "21120 - INFO - Step 80750 loss: 0.00020616\n",
      "21120 - INFO - Step 80800 loss: 0.00018708\n",
      "21120 - INFO - Step 80850 loss: 0.00019750\n",
      "21120 - INFO - Step 80900 loss: 0.00021199\n",
      "21120 - INFO - Step 80950 loss: 0.00022073\n",
      "21120 - INFO - Step 81000 loss: 0.00024556\n",
      "21120 - INFO - Step 81050 loss: 0.00019919\n",
      "21120 - INFO - Step 81100 loss: 0.00024948\n",
      "21120 - INFO - Step 81150 loss: 0.00019412\n",
      "21120 - INFO - Epoch [187/200], Train Loss: 0.00022428, Test Loss: 0.00022392\n",
      "\n",
      "21120 - INFO - Step 81200 loss: 0.00021493\n",
      "21120 - INFO - Step 81250 loss: 0.00028307\n",
      "21120 - INFO - Step 81300 loss: 0.00023621\n",
      "21120 - INFO - Step 81350 loss: 0.00019691\n",
      "21120 - INFO - Step 81400 loss: 0.00021656\n",
      "21120 - INFO - Step 81450 loss: 0.00021503\n",
      "21120 - INFO - Step 81500 loss: 0.00024142\n",
      "21120 - INFO - Step 81550 loss: 0.00020659\n",
      "21120 - INFO - Epoch [188/200], Train Loss: 0.00022453, Test Loss: 0.00022703\n",
      "\n",
      "21120 - INFO - Step 81600 loss: 0.00023384\n",
      "21120 - INFO - Step 81650 loss: 0.00023002\n",
      "21120 - INFO - Step 81700 loss: 0.00021282\n",
      "21120 - INFO - Step 81750 loss: 0.00025241\n",
      "21120 - INFO - Step 81800 loss: 0.00022964\n",
      "21120 - INFO - Step 81850 loss: 0.00023884\n",
      "21120 - INFO - Step 81900 loss: 0.00023077\n",
      "21120 - INFO - Step 81950 loss: 0.00023337\n",
      "21120 - INFO - Step 82000 loss: 0.00019955\n",
      "21120 - INFO - Epoch [189/200], Train Loss: 0.00022441, Test Loss: 0.00022403\n",
      "\n",
      "21120 - INFO - Step 82050 loss: 0.00025056\n",
      "21120 - INFO - Step 82100 loss: 0.00019554\n",
      "21120 - INFO - Step 82150 loss: 0.00020849\n",
      "21120 - INFO - Step 82200 loss: 0.00023620\n",
      "21120 - INFO - Step 82250 loss: 0.00023452\n",
      "21120 - INFO - Step 82300 loss: 0.00024239\n",
      "21120 - INFO - Step 82350 loss: 0.00021020\n",
      "21120 - INFO - Step 82400 loss: 0.00022916\n",
      "21120 - INFO - Step 82450 loss: 0.00022550\n",
      "21120 - INFO - Epoch [190/200], Train Loss: 0.00022451, Test Loss: 0.00022447\n",
      "\n",
      "21120 - INFO - Step 82500 loss: 0.00022799\n",
      "21120 - INFO - Step 82550 loss: 0.00022135\n",
      "21120 - INFO - Step 82600 loss: 0.00021346\n",
      "21120 - INFO - Step 82650 loss: 0.00025347\n",
      "21120 - INFO - Step 82700 loss: 0.00022246\n",
      "21120 - INFO - Step 82750 loss: 0.00023299\n",
      "21120 - INFO - Step 82800 loss: 0.00021023\n",
      "21120 - INFO - Step 82850 loss: 0.00021736\n",
      "21120 - INFO - Epoch [191/200], Train Loss: 0.00022440, Test Loss: 0.00022505\n",
      "\n",
      "21120 - INFO - Step 82900 loss: 0.00024859\n",
      "21120 - INFO - Step 82950 loss: 0.00020390\n",
      "21120 - INFO - Step 83000 loss: 0.00025148\n",
      "21120 - INFO - Step 83050 loss: 0.00022916\n",
      "21120 - INFO - Step 83100 loss: 0.00021263\n",
      "21120 - INFO - Step 83150 loss: 0.00027584\n",
      "21120 - INFO - Step 83200 loss: 0.00028086\n",
      "21120 - INFO - Step 83250 loss: 0.00021884\n",
      "21120 - INFO - Step 83300 loss: 0.00021569\n",
      "21120 - INFO - Epoch [192/200], Train Loss: 0.00022449, Test Loss: 0.00022770\n",
      "\n",
      "21120 - INFO - Step 83350 loss: 0.00019274\n",
      "21120 - INFO - Step 83400 loss: 0.00024135\n",
      "21120 - INFO - Step 83450 loss: 0.00018827\n",
      "21120 - INFO - Step 83500 loss: 0.00021169\n",
      "21120 - INFO - Step 83550 loss: 0.00024117\n",
      "21120 - INFO - Step 83600 loss: 0.00021912\n",
      "21120 - INFO - Step 83650 loss: 0.00021471\n",
      "21120 - INFO - Step 83700 loss: 0.00022516\n",
      "21120 - INFO - Step 83750 loss: 0.00023078\n",
      "21120 - INFO - Epoch [193/200], Train Loss: 0.00022462, Test Loss: 0.00022463\n",
      "\n",
      "21120 - INFO - Step 83800 loss: 0.00022917\n",
      "21120 - INFO - Step 83850 loss: 0.00024787\n",
      "21120 - INFO - Step 83900 loss: 0.00020891\n",
      "21120 - INFO - Step 83950 loss: 0.00022157\n",
      "21120 - INFO - Step 84000 loss: 0.00021844\n",
      "21120 - INFO - Step 84050 loss: 0.00026412\n",
      "21120 - INFO - Step 84100 loss: 0.00021836\n",
      "21120 - INFO - Step 84150 loss: 0.00022184\n",
      "21120 - INFO - Epoch [194/200], Train Loss: 0.00022413, Test Loss: 0.00022354\n",
      "\n",
      "21120 - INFO - Step 84200 loss: 0.00024486\n",
      "21120 - INFO - Step 84250 loss: 0.00022789\n",
      "21120 - INFO - Step 84300 loss: 0.00023338\n",
      "21120 - INFO - Step 84350 loss: 0.00025158\n",
      "21120 - INFO - Step 84400 loss: 0.00021210\n",
      "21120 - INFO - Step 84450 loss: 0.00022585\n",
      "21120 - INFO - Step 84500 loss: 0.00020889\n",
      "21120 - INFO - Step 84550 loss: 0.00026081\n",
      "21120 - INFO - Step 84600 loss: 0.00023170\n",
      "21120 - INFO - Epoch [195/200], Train Loss: 0.00022435, Test Loss: 0.00022321\n",
      "\n",
      "21120 - INFO - Step 84650 loss: 0.00019895\n",
      "21120 - INFO - Step 84700 loss: 0.00020261\n",
      "21120 - INFO - Step 84750 loss: 0.00023884\n",
      "21120 - INFO - Step 84800 loss: 0.00022171\n",
      "21120 - INFO - Step 84850 loss: 0.00021473\n",
      "21120 - INFO - Step 84900 loss: 0.00020327\n",
      "21120 - INFO - Step 84950 loss: 0.00018356\n",
      "21120 - INFO - Step 85000 loss: 0.00019715\n",
      "21120 - INFO - Step 85050 loss: 0.00027100\n",
      "21120 - INFO - Epoch [196/200], Train Loss: 0.00022403, Test Loss: 0.00022496\n",
      "\n",
      "21120 - INFO - Step 85100 loss: 0.00022465\n",
      "21120 - INFO - Step 85150 loss: 0.00020961\n",
      "21120 - INFO - Step 85200 loss: 0.00020909\n",
      "21120 - INFO - Step 85250 loss: 0.00027412\n",
      "21120 - INFO - Step 85300 loss: 0.00025148\n",
      "21120 - INFO - Step 85350 loss: 0.00022494\n",
      "21120 - INFO - Step 85400 loss: 0.00024098\n",
      "21120 - INFO - Step 85450 loss: 0.00021654\n",
      "21120 - INFO - Epoch [197/200], Train Loss: 0.00022428, Test Loss: 0.00022689\n",
      "\n",
      "21120 - INFO - Step 85500 loss: 0.00023326\n",
      "21120 - INFO - Step 85550 loss: 0.00023799\n",
      "21120 - INFO - Step 85600 loss: 0.00026546\n",
      "21120 - INFO - Step 85650 loss: 0.00023197\n",
      "21120 - INFO - Step 85700 loss: 0.00023104\n",
      "21120 - INFO - Step 85750 loss: 0.00020181\n",
      "21120 - INFO - Step 85800 loss: 0.00024377\n",
      "21120 - INFO - Step 85850 loss: 0.00029074\n",
      "21120 - INFO - Step 85900 loss: 0.00022533\n",
      "21120 - INFO - Epoch [198/200], Train Loss: 0.00022407, Test Loss: 0.00022418\n",
      "\n",
      "21120 - INFO - Step 85950 loss: 0.00022087\n",
      "21120 - INFO - Step 86000 loss: 0.00023983\n",
      "21120 - INFO - Step 86050 loss: 0.00020439\n",
      "21120 - INFO - Step 86100 loss: 0.00022056\n",
      "21120 - INFO - Step 86150 loss: 0.00020638\n",
      "21120 - INFO - Step 86200 loss: 0.00018588\n",
      "21120 - INFO - Step 86250 loss: 0.00019876\n",
      "21120 - INFO - Step 86300 loss: 0.00016872\n",
      "21120 - INFO - Step 86350 loss: 0.00022508\n",
      "21120 - INFO - Epoch [199/200], Train Loss: 0.00022433, Test Loss: 0.00022565\n",
      "\n",
      "21120 - INFO - Step 86400 loss: 0.00020422\n",
      "21120 - INFO - Step 86450 loss: 0.00022868\n",
      "21120 - INFO - Step 86500 loss: 0.00020411\n",
      "21120 - INFO - Step 86550 loss: 0.00020189\n",
      "21120 - INFO - Step 86600 loss: 0.00020928\n",
      "21120 - INFO - Step 86650 loss: 0.00024622\n",
      "21120 - INFO - Step 86700 loss: 0.00024622\n",
      "21120 - INFO - Step 86750 loss: 0.00021142\n",
      "21120 - INFO - Step 86800 loss: 0.00036595\n",
      "21120 - INFO - Epoch [200/200], Train Loss: 0.00022454, Test Loss: 0.00022468\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Trainer definition\n",
    "from models import StandardAETrainer\n",
    "from benchmarking.utils import Experiment\n",
    "\n",
    "experiment = Experiment({}, \"StandardAE Single Layer Example\", '1.0', model, dataset_name)\n",
    "trainer = StandardAETrainer(model=model)\n",
    "trainer.train(\n",
    "    train_loader=train_loader, \n",
    "    test_loader=test_loader, \n",
    "    epochs=model_configs['StandardAE']['epochs'], \n",
    "    lr=1e-4, #model_configs['StandardAE']['lr'], \n",
    "    experiment=experiment,\n",
    "    early_stopping=False,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiwAAAGdCAYAAAAxCSikAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy80BEi2AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA8kElEQVR4nO3deXxU9aH///eZyUaAJEAgQyAQxAgiCMoSgl6xGg2KC1grRSqIVGovKjaWy/JTcKtxA6lKRb0F7G0tlFYpRcViFFGJItvXBaGIbJUkgJQEAmSZ+fz+IDNkJOTMhCQnhNfz8ZiHyZnPOedzckjm7Wc7ljHGCAAAoBFzOV0BAAAAOwQWAADQ6BFYAABAo0dgAQAAjR6BBQAANHoEFgAA0OgRWAAAQKNHYAEAAI1ehNMVqAs+n0979uxRy5YtZVmW09UBAAAhMMbo0KFDSk5OlstVcxtKkwgse/bsUUpKitPVAAAAtbB792517NixxjJNIrC0bNlS0vELjouLc7g2AAAgFMXFxUpJSQl8jtekSQQWfzdQXFwcgQUAgDNMKMM5GHQLAAAaPQILAABo9AgsAACg0WsSY1gAAE2LMUYVFRXyer1OVwWnye12KyIi4rSXHSGwAAAalbKyMuXn5+vIkSNOVwV1JDY2Vu3bt1dUVFStj0FgAQA0Gj6fT9u3b5fb7VZycrKioqJYEPQMZoxRWVmZ9u3bp+3btystLc12gbhTIbAAABqNsrIy+Xw+paSkKDY21unqoA40a9ZMkZGR2rlzp8rKyhQTE1Or4zDoFgDQ6NT2/8LRONXF/eRfBAAAaPQILAAAoNEjsAAA0EilpqZq9uzZTlejUSCwAABwmizLqvH10EMP1eq4n332mcaPH39adbv88stlWZaeeOKJk94bOnToSfXbvn27br31ViUnJysmJkYdO3bUjTfeqM2bNwfKnOo6Fy5ceFp1rQmzhGpQ7vXp8be+ljHSlGu6KybS7XSVAACNUH5+fuDrRYsWafr06dqyZUtgW4sWLQJfG2Pk9XoVEWH/Edy2bds6qV9KSooWLFigKVOmBLZ99913ys3NVfv27QPbysvLddVVV6lbt256/fXX1b59e/373//W22+/rYMHDwYdc/78+RoyZEjQtoSEhDqpb3VoYamBMdL8j3doweodKvP6nK4OAJyVjDE6UlbR4C9jTMh19Hg8gVd8fLwsywp8v3nzZrVs2VJvv/22+vbtq+joaH300Ufatm2bbrzxRiUlJalFixbq37+/3n333aDj/rBLyLIs/e///q+GDx+u2NhYpaWlaenSpbb1u+6667R//359/PHHgW2vvvqqrr76arVr1y6w7auvvtK2bdv0u9/9TgMHDlTnzp11ySWX6LHHHtPAgQODjpmQkBB03R6Pp9ZTlkNBC0sNXFXWKjLkFQBwxNFyr3pMf6fBz7vpkSzFRtXdx+SUKVP0zDPP6JxzzlGrVq20e/duXXvttfrNb36j6Oho/eEPf9D111+vLVu2qFOnTqc8zsMPP6ynnnpKTz/9tJ5//nmNGjVKO3fuVOvWrU+5T1RUlEaNGqX58+frkksukSQtWLBATz31VFB3UNu2beVyufTXv/5V9913n9zuxtOzQAtLDVxVVlf0hpG0AQD4oUceeURXXXWVunbtqtatW6t37976xS9+oZ49eyotLU2PPvqounbtatticvvtt2vkyJE699xz9fjjj+vw4cNas2aN7fnvuOMO/eUvf1FJSYlWrVqloqIiXXfddUFlOnTooOeee07Tp09Xq1atdMUVV+jRRx/Vt99+e9LxRo4cqRYtWgS9du3aFd4PJQy0sNTAVaWJxUdgAQBHNIt0a9MjWY6cty7169cv6PvDhw/roYce0ptvvqn8/HxVVFTo6NGjth/6F154YeDr5s2bKy4uTnv37rU9f+/evZWWlqa//vWvev/993XbbbdVO45mwoQJGj16tFauXKlPPvlEixcv1uOPP66lS5fqqquuCpR79tlnlZmZGbRvcnKybT1qi8Biw2VJPkNgAQCnWJZVp10zTmnevHnQ97/+9a+1YsUKPfPMMzr33HPVrFkz3XzzzSorK6vxOJGRkUHfW5Ylny+0cQt33HGH5syZo02bNtXYKtOyZUtdf/31uv766/XYY48pKytLjz32WFBg8Xg8Ovfcc0M6b12gS8iGv1uIvAIAqEsff/yxbr/9dg0fPly9evWSx+PRjh076vWct956q7744gv17NlTPXr0CGkfy7LUvXt3lZSU1Gvd7Jz5kbWeHQ8sRl4fiQUAUHfS0tL0+uuv6/rrr5dlWXrwwQdDbimprVatWik/P/+kVhq/jRs3asaMGbrtttvUo0cPRUVF6YMPPtC8efM0efLkoLIHDx5UQUFB0LaWLVue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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(experiment.train_loss_mse[-200:], label=\"Train MSE\")\n",
    "plt.plot(experiment.test_loss_mse[-200:], label=\"Test MSE\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.00022468145708648526"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "experiment.test_loss_mse[-1]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Stacked Contractive Autoencoder\n",
    "Stacked contractive autoencoder with TanH activation."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[24, 16]\n",
      "StackedCAE(\n",
      "  (caes): ModuleList(\n",
      "    (0): CAE(\n",
      "      (encoder): Sequential(\n",
      "        (0): Linear(in_features=31, out_features=24, bias=True)\n",
      "        (1): Tanh()\n",
      "      )\n",
      "      (decoder): Sequential(\n",
      "        (0): Linear(in_features=24, out_features=31, bias=True)\n",
      "        (1): Tanh()\n",
      "      )\n",
      "    )\n",
      "    (1): CAE(\n",
      "      (encoder): Sequential(\n",
      "        (0): Linear(in_features=24, out_features=16, bias=True)\n",
      "        (1): Tanh()\n",
      "      )\n",
      "      (decoder): Sequential(\n",
      "        (0): Linear(in_features=16, out_features=24, bias=True)\n",
      "        (1): Tanh()\n",
      "      )\n",
      "    )\n",
      "  )\n",
      ")\n"
     ]
    }
   ],
   "source": [
    "# Model init\n",
    "from models import StackedCAE\n",
    "\n",
    "hidden_spec = model_configs['StackedCAE']['hidden_spec']\n",
    "hidden_spec[-1] = round(input_dim * dim_reduction)\n",
    "print(hidden_spec)\n",
    "model = StackedCAE(input_dim=input_dim, hidden_spec=hidden_spec)\n",
    "print(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "412 - INFO - Step 50 loss: 0.68522704\n",
      " >> MSE: 0.00621298, Contractive loss: 0.67901409\n",
      "412 - INFO - Step 100 loss: 0.60802233\n",
      " >> MSE: 0.00522215, Contractive loss: 0.60280019\n",
      "412 - INFO - Step 150 loss: 0.54528320\n",
      " >> MSE: 0.00576309, Contractive loss: 0.53952008\n",
      "412 - INFO - Step 200 loss: 0.49355945\n",
      " >> MSE: 0.00589978, Contractive loss: 0.48765966\n",
      "412 - INFO - Step 250 loss: 0.43705714\n",
      " >> MSE: 0.00544750, Contractive loss: 0.43160963\n",
      "412 - INFO - Step 300 loss: 0.39221036\n",
      " >> MSE: 0.00531334, Contractive loss: 0.38689703\n",
      "412 - INFO - Step 350 loss: 0.35033411\n",
      " >> MSE: 0.00549006, Contractive loss: 0.34484404\n",
      "412 - INFO - Step 400 loss: 0.32031229\n",
      " >> MSE: 0.00581031, Contractive loss: 0.31450197\n",
      "412 - INFO - Epoch [1/2]: Avg. Train Loss: 0.48983923, Avg. Test Loss: 0.03261009\n",
      "\n",
      "412 - INFO - Step 450 loss: 0.28682235\n",
      " >> MSE: 0.00584037, Contractive loss: 0.28098199\n",
      "412 - INFO - Step 500 loss: 0.25853270\n",
      " >> MSE: 0.00605089, Contractive loss: 0.25248182\n",
      "412 - INFO - Step 550 loss: 0.22949597\n",
      " >> MSE: 0.00544591, Contractive loss: 0.22405006\n",
      "412 - INFO - Step 600 loss: 0.20700741\n",
      " >> MSE: 0.00526936, Contractive loss: 0.20173804\n",
      "412 - INFO - Step 650 loss: 0.19237635\n",
      " >> MSE: 0.00582930, Contractive loss: 0.18654704\n",
      "412 - INFO - Step 700 loss: 0.17435734\n",
      " >> MSE: 0.00603901, Contractive loss: 0.16831833\n",
      "412 - INFO - Step 750 loss: 0.15846378\n",
      " >> MSE: 0.00577234, Contractive loss: 0.15269144\n",
      "412 - INFO - Step 800 loss: 0.14035282\n",
      " >> MSE: 0.00501690, Contractive loss: 0.13533592\n",
      "412 - INFO - Step 850 loss: 0.13109368\n",
      " >> MSE: 0.00561506, Contractive loss: 0.12547863\n",
      "412 - INFO - Epoch [2/2]: Avg. Train Loss: 0.19556527, Avg. Test Loss: 0.01385615\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Trainer definition\n",
    "from models import StackedCAETrainer\n",
    "from benchmarking.utils import Experiment\n",
    "\n",
    "experiment = Experiment({}, \"StackedCAE Example\", '1.0', model, dataset_name)\n",
    "trainer = StackedCAETrainer(model=model)\n",
    "trainer.train(\n",
    "    train_loader=train_loader, \n",
    "    test_loader=test_loader, \n",
    "    epochs=model_configs['StackedCAE']['epochs'], \n",
    "    lr=model_configs['StackedCAE']['lr'], \n",
    "    experiment=experiment,\n",
    "    early_stopping=False,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkYAAAGdCAYAAAD3zLwdAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy80BEi2AAAACXBIWXMAAA9hAAAPYQGoP6dpAABS5ElEQVR4nO3deVxU9cIG8GdmYGbYFxEGkAT3DTdURE0q8WJaib3d1Mol1+41DbFcKpfc4HW/ml3blHyrS2FppmYZLt0UNRdyQSkVXBnUFAZR1vm9fwwzMjKDDALDwPP9fM4HmPnNOb85du88nzPnnEcihBAgIiIiIkitPQEiIiKiuoLBiIiIiKgUgxERERFRKQYjIiIiolIMRkRERESlGIyIiIiISjEYEREREZViMCIiIiIqZWftCdgarVaLa9euwcXFBRKJxNrTISIiokoQQiA3Nxd+fn6QSs0fF2IwstC1a9cQEBBg7WkQERFRFVy+fBlNmjQx+zyDkYVcXFwA6Hasq6urlWdDRERElaHRaBAQEGD4HDeHwchC+q/PXF1dGYyIiIhszMNOg+HJ10RERESlGIyIiIiISjEYEREREZXiOUZERNRgCSFQXFyMkpISa0+FHpFMJoOdnd0j30qHwYiIiBqkwsJCZGZm4u7du9aeClUTR0dH+Pr6Qi6XV3kdDEZERNTgaLVapKenQyaTwc/PD3K5nDfttWFCCBQWFuLGjRtIT09Hy5YtK7yJY0UYjIiIqMEpLCyEVqtFQEAAHB0drT0dqgYODg6wt7fHxYsXUVhYCKVSWaX18ORrIiJqsKp6VIHqpur49+R/EURERESlGIyIiIiISjEYERERNXCBgYFYtWqVtadRJzAYERER2QiJRFLhMm/evCqt97fffsOECRMeaW5PPPEEJBIJ4uLiyj03aNCgcvNLT0/HSy+9BD8/PyiVSjRp0gSDBw/G2bNnDWPMvc+EhIRHmmtFeFVaHfFdylUkn/8LM59uA3fHqt9/gYiI6q/MzEzD71999RXmzJmDtLQ0w2POzs6G34UQKCkpgZ3dwz/qGzduXC3zCwgIQHx8PGbOnGl47OrVq0hKSoKvr6/hsaKiIvTv3x+tW7fGt99+C19fX1y5cgU//PADsrOzjda5YcMGDBgwwOgxd3f3apmvKTxiVAfkF5VgwbYzSPjtMp5avg/fHL0CIYS1p0VE1KAIIXC3sNgqS2X/P1+lUhkWNzc3SCQSw99nz56Fi4sLfvjhB4SEhEChUODXX3/F+fPnMXjwYPj4+MDZ2Rndu3fHzz//bLTeB79Kk0gk+OSTTzBkyBA4OjqiZcuW2Lp160Pn98wzz+DmzZvYv3+/4bHPPvsMf/vb3+Dt7W147PTp0zh//jw++OAD9OzZE02bNkXv3r2xcOFC9OzZ02id7u7uRu9bpVJV+VL8yuARozpAaS/DBy93xTubT+LP63cwLfF3JB69jIVRwWjh7fzwFRAR0SO7V1SCdnN+tMq2U+dHwlFePR/JM2fOxLJly9CsWTN4eHjg8uXLGDhwIBYtWgSFQoGNGzfi2WefRVpaGh577DGz63nvvfewZMkSLF26FGvWrMHLL7+MixcvwtPT0+xr5HI5Xn75ZWzYsAG9e/cGAMTHx2PJkiVGX6M1btwYUqkUmzZtQnR0NGQyWbW89+rAI0Z1RI8gT2yf8jimD2gNpb0UBy/cwtP/+gXLf0pDfhE7fIiIqHLmz5+P/v37o3nz5vD09ESnTp0wceJEdOjQAS1btsSCBQvQvHnzhx4BGj16NIYPH44WLVpg8eLFuHPnDg4fPvzQ7Y8ZMwZff/018vLy8MsvvyAnJwfPPPOM0Rh/f3+sXr0ac+bMgYeHB5566iksWLAAFy5cKLe+4cOHw9nZ2Wi5dOmSZTvFAjxiVIfI7aT45xMt8GxHP8z57hT2pN3Amt3nsPX3a1gwuAP6tqqe74CJiKg8B3sZUudHWm3b1aVbt25Gf9+5cwfz5s3D9u3bkZmZieLiYty7d++h4aJjx46G352cnODq6orr168/dPudOnVCy5YtsWnTJuzZswcjRowweZ7TpEmTMHLkSOzduxcHDx5EYmIiFi9ejK1bt6J///6GcStXrkRERITRa/38/B46j6piMKqDAjwdsX50d+w8pca870/j4l93MXL9YTzT0RdznmkHb9ea+26ViKihkkgk1fZ1ljU5OTkZ/f3mm29i165dWLZsGVq0aAEHBwe88MILKCwsrHA99vb2Rn9LJBJotdpKzWHMmDFYu3YtUlNTKzzK5OLigmeffRbPPvssFi5ciMjISCxcuNAoGKlUKrRo0aJS260O/CqtjpJIJHg62Bc/x4Tj1d6BkEqAbScy0W/5PvxfcgZKtDw5m4iIHm7//v0YPXo0hgwZguDgYKhUKmRkZNToNl966SWcPHkSHTp0QLt27Sr1GolEgjZt2iAvL69G5/YwDEZ1nIvSHnOfbY/vJvVBxyZuyC0oxuzvTuP5D/bj1NUca0+PiIjquJYtW+Lbb79FSkoKfv/9d7z00kuVPvJTVR4eHsjMzERSUpLJ51NSUjB48GBs2rQJqampOHfuHD799FOsX78egwcPNhqbnZ0NtVpttNRkeLL9Y4YNRHATN2z+Z298fvAilv6Yht+v5OC593/F6F5BiPlbKzgr+E9JRETlrVixAmPGjEGvXr3g5eWFGTNmQKPR1Ph2K7rXUJMmTRAYGIj33nsPGRkZkEgkhr+nTp1qNPbVV18t9/rY2FijeyVVJ4ngDXMsotFo4ObmhpycHLi6ulplDlmafCzYloptJ3Q3+lK5KjHvuXaIbK+CRCKxypyIiGxJfn4+0tPTERQUVKP3xKHaVdG/a2U/v/lVmg3ycVXi/Ze6Iv7V7njM0xFqTT5e+/wYxn12BJdv3bX29IiIiGwWg5ENe6K1N36a2hevP9kC9jIJks5eR/+V+/DvvedRVFKz3x8TERHVRwxGNk5pL8Obka3xwxuPIzTIE/lFWvzvzrMYtPq/OJJxy9rTIyIisikMRvVEC28XJEzoiWV/7wQPR3v8kXUHL6xLxsxvTuB2XsX3qiAiIiIdBqN6RCKR4IWQJtg97QkM7RYAAEj47TL6rWAxLRERUWUwGNVDHk5y/O8LHfH1xDC09HbGrbxCTEv8HcM/Pohz1+9Ye3pERER1FoNRPcZiWiIiIsswGNVz+mLaXVPD8WTrxigqEViz+xwiV/2CX/64Ye3pERER1SkMRg2Evpj23y93hY+rwlBM+/qXx3Bdk2/t6REREdUJDEYNSEXFtBtZTEtEVOdJJJIKl3nz5j3Surds2VLpORw8eNDo8YKCAjRq1AgSiQR79+41PL5v3z489dRT8PT0hKOjI1q2bIlRo0ahsFB3xfTevXvNvh+1Wl3l91NVDEYNkL6Yduvr94tp57CYloiozsvMzDQsq1atgqurq9Fjb775Zq3MIyAgABs2bDB6bPPmzXB2djZ6LDU1FQMGDEC3bt3wyy+/4OTJk1izZg3kcjlKSozPdU1LSzN6L5mZmfD29q7x9/IgBqMGrIO/rph2/uD2cFHYGYpp53+fijsFxdaeHhERPUClUhkWNzc3SCQSo8cSEhLQtm1bKJVKtGnTBh988IHhtYWFhXj99dfh6+sLpVKJpk2bIjY2FgAQGBgIABgyZIih0LUio0aNQkJCAu7du2d4bP369Rg1apTRuJ9++gkqlQpLlixBhw4d0Lx5cwwYMAAff/wxHBwcjMZ6e3sbvReVSgWptPZjCoNRAyeTSjAyLBA/TwvHMx19oRXA+v3piFi+DztPZfLeR0TUcAgBFOZZZ6mG/6/94osvMGfOHCxatAhnzpzB4sWLMXv2bHz22WcAgNWrV2Pr1q34+uuvkZaWhi+++MIQgH777TcAwIYNG5CZmWn425yQkBAEBgbim2++AQBcunQJv/zyC0aMGGE0TqVSITMzE7/88ssjv7/aYmftCVDdoC+m/Xu3G5i95RQu3bqL1z4/hqfaeOO959ojwNPR2lMkIqpZRXeBxX7W2fbb1wC50yOtYu7cuVi+fDmef/55AEBQUBBSU1Px4YcfYtSoUbh06RJatmyJPn36QCKRoGnTpobXNm7cGADg7u4OlUpVqe2NGTMG69evxyuvvIL4+HgMHDjQsB69v//97/jxxx8RHh4OlUqFnj17ol+/fhg5cmS5hvsmTZoY/d20aVOcPn3a4v3wqHjEiIyEt2qMn6b2xeSndMW0u1lMS0RU5+Xl5eH8+fMYO3YsnJ2dDcvChQtx/vx5AMDo0aORkpKC1q1bY8qUKfjpp58eaZuvvPIKkpOTceHCBcTHx2PMmDHlxshkMmzYsAFXrlzBkiVL4O/vj8WLF6N9+/bIzMw0Gvvf//4XKSkphmXHjh2PNL+q4hEjKkdpL8O0v7XG4M5+eGfzKRxKv4X/3XkWm49fweIhwegW6GntKRIRVT97R92RG2tt+xHcuaNrNfj4448RGhpq9JxMJgMAdO3aFenp6fjhhx/w888/48UXX0RERAQ2bdpUpW02atQIzzzzDMaOHYv8/Hw8/fTTyM3NNTnW398fI0aMwIgRI7BgwQK0atUK69atw3vvvWcYExQUBHd39yrNpToxGJFZ+mLab45dxeIdZwzFtMO6B2DGgDbwcJJbe4pERNVHInnkr7OsxcfHB35+frhw4QJefvlls+NcXV0xdOhQDB06FC+88AIGDBiAW7duwdPTE/b29uWuFHuYMWPGYODAgZgxY4YhgD2Mh4cHfH19kZeXZ9G2aguDEVVIX0zbr4034n44i6+OXEbCb5fxU2oW3h7YFv/T1R8SicTa0yQiavDee+89TJkyBW5ubhgwYAAKCgpw5MgR3L59GzExMVixYgV8fX3RpUsXSKVSJCYmQqVSGY7SBAYGIikpCb1794ZCoYCHh8dDtzlgwADcuHGj3PlCeh9++CFSUlIwZMgQNG/eHPn5+di4cSNOnz6NNWvWGI29fv068vONbzjcqFEj2NvbV22HVFGVzjFau3YtAgMDoVQqERoaisOHD1c4PjExEW3atIFSqURwcHC57w2FEJgzZw58fX3h4OCAiIgI/Pnnn0ZjAgMDy934KS4urtx6li1bhlatWkGhUMDf3x+LFi0yPG/uJlLWuIGUrdEX0ya+FoZWPrpi2jcTf8ewj1hMS0RUF4wbNw6ffPIJNmzYgODgYISHhyM+Ph5BQUEAABcXFyxZsgTdunVD9+7dkZGRgR07dhguiV++fDl27dqFgIAAdOnSpVLblEgk8PLyglxu+huEHj164M6dO3jttdfQvn17hIeH4+DBg9iyZQvCw8ONxrZu3Rq+vr5Gy9GjRx9hj1SRsFBCQoKQy+Vi/fr14vTp02L8+PHC3d1dZGVlmRy/f/9+IZPJxJIlS0Rqaqp49913hb29vTh58qRhTFxcnHBzcxNbtmwRv//+u3juuedEUFCQuHfvnmFM06ZNxfz580VmZqZhuXPnjtG2Jk+eLFq3bi2+++47ceHCBXHkyBHx008/GZ7fs2ePACDS0tKM1lNSUlLp95+TkyMAiJycnEq/pr4pKCoRH+w5J1q/u0M0nbFNtHh7u1j241lxr7DY2lMjIqqUe/fuidTUVKPPGbJ9Ff27Vvbz2+Jg1KNHDzFp0iTD3yUlJcLPz0/ExsaaHP/iiy+KQYMGGT0WGhoqJk6cKIQQQqvVCpVKJZYuXWp4Pjs7WygUCvGf//zH8FjTpk3FypUrzc4rNTVV2NnZibNnz5odow9Gt2/frugtVojB6L5Lf+WJ0esPiaYztommM7aJvkt2i31p1609LSKih2Iwqp+qIxhZ9FVaYWEhjh49ioiICMNjUqkUERERSE5ONvma5ORko/EAEBkZaRifnp4OtVptNMbNzQ2hoaHl1hkXF4dGjRqhS5cuWLp0KYqL79+d+fvvv0ezZs2wbds2BAUFITAwEOPGjcOtW7fKzalz587w9fVF//79sX//fkt2AZXBYloiIqpvLDr5+ubNmygpKYGPj4/R4z4+Pjh79qzJ16jVapPj9ef16H9WNAYApkyZgq5du8LT0xMHDhzArFmzkJmZiRUrVgAALly4gIsXLyIxMREbN25ESUkJpk6dihdeeAG7d+8GAPj6+mLdunXo1q0bCgoK8Mknn+CJJ57AoUOH0LVrV5PzLygoQEFBgeFvjUbz0P3UkOiLaR9v1RjLf0rDZwcysO1EJval3cBbA1rj5dCmkEl5cjYREdkGm7kqLSYmxvB7x44dIZfLMXHiRMTGxkKhUECr1aKgoAAbN25Eq1atAACffvopQkJCkJaWhtatWxsWvV69euH8+fNYuXIl/u///s/kdmNjY43us0CmOSvsMPfZ9vifrk3w9uaTOHElB3O+O41vjl7BoiHB6ODvZu0pEhERPZRFX6V5eXlBJpMhKyvL6PGsrCyztxBXqVQVjtf/tGSdABAaGori4mJkZGQA0B0NsrOzM4QiAGjbti0AXYeLOT169MC5c+fMPj9r1izk5OQYlsuXL5sdSyymJSIi22ZRMJLL5QgJCUFSUpLhMa1Wi6SkJISFhZl8TVhYmNF4ANi1a5dhfFBQEFQqldEYjUaDQ4cOmV0nAKSkpEAqlcLb2xsA0Lt3bxQXFxtufQ4Af/zxBwAY9cGYWo+vr6/Z5xUKBVxdXY0WqlhFxbQ/nGQxLRHVHfz/o/qlOv49Lf4qLSYmBqNGjUK3bt3Qo0cPrFq1Cnl5eXj11VcBACNHjoS/vz9iY2MBAG+88QbCw8OxfPlyDBo0CAkJCThy5Ag++ugjALpzVKKjo7Fw4UK0bNkSQUFBmD17Nvz8/BAVFQVAdwL3oUOH8OSTT8LFxQXJycmYOnUqXnnlFcMNqCIiItC1a1eMGTMGq1atglarxaRJk9C/f3/DUaRVq1YhKCgI7du3R35+Pj755BPs3r37kftiyDRTxbT/+ILFtERkffqbBt69excODg5Wng1Vl7t37wLAI90U0uJgNHToUNy4cQNz5syBWq1G586dsXPnTsPJ05cuXTLcLArQncfz5Zdf4t1338Xbb7+Nli1bYsuWLejQoYNhzPTp05GXl4cJEyYgOzsbffr0wc6dO6FUKgHojtokJCRg3rx5KCgoQFBQEKZOnWp03pFUKsX333+PyZMno2/fvnBycsLTTz+N5cuXG8YUFhZi2rRpuHr1KhwdHdGxY0f8/PPPePLJJy3fc1Rp+mLatXvOYd2+89h99joOnL+JN/q1wrjHg2AvY5cxEdUumUwGd3d3XL9+HQDg6OjIu/jbMCEE7t69i+vXr8Pd3b3S9SSmSASPI1pEo9HAzc0NOTk5/FqtCs5dzzUU0wJAKx9nLBoSjO4spiWiWiaEgFqtRnZ2trWnQtXE3d0dKpXKZMit7Oc3g5GFGIwenRDCUEx7K68QADC0WwBmPs1iWiKqfSUlJSgqKrL2NOgR2dvbV3ikiMGohjAYVZ/beYX4351nkfCb7ko/Tyc5i2mJiKhGVPbzmyd3kNV4OMkR9z/mimlzrT09IiJqgBiMyOq6B3pi2+THMWNAGyjtpTiUfgtP/+u/WPZjGvKLSqw9PSIiakAYjKhOkNtJ8Y8nmmPX1HA81cYbRSUC7+85h7+t/AX7/rhh7ekREVEDwWBEdUqApyM+HdUN617pCpWrEpdu3cUoFtMSEVEtYTCiOkcikWBAB1/8PC0cY3oHQSoBtp3IRL/l+7AxOQMlWl4vQERENYNXpVmIV6XVvlNXcwzFtADQqYkbi2mJiMgivCqN6g0W0xIRUW1hMCKboC+mTZoWjmc7+bGYloiIagSDEdkUb1cl1gzvgs/G9MBjno5Qa/Lxjy+OYUz8b7h86661p0dERDaOwYhskr6YdvJTLWAvk2BP2g30X7kP/957HkUlWmtPj4iIbBSDEdkspb0M0/7WGj+80RehQZ7IL9Lif3eexaDV/8VvGbesPT0iIrJBDEZk81p4OyNhQk8s/3sneDrJ8UfWHfx9XTJmbDqB26UltURERJXBYET1gkQiwf+ENEFSTDiGdQ8AAHx15DL6rdiHTUev8ORsIiKqFAYjqldYTEtERI+CwYjqpe6Bntg+5XHMfJrFtEREVHkMRlRv2cukeC2cxbRERFR5DEZU77GYloiIKovBiBoEFtMSEVFlsETWQiyRrR9OXc3BO5tP4ncW0xIRNQgskSWqQAd/N3z7z95Y8EAx7Xvfn2YxLRFRA8ZgRA2WTCrBiAeKaTfsz2AxLRFRA8ZgRA1e2WLapo1YTEtE1JAxGBGVCm/VGD9Gs5iWiKghYzAiKqNsMW3PZiymJSJqaBiMiExo4e2M/4xnMS0RUUPDYERkBotpiYgaHt7HyEK8j1HDdSTjFt7ZfAppWboy2tAgTywa0gEtvF2sPDMiInoY3seIqJp1C/TEtil9WExLRFSPMRgRWYDFtERE9RuDEVEVsJiWiKh+YjAiqqKyxbRj+xgX0352gMW0RES2iCdfW4gnX5M5DxbTdmzihsUspiUiqhN48jVRLXuwmPZEmWLa3Pwia0+PiIgqgcGIqBqZLaZdwWJaIiJbwGBEVAP0xbQbS4tpszQFLKYlIrIBDEZENahvaTHtlAeKaT/Ye47FtEREdRCDEVENU9rLEPNAMe2SnWkspiUiqoMYjIhqCYtpiYjqPgYjolqkL6bdPc24mPap5XuReOQyT84mIrIyBiMiK3B3lCPufzpi02thaO3jgtt3i/DWphMY9tFBnLuea+3pERE1WAxGRFbEYloiorqFwYjIysoW0/ZjMS0RkVUxGBHVEQGejvhkVDeseyXEqJh2EotpiYhqDYMRUR2iK6ZVGRXTbmcxLRFRrWGJrIVYIku1icW0RETVgyWyRPUAi2mJiGoXgxFRHVdRMe0OFtMSEVUrBiMiG2GqmPafLKYlIqpWDEZENqaiYtrCYhbTEhE9CgYjIhtkrpj2mTUspiUiehRVCkZr165FYGAglEolQkNDcfjw4QrHJyYmok2bNlAqlQgODsaOHTuMnhdCYM6cOfD19YWDgwMiIiLw559/Go0JDAyERCIxWuLi4sqtZ9myZWjVqhUUCgX8/f2xaNEiozF79+5F165doVAo0KJFC8THx1dlFxDVCfpi2hUvspiWiKg6WByMvvrqK8TExGDu3Lk4duwYOnXqhMjISFy/ft3k+AMHDmD48OEYO3Ysjh8/jqioKERFReHUqVOGMUuWLMHq1auxbt06HDp0CE5OToiMjER+vvFN7ebPn4/MzEzDMnnyZKPn33jjDXzyySdYtmwZzp49i61bt6JHjx6G59PT0zFo0CA8+eSTSElJQXR0NMaNG4cff/zR0t1AVGdIJBI831VXTDu8B4tpiYgehcX3MQoNDUX37t3x/vvvAwC0Wi0CAgIwefJkzJw5s9z4oUOHIi8vD9u2bTM81rNnT3Tu3Bnr1q2DEAJ+fn6YNm0a3nzzTQBATk4OfHx8EB8fj2HDhgHQHTGKjo5GdHS0yXmdOXMGHTt2xKlTp9C6dWuTY2bMmIHt27cbhbJhw4YhOzsbO3furNT7532MqK47knEL72w+hbQsXRltaJAnFg3pgBbeLlaeGRGR9dTIfYwKCwtx9OhRRERE3F+BVIqIiAgkJyebfE1ycrLReACIjIw0jE9PT4darTYa4+bmhtDQ0HLrjIuLQ6NGjdClSxcsXboUxcXFhue+//57NGvWDNu2bUNQUBACAwMxbtw43Lp1/3yLh83FlIKCAmg0GqOFqC5jMS0RUdVZFIxu3ryJkpIS+Pj4GD3u4+MDtVpt8jVqtbrC8fqfD1vnlClTkJCQgD179mDixIlYvHgxpk+fbnj+woULuHjxIhITE7Fx40bEx8fj6NGjeOGFFx46F41Gg3v37pmcf2xsLNzc3AxLQECAyXFEdUlFxbR700x/7U1ERICdtSdQWTExMYbfO3bsCLlcjokTJyI2NhYKhQJarRYFBQXYuHEjWrVqBQD49NNPERISgrS0NLNfrz3MrFmzjLat0WgYjshm6ItpfzydhXlbT+PSrbsYveE3DOroiznPtIOPq9LaUyQiqlMsOmLk5eUFmUyGrKwso8ezsrKgUqlMvkalUlU4Xv/TknUCunOdiouLkZGRAQDw9fWFnZ2dIRQBQNu2bQEAly5dqnAurq6ucHBwMLkdhUIBV1dXo4XIlpgrpo1gMS0RUTkWBSO5XI6QkBAkJSUZHtNqtUhKSkJYWJjJ14SFhRmNB4Bdu3YZxgcFBUGlUhmN0Wg0OHTokNl1AkBKSgqkUim8vb0BAL1790ZxcTHOnz9vGPPHH38AAJo2bVqpuRDVZ84KO8x+ph22vt4HnQLckVtQjLlbT2PIB/tx6mqOtadHRFQ3CAslJCQIhUIh4uPjRWpqqpgwYYJwd3cXarVaCCHEiBEjxMyZMw3j9+/fL+zs7MSyZcvEmTNnxNy5c4W9vb04efKkYUxcXJxwd3cX3333nThx4oQYPHiwCAoKEvfu3RNCCHHgwAGxcuVKkZKSIs6fPy8+//xz0bhxYzFy5EjDOkpKSkTXrl1F3759xbFjx8SRI0dEaGio6N+/v2HMhQsXhKOjo3jrrbfEmTNnxNq1a4VMJhM7d+6s9PvPyckRAEROTo6lu46ozigu0YqNyRmiw9ydoumMbSJo5jYx97tTQnOv0NpTIyKqEZX9/LY4GAkhxJo1a8Rjjz0m5HK56NGjhzh48KDhufDwcDFq1Cij8V9//bVo1aqVkMvlon379mL79u1Gz2u1WjF79mzh4+MjFAqF6Nevn0hLSzM8f/ToUREaGirc3NyEUqkUbdu2FYsXLxb5+flG67l69ap4/vnnhbOzs/Dx8RGjR48Wf/31l9GYPXv2iM6dOwu5XC6aNWsmNmzYYNF7ZzCi+iRLc0+8/uUx0XTGNtF0xjbRY9Eusf3ENaHVaq09NSKialXZz2+L72PU0PE+RlQf/fLHDcz+7hQu/qUro32ydWPMH9wBAZ6OVp4ZEVH1qJH7GBFR/cRiWiIiHQYjIgJQcTHt4XQW0xJRw8BgRERGyhbTNiotpn3xw2RM3/Q7i2mJqN5jMCKicvTFtEllimm/PnKFxbREVO8xGBGRWe6OcsQ+3xGbXgtDax8X3L5bhLc2ncDQjw7i3PVca0+PiKjaMRgR0UPpi2lnPd0GDvYyHGYxLRHVUwxGRFQp9jIpJoY3x66YviymJaJ6i8GIiCzSxENXTLvulRD4uikNxbSTvjyGLE2+tadHRPRIGIyIyGL6YtpdMSymJaL6hXe+thDvfE1U3qmrOXhnyyn8fjkbANCxiRsWDwlGB383606MiKgU73xNRLWmg78bvv1HLyyI6gAXpR1OXMnBc+//inlbTyM3v8ja0yMiqjQGIyKqFjKpBCN6NkXStHA818kPWgHEH8hAxIp92HEyk/c+IiKbwGBERNXK20WJ1cO74P/G9kBgI0dkaQrwzy+OYUz8b7h86661p0dEVCEGIyKqEY+3bIyd0X0xpV9LyGVSQzHt2j0spiWiuovBiIhqjNJehpj+rbDjjccR1qwR8ou0WPpjGgatZjEtEdVNDEZEVONaeDvjy/GhhmLaP6/fL6a9xWJaIqpDGIyIqFaYK6btx2JaIqpDGIyIqFbpi2m/+QeLaYmo7mEwIiKrCGlquph26Y9nWUxLRFbDYEREVlO2mDaira6Ydu2e8yymJSKrYTAiIqtr4uGIj0d2w4cjWExLRNbFYEREdYJEIkFke10x7bg+QZBJJSymJaJaxxJZC7FElqh2nL6Wg7c33y+mDfbXFdMGN2ExLRFZjiWyRGTT2vsZF9OevJqDwWtZTEtENYvBiIjqLBbTElFtYzAiojrPXDHtqyymJaJqxmBERDbjwWLavSymJaJqxmBERDZFX0z7QzSLaYmo+jEYEZFNat5YV0y7ciiLaYmo+jAYEZHNkkgkGNKFxbREVH0YjIjI5pUtpm2jMi6m/TOLxbREVHkMRkRUb4Q09cT3k42LaQeu1hXT3itkMS0RPRyDERHVK2aLaVftYzEtET0UgxER1UsPFtNevnWPxbRE9FAMRkRUb+mLaX9+oJi23/J9iN+fzmJaIiqHJbIWYokske1iMS1Rw8USWSKiB7CYlogehsGIiBqUssW0gzvfL6btt3wftp9gMS1RQ8dgREQNkreLEv8adr+Y9npuASZ9qSumvfQXi2mJGioGIyJq0FhMS0RlMRgRUYNXtpi2V/NGKChmMS1RQ8VgRERUqnljZ3wxrnwx7VuJLKYlaigYjIiIyjAupn0MAJB4lMW0RA0FgxERkQm6YtpgFtMSNTAMRkREFWAxLVHDwmBERPQQLKYlajgYjIiIKqmJhyM+GdW9fDHtFyymJaovGIyIiCxUrpj2JItpieoLlshaiCWyRFTW6Ws5eGfzKaSwmJaoTmOJLBFRLWjv54Zv/tELC1lMS1QvMBgRET0imVSCV1hMS1QvVCkYrV27FoGBgVAqlQgNDcXhw4crHJ+YmIg2bdpAqVQiODgYO3bsMHpeCIE5c+bA19cXDg4OiIiIwJ9//mk0JjAwEBKJxGiJi4szPJ+RkVHueYlEgoMHDxrGxMfHl3teqVRWZRcQEZXDYloi22dxMPrqq68QExODuXPn4tixY+jUqRMiIyNx/brpS1YPHDiA4cOHY+zYsTh+/DiioqIQFRWFU6dOGcYsWbIEq1evxrp163Do0CE4OTkhMjIS+fnGV3nMnz8fmZmZhmXy5Mnltvfzzz8bjQkJCTF63tXV1ej5ixcvWroLiIgqpC+mfYPFtEQ2x+KTr0NDQ9G9e3e8//77AACtVouAgABMnjwZM2fOLDd+6NChyMvLw7Zt2wyP9ezZE507d8a6desghICfnx+mTZuGN998EwCQk5MDHx8fxMfHY9iwYQB0R4yio6MRHR1tcl4ZGRkICgrC8ePH0blzZ5Nj4uPjER0djezsbEveshGefE1Eljh/4w5mbzmFA+f/AgC09HbGoiHB6BHkaeWZETUsNXLydWFhIY4ePYqIiIj7K5BKERERgeTkZJOvSU5ONhoPAJGRkYbx6enpUKvVRmPc3NwQGhpabp1xcXFo1KgRunTpgqVLl6K4uLjc9p577jl4e3ujT58+2Lp1a7nn79y5g6ZNmyIgIACDBw/G6dOnK3zPBQUF0Gg0RgsRUWWxmJbItlgUjG7evImSkhL4+PgYPe7j4wO1Wm3yNWq1usLx+p8PW+eUKVOQkJCAPXv2YOLEiVi8eDGmT59ueN7Z2RnLly9HYmIitm/fjj59+iAqKsooHLVu3Rrr16/Hd999h88//xxarRa9evXClStXzL7n2NhYuLm5GZaAgICKdhERUTn6Ytrd054oV0z7NYtpieoUO2tPoLJiYmIMv3fs2BFyuRwTJ05EbGwsFAoFvLy8jMZ0794d165dw9KlS/Hcc88BAMLCwhAWFmYY06tXL7Rt2xYffvghFixYYHK7s2bNMlqvRqNhOCKiKnFztEfs88F4IcQf72w+hbPqXEzfdAKbjl7BoqgOaOnjYu0pEjV4Fh0x8vLygkwmQ1ZWltHjWVlZUKlUJl+jUqkqHK//ack6Ad25TsXFxcjIyKhwzLlz58w+b29vjy5dulQ4RqFQwNXV1WghInoU+mLatweymJaorrEoGMnlcoSEhCApKcnwmFarRVJSktGRmLLCwsKMxgPArl27DOODgoKgUqmMxmg0Ghw6dMjsOgEgJSUFUqkU3t7eFY7x9fU1+3xJSQlOnjxZ4RgioppgL5NiQl8W0xLVNRZ/lRYTE4NRo0ahW7du6NGjB1atWoW8vDy8+uqrAICRI0fC398fsbGxAIA33ngD4eHhWL58OQYNGoSEhAQcOXIEH330EQDdd+/R0dFYuHAhWrZsiaCgIMyePRt+fn6IiooCoDuB+9ChQ3jyySfh4uKC5ORkTJ06Fa+88go8PDwAAJ999hnkcjm6dOkCAPj222+xfv16fPLJJ4a5z58/Hz179kSLFi2QnZ2NpUuX4uLFixg3blzV9yAR0SPQF9P+dFqNeVtPG4ppBwX7Ys6z7eDjynutEdUmi4PR0KFDcePGDcyZMwdqtRqdO3fGzp07DSdPX7p0CVLp/QNRvXr1wpdffol3330Xb7/9Nlq2bIktW7agQ4cOhjHTp09HXl4eJkyYgOzsbPTp0wc7d+403HxRoVAgISEB8+bNQ0FBAYKCgjB16lSjc38AYMGCBbh48SLs7OzQpk0bfPXVV3jhhRcMz9++fRvjx4+HWq2Gh4cHQkJCcODAAbRr187S3UBEVK3+1l6F3i28sHLXH9hwIAPbT2Zi3x838ObfWmFEWCBkUom1p0jUILBE1kK8jxER1TQW0xJVP5bIEhHZqPZ+bviWxbREVsFgRERUB0lZTEtkFQxGRER1mL6Y9vOxoQjycmIxLVENYzAiIrIBfVp64Yc3HmcxLVENYzAiIrIRSnsZpvZvhR+iH0ev5o1QUKzF0h/TMHD1f3Howl/Wnh5RvcBgRERkYx4spj13/Q6GfnSQxbRE1YDBiIjIBpUtpn0plMW0RNWFwYiIyIa5Odpj8ZBgfPOPXmijcsHtu0WYvukEhn54EH9m5Vp7ekQ2h8GIiKgeCGnqYVxMm3ELT//rv1iyk8W0RJZgMCIiqif0xbQ/TwtHRFsfFGsFPtirK6bdw2JaokphMCIiqmf83R3wyahu+GhECPzclLh86x5e3fAbJn1xDFmafGtPj6hOYzAiIqqn/tZehV0x4Rj/eBBkUgm2n8xEv+X7EL8/HSVanpxNZApLZC3EElkiskWp1zR4e/NJo2LaRUM6oGMTd6vOi6i2sESWiIgM2vm5liumjVq7H/O2noaGxbREBgxGREQNhL6Ydve0J4yKaSNYTEtkwGBERNTANHZRsJiWyAwGIyKiBorFtETlMRgRETVg+mLanSymJQLAYERERACalRbTrhraGV7OLKalhovBiIiIAOiKaaO6+CMphsW01HAxGBERkZGKimn/YDEt1XMMRkREZJKpYtqBLKaleo7BiIiIzGIxLTU0DEZERPRQ5opp//nFURbTUr3CYERERJX2YDHtjpNqFtNSvcISWQuxRJaISCf1mgbvbDmJ45eyAbCYluo2lsgSEVGNaufnim9e64VFQzrAlcW0VE8wGBERUZVJpRK8HNoUSdOeQBSLaakeYDAiIqJH1thFgVXDuuCLccbFtKM3sJiWbAuDERERVZveLYyLaff9wWJasi0MRkREVK3KFtP2bsFiWrItDEZERFQjmjV2xudjWUxLtoXBiIiIaoy5Ytqnlu/F17+xmJbqHgYjIiKqcQ8W02bfLcL0b1hMS3UPgxEREdUafTHtOwPbspiW6iQGIyIiqlX2MinG922Gn6eFo387FtNS3cJgREREVuHv7oCPR5ouplXnsJiWrIPBiIiIrEpfTDuhbzNDMW3Ein3YwGJasgKWyFqIJbJERDWHxbRUU1giS0RENsdUMe3gtfsx97tTLKalWsFgREREdcqDxbRCAJ8lX2QxLdUKBiMiIqqTWExL1sBgREREdZq+mDY6gsW0VPMYjIiIqM5T2ssQHcFiWqp5DEZERGQzzBXTvsliWqomDEZERGRTTBXTbipTTKvlvY/oETAYERGRTTJXTDvsIxbTUtUxGBERkU0LaeqBbSympWrCYERERDbPzkwxbf+V+7DnLItpqfIYjIiIqN54sJj2yu17eDWexbRUeQxGRERU77CYlqqqSsFo7dq1CAwMhFKpRGhoKA4fPlzh+MTERLRp0wZKpRLBwcHYsWOH0fNCCMyZMwe+vr5wcHBAREQE/vzzT6MxgYGBkEgkRktcXJzh+YyMjHLPSyQSHDx40KK5EBFR/eCksMPbA9vi+9f7oMtj7rhTUIz3vk/F4LW/4sSVbGtPj+ooi4PRV199hZiYGMydOxfHjh1Dp06dEBkZievXTX+He+DAAQwfPhxjx47F8ePHERUVhaioKJw6dcowZsmSJVi9ejXWrVuHQ4cOwcnJCZGRkcjPNz7sOX/+fGRmZhqWyZMnl9vezz//bDQmJCTEorkQEVH98mAx7amrGhbTklkSYWEbX2hoKLp37473338fAKDVahEQEIDJkydj5syZ5cYPHToUeXl52LZtm+Gxnj17onPnzli3bh2EEPDz88O0adPw5ptvAgBycnLg4+OD+Ph4DBs2DIDuiFF0dDSio6NNzisjIwNBQUE4fvw4OnfubHLMw+ZSGRqNBm5ubsjJyYGrq2ulXkNERHXDjdwCLNqeii0p1wAA3i4KzHm2HQYF+0IikVh5dlSTKvv5bdERo8LCQhw9ehQRERH3VyCVIiIiAsnJySZfk5ycbDQeACIjIw3j09PToVarjca4ubkhNDS03Drj4uLQqFEjdOnSBUuXLkVxcXG57T333HPw9vZGnz59sHXrVovmQkRE9ZupYtrXvzzOYloysCgY3bx5EyUlJfDx8TF63MfHB2q12uRr1Gp1heP1Px+2zilTpiAhIQF79uzBxIkTsXjxYkyfPt3wvLOzM5YvX47ExERs374dffr0QVRUlFE4ethcTCkoKIBGozFaiIjItrGYlsyxs/YEKismJsbwe8eOHSGXyzFx4kTExsZCoVDAy8vLaEz37t1x7do1LF26FM8991yVtxsbG4v33nvvkeZORER1j76Y9rlOfpj93SnsP/cXlv6Yhs3Hr2JRVAeENmtk7SmSFVh0xMjLywsymQxZWVlGj2dlZUGlUpl8jUqlqnC8/qcl6wR05zoVFxcjIyOjwjHnzp2r9FxMmTVrFnJycgzL5cuXzY4lIiLboy+m/dcwFtOShcFILpcjJCQESUlJhse0Wi2SkpIQFhZm8jVhYWFG4wFg165dhvFBQUFQqVRGYzQaDQ4dOmR2nQCQkpICqVQKb2/vCsf4+vpWei6mKBQKuLq6Gi1ERFS/SCQSDO6sK6Z9OfQxSCQspm2whIUSEhKEQqEQ8fHxIjU1VUyYMEG4u7sLtVothBBixIgRYubMmYbx+/fvF3Z2dmLZsmXizJkzYu7cucLe3l6cPHnSMCYuLk64u7uL7777Tpw4cUIMHjxYBAUFiXv37gkhhDhw4IBYuXKlSElJEefPnxeff/65aNy4sRg5cqRhHfHx8eLLL78UZ86cEWfOnBGLFi0SUqlUrF+/3qK5PExOTo4AIHJycizddUREZCOOXrwlIlfuE01nbBNNZ2wTf//3AZGm1lh7WvQIKvv5bXEwEkKINWvWiMcee0zI5XLRo0cPcfDgQcNz4eHhYtSoUUbjv/76a9GqVSshl8tF+/btxfbt242e12q1Yvbs2cLHx0coFArRr18/kZaWZnj+6NGjIjQ0VLi5uQmlUinatm0rFi9eLPLz8w1j4uPjRdu2bYWjo6NwdXUVPXr0EImJieXm/rC5PAyDERFRw1BUXCI+2ndetJ39g2g6Y5toPmu7iPvhjLhbUGztqVEVVPbz2+L7GDV0vI8REVHDcjX7Ht7beho/perOUW3i4YAFgzvgyTbmT+WguqdG7mNERETU0Pi7O+Cjkd3w8chuLKZtABiMiIiIKqF/Ox8W0zYA/CrNQvwqjYiIzmRq8Pbmkzh+KRsA0MHfFYuHBKNjE3erzovM41dpRERENaStr66YdvGQYBbT1jMMRkRERFUglUrwUuhjSJr2BIZ08YcQwGfJFxGxfB+2nbgGfiFjmxiMiIiIHkFjFwVWDu3MYtp6gsGIiIioGuiLaadGtILcjsW0torBiIiIqJoo7WV4I6Ilfozui94tGqGgWIulP6Zh4Or/4uCFv6w9PaoEBiMiIqJqFuTlVK6YdhiLaW0CgxEREVENYDGtbeJ9jCzE+xgREVFVHLt0G+9sPoUzmRoAQPdADywaEoxWPi5WnlnDwPsYERER1SFdH/PA96/3xjsD28JRLsNvGbcx8F//xf/uPIt7hSXWnh6VYjAiIiKqJXYyKcb3bYZdMeH4WzsfFGsF/r33PPqv3Ic9Z69be3oEBiMiIqJax2LauovBiIiIyEpMFdP2W74X639lMa21MBgRERFZkZPCDm8PbIttk/ug62PuyCsswfxtqRi89lecuJJt7ek1OAxGREREdUBbX1dsYjGt1TEYERER1REsprU+BiMiIqI6pqJi2ot/5Vl7evUagxEREVEdZaqY9m8rf8H7u/9kMW0NYTAiIiKqw8oW0/Zp4YWCYi2W/fQHi2lrCIMRERGRDQjycsL/je1Rrph22tcspq1ODEZEREQ2wlQx7TfHWExbnVgiayGWyBIRUV3BYtrKY4ksERFRPacvpn13EItpqwuDERERkQ2zk0kx7vFm+JnFtNWCwYiIiKge8CtTTOvv7mAopv3H5yymtQSDERERUT3Sv50PfpraFxNLi2l/OHW/mLa4hPc+ehgGIyIionrGSWGHWSaKaaM+2I/fL2dbe3p1GoMRERFRPWWqmDbqAxbTVoTBiIiIqB7TF9PufpPFtJXBYERERNQAeDnrimm/HBeKZiymNYvBiIiIqAHp1cILP0SbLqYtKOa9jxiMiIiIGhiFnZli2n+xmJbBiIiIqIEyLqZV4PyNPEMx7V93Cqw9PatgMCIiImrADMW008LxSs/7xbT9VuzDV79danDFtAxGREREBDcHeyyMCsY3/+iFtr6uyL5bhBnfnMTQj5LxR1autadXaxiMiIiIyKChF9MyGBEREZGRhlxMy2BEREREJlVUTJuZc8/a06sRDEZERERUof7tfLArxriYNmL5vnpZTMtgRERERA/lKG8YxbQMRkRERFRp+mLa2OeNi2nn1JNiWgYjIiIisohUKsHwHrpi2udLi2k3Jl9Ev+X78P3vtl1My2BEREREVeLlrMCKMsW0N3ILMPk/xzHKhotpGYyIiIjokTxYTPuLDRfTMhgRERHRI6svxbQMRkRERFRtbL2YlsGIiIiIqpUtF9NKhC2fOm4FGo0Gbm5uyMnJgaurq7WnQ0REVOcdv3Qbb28+hTOZGgBA90APLBoSjFY+LrU2h8p+fvOIEREREdWoLjZUTMtgRERERDWubDFtZHvjYtrdZ7OsPT2DKgWjtWvXIjAwEEqlEqGhoTh8+HCF4xMTE9GmTRsolUoEBwdjx44dRs8LITBnzhz4+vrCwcEBERER+PPPP43GBAYGQiKRGC1xcXEmt3fu3Dm4uLjA3d3d6PH4+Phy61AqlZbvACIiIqoSP3cHfDiiGz4pU0w7Jv5InSmmtTgYffXVV4iJicHcuXNx7NgxdOrUCZGRkbh+/brJ8QcOHMDw4cMxduxYHD9+HFFRUYiKisKpU6cMY5YsWYLVq1dj3bp1OHToEJycnBAZGYn8/Hyjdc2fPx+ZmZmGZfLkyeW2V1RUhOHDh+Pxxx83OR9XV1ejdVy8eNHSXUBERESPKKKOFtNaHIxWrFiB8ePH49VXX0W7du2wbt06ODo6Yv369SbH/+tf/8KAAQPw1ltvoW3btliwYAG6du2K999/H4DuaNGqVavw7rvvYvDgwejYsSM2btyIa9euYcuWLUbrcnFxgUqlMixOTk7ltvfuu++iTZs2ePHFF03ORyKRGK3Dx8fH0l1ARERE1UBfTLt9inEx7TfHrlhtThYFo8LCQhw9ehQRERH3VyCVIiIiAsnJySZfk5ycbDQeACIjIw3j09PToVarjca4ubkhNDS03Drj4uLQqFEjdOnSBUuXLkVxcbHR87t370ZiYiLWrl1r9j3cuXMHTZs2RUBAAAYPHozTp09X+J4LCgqg0WiMFiIiIqo+bVT3i2lDgzzxfNcmVpuLnSWDb968iZKSknJHWXx8fHD27FmTr1Gr1SbHq9Vqw/P6x8yNAYApU6aga9eu8PT0xIEDBzBr1ixkZmZixYoVAIC//voLo0ePxueff272MrzWrVtj/fr16NixI3JycrBs2TL06tULp0+fRpMmpv8RYmNj8d5775nbJURERFQN9MW0w7oHQCKRWG0eFgUja4qJiTH83rFjR8jlckycOBGxsbFQKBQYP348XnrpJfTt29fsOsLCwhAWFmb4u1evXmjbti0+/PBDLFiwwORrZs2aZbRtjUaDgICAanhHRERE9CBrhiLAwq/SvLy8IJPJkJVlfFldVlYWVCqVydeoVKoKx+t/WrJOAAgNDUVxcTEyMjIA6L5GW7ZsGezs7GBnZ4exY8ciJycHdnZ2Zs9/sre3R5cuXXDu3Dmz21EoFHB1dTVaiIiIqH6yKBjJ5XKEhIQgKSnJ8JhWq0VSUpLRkZiywsLCjMYDwK5duwzjg4KCoFKpjMZoNBocOnTI7DoBICUlBVKpFN7e3gB05zKlpKQYlvnz58PFxQUpKSkYMmSIyXWUlJTg5MmT8PX1rdwOICIionrN4q/SYmJiMGrUKHTr1g09evTAqlWrkJeXh1dffRUAMHLkSPj7+yM2NhYA8MYbbyA8PBzLly/HoEGDkJCQgCNHjuCjjz4CoDtkFh0djYULF6Jly5YICgrC7Nmz4efnh6ioKAC60HPo0CE8+eSTcHFxQXJyMqZOnYpXXnkFHh4eAIC2bdsazfPIkSOQSqXo0KGD4bH58+ejZ8+eaNGiBbKzs7F06VJcvHgR48aNs3zPVbdvxgPXzwBu/oCrH+Dqr1vcSn+6+gH2DtaeJRERUb1mcTAaOnQobty4gTlz5kCtVqNz587YuXOn4eTpS5cuQSq9fyCqV69e+PLLL/Huu+/i7bffRsuWLbFlyxajwDJ9+nTk5eVhwoQJyM7ORp8+fbBz507DzRcVCgUSEhIwb948FBQUICgoCFOnTjU696cybt++jfHjx0OtVsPDwwMhISE4cOAA2rVrZ+luqH7XU4GsU0DWSfNjHBuVhqYmup+G0FQmTNnzhpVERERVxRJZC9VYieyNNCD7EpBzBdBcAzRXdUtO6c+iu5Vbj2OjB442lQapskei7BTVN28iIiIbUNnPb5u5Kq3ea9xat5giBJCfXRqSrgGa0vCkD036AFV8D7j7l25RnzC/LUev8keb3JqU+QrPj+GJiIgaJAYjWyCRAA4eukXVwfQYIYB7t+8fbTJ55OlaaXi6qVsyfze/TafGpo886b/Cc/FleCIionqHwai+kEgAR0/d8tDwdNX4aJPmWmmQ0oenfCDvhm7JTDG/TSfv8kebyv7u4gvYyWvk7RIREdUEBqOGxCg8BZseIwRw91aZ0FTmaFPZv0sKgLzrusVseJIAzt5mrrLTH4XyA2T2NfWOiYiILMJgRMYkEsCpkW7x7Wh6jCE8XSl/tCmnzFGokgLgTpZuuXbc3AYBZx/TV9npjz65+DI8ERFRrWAwIssZhadOpscIoTsJ3Ny5TvpQVVII3FHrlmvHzG1QF55MnevkWjY88T9nIiJ6NPwkoZohkQBOXrrFr7PpMVqtLjyZusrOcCTqGqAtuh+erh41sz1p6ZEnU1fZlX6F56xieCIiogrxU4KsRyoFnBvrFr8upsdotbor6B48YdzoyFOmLjzlZuqWq2a2J5HqwpHJI0+li7MPwxMRUQPGTwCq26RS3Qnczt4Vh6e8G6aPNulDVO41QFus+5l7zfz2JDLARWX+hHG30vAkldXM+yUiIqtiMCLbJ5UCLj66xb+r6TFare4KOlPnOen/1ocnfcDCb6bXJZHpzmmq6IRxhiciIpvEYEQNg1SqOxLkogL8Q0yP0ZbojjzlXH3girtr949Eaa4BoqT0+SvAFXPbs7sfnsqd96QPT94MT0REdQyDEZGeVHY/PKGC8HTnevkuu7K3K8jN1B15yrmsW8xuTx+e/MtfZac/EuXkrQt1RERUKxiMiCwhlQGuvroF3UyP0Zbo7t1k7io7jaXhyc+4BPjBmhanxgxPRETVhMGIqLpJZffv6o3upseUFOvCk/5cJ1PnPd1Rl4anS7rF7PbsS8Oaiavs9F/hOXoxPBERVQKDEZE1yOx0AcbNHxWHJ7WJc53KfIWXq9bdqiD7km4xuz35/a/tyh5tKvu7YyOGJyJq8BiMiOoqmZ3uaI9bEyCgh+kxJUW6cFTuKrsyX+HlqnV3GM++qFvMbk9u/HWdqRtlOnnpbt5JRFRPMRgR2TKZPeAeoFsQanqMITxdNV/RcidLF55uZ+gWs9tT3A9KJs978tcdeWJ4IiIbxWBEVN8ZhScziks76yo6YfzOdV0x8O103WJ2e4oyR5v8TZz35A84ejI8EVGdxGBERICdHHB/TLeYU1you5rOVGjSH33Kq2R4slOav8pOH6IcPBieiKjWMRgRUeXYyQGPprrFnOJC3R3ETd5dvHTJuwEU5wO3LugWs9tzqPju4gxPRFQDGIyIqPrYyQGPQN1iTnHB/buIm7pRZs5VXXFw8T3g1nndYo694/1bIzx4lZ0+VCndGZ6IqNIYjIiodtkpAM8g3WJOUb7uyJOpq+z0X+HdvQkU3QX+OqdbzLF3NH+Vnf5olNKN4YmIADAYEVFdZK8EPJvpFnOK8st02D1wlZ3+K7y7f5WGpz91i9ntOZk+2lT2KzyGJ6IGgcGIiGyTvRJo1Fy3mFN0z7gEOOeKca+d5ipw7xZQlAfc/EO3mCN3fuBWBf7lTx5XulX/+ySiWsVgRET1l73Dw8NT4V3d1XaGq+zKnjBe+ve920DhnUqEJ5cyR5sePPpU+rvStfrfJxFVGwYjImrY5I6VC08V3V085wqQnw0U5gI303SLOQrXMuc5mTnvSeFS7W+TiCqHwYiI6GHkjoBXC91iTmHe/a/tyh5tKvt7fg5QoAFuaIAbZ82vS+H6wM0xTZz3pHCu/vdJRAxGRETVQu4EeLXULeYU3DE+WdzUjTKNwtMZ8+tSuJmpZSlz6wK5U/W/T6J6jsGIiKi2KJyBxq10izkFuaaPPJU976kgR7dczwGup5pfl9LN/FV2+q/wGJ6IjDAYERHVJQoXoHFr3WKOPjyVPdpkdOTpmu6oU36Obrl+2vy6lO7lr7R78ORxuWO1v02iuorBiIjI1lQmPOVrHnLC+FXdyeL52bqlovDk4PHA0aayIaoJ4OLL8ET1BoMREVF9pHTVLd5tzI/J15SvZDH6Cu+q7jYF927rlqxT5tfl4PnA0aYH7i7u6qe7fQJRHcdgRETUUBnCU1vTzwuh+0rO5LlOZX4vytPdKPPeLSDrpPntOXiav8pOH6bslTXzXokqicGIiIhMk0h0J3Ar3QCfdqbHCKE7j8ncVXb6o1FFd++HJ3UF4cmxkflznfRByk5RM++XCAxGRET0KCQSwMFdt/i0Nz1GCN15TCaPPJUJUMX3dP12d/8C1CfMb9PRy/xVdvq/GZ6oihiMiIioZkkkuhO4HTwAVQfTY4TQncdk6mhT2fOeiu8Bd2/qlszfzW/TqXHFR55cfBmeyCQGIyIisj6JBHD01C0PDU8PnjD+wFd4xflA3g3dkplifptO3uWPNpX93cUXsJPXyNuluovBiIiIbINReAo2PUYI4O4t81fZ6f8uKQDyrusWs+FJAjh7m7nKTn8Uyg+Q2dfUOyYrYDAiIqL6QyIBnBrpFt+OpscYwtOVMkebrj5w3tM1XXi6k6Vbrh03t0HA2afiu4u7+DI82RAGIyIialiMwlMn02OE0J0EbvIquzInkJcUAnfUuuXaMXMb1IUnk1fZlQ1P/EiuC/ivQERE9CCJBHDy0i1+nU2P0Wp14cns3cVLH9cW3Q9PV4+a2Z609MiTqavsSr/Cc1YxPNUC7mEiIqKqkEoB58a6xa+L6TFare4KOnNX2WmuAJpMXXjKzdQtV81sTyLVhSNz93dy9deFK4anR8K9R0REVFOkUt0J3M7eFYenvBvmr7LLuQrkXgO0xbqfudfMb08iA1xU5k8YdysNT1JZzbzfeoDBiIiIyJqkUsDFR7f4dzU9RqvVXUFn6jwn/d/68KQPWPjN9LokMt05TRWdMN6AwxODERERUV0nleqOBLmoAP8Q02O0JbojT0ZddmVPHr+mW0RJ6fNXgCvmtmd3PzyVO+9JH56862V4YjAiIiKqD6Sy++EJFYSnO9dN311cf/QpN1N35Cnnsm4xuz19ePIvf5Wd/kiUk7cu1NkQBiMiIqKGQioDXH11C7qZHqMt0d27qaK7i1sUnvzKnDBuoqbFqXGdCk8MRkRERHSfVHb/rt7obnpMSbEuPOnPdTJ13tMddWl4uqRbzG7PvjSslTna1HUU0Kh5jby9h2EwIiIiIsvI7HQBxs0fFYcntYlzncp8hZer1t2qIPuSbtFr8wyDEREREdUjMjvdCdtuTYCAHqbHlBTpwtGDR5s8m9XuXMtgMCIiIiLrkNkD7gG6BaHWng0AoEpnO61duxaBgYFQKpUIDQ3F4cOHKxyfmJiINm3aQKlUIjg4GDt27DB6XgiBOXPmwNfXFw4ODoiIiMCff/5pNCYwMBASicRoiYuLM7m9c+fOwcXFBe7u7hbPhYiIiBoui4PRV199hZiYGMydOxfHjh1Dp06dEBkZievXr5scf+DAAQwfPhxjx47F8ePHERUVhaioKJw6dcowZsmSJVi9ejXWrVuHQ4cOwcnJCZGRkcjPzzda1/z585GZmWlYJk+eXG57RUVFGD58OB5//PEqzYWIiIgaLokQQljygtDQUHTv3h3vv/8+AECr1SIgIACTJ0/GzJkzy40fOnQo8vLysG3bNsNjPXv2ROfOnbFu3ToIIeDn54dp06bhzTffBADk5OTAx8cH8fHxGDZsGADdEaPo6GhER0dXOL8ZM2bg2rVr6NevH6Kjo5GdnV3puVSGRqOBm5sbcnJy4OrqWqnXEBERkXVV9vPboiNGhYWFOHr0KCIiIu6vQCpFREQEkpOTTb4mOTnZaDwAREZGGsanp6dDrVYbjXFzc0NoaGi5dcbFxaFRo0bo0qULli5diuLiYqPnd+/ejcTERKxdu7ZKczGloKAAGo3GaCEiIqL6yaKTr2/evImSkhL4+PgYPe7j44OzZ8+afI1arTY5Xq1WG57XP2ZuDABMmTIFXbt2haenJw4cOIBZs2YhMzMTK1asAAD89ddfGD16ND7//HOzSfBhczElNjYW7733ntnniYiIqP6wmavSYmJiDL937NgRcrkcEydORGxsLBQKBcaPH4+XXnoJffv2rdbtzpo1y2jbGo0GAQEB1boNIiIiqhss+irNy8sLMpkMWVlZRo9nZWVBpVKZfI1KpapwvP6nJesEdOc6FRcXIyMjA4Dua7Rly5bBzs4OdnZ2GDt2LHJycmBnZ4f169dXai6mKBQKuLq6Gi1ERERUP1kUjORyOUJCQpCUlGR4TKvVIikpCWFhYSZfExYWZjQeAHbt2mUYHxQUBJVKZTRGo9Hg0KFDZtcJACkpKZBKpfD29gagO38oJSXFsMyfPx8uLi5ISUnBkCFDKjUXIiIiauCEhRISEoRCoRDx8fEiNTVVTJgwQbi7uwu1Wi2EEGLEiBFi5syZhvH79+8XdnZ2YtmyZeLMmTNi7ty5wt7eXpw8edIwJi4uTri7u4vvvvtOnDhxQgwePFgEBQWJe/fuCSGEOHDggFi5cqVISUkR58+fF59//rlo3LixGDlypNl5btiwQbi5uRk9Vpm5PExOTo4AIHJycir9GiIiIrKuyn5+WxyMhBBizZo14rHHHhNyuVz06NFDHDx40PBceHi4GDVqlNH4r7/+WrRq1UrI5XLRvn17sX37dqPntVqtmD17tvDx8REKhUL069dPpKWlGZ4/evSoCA0NFW5ubkKpVIq2bduKxYsXi/z8fLNzNBWMKjOXh2EwIiIisj2V/fy2+D5GDR3vY0RERGR7auQ+RkRERET1GYMRERERUSmbuY9RXaH/5pF3wCYiIrId+s/th51BxGBkodzcXADgTR6JiIhsUG5uLtzc3Mw+z5OvLaTVanHt2jW4uLhAIpFU23r1d9S+fPkyT+quQdzPtYf7unZwP9cO7ufaUZP7WQiB3Nxc+Pn5QSo1fyYRjxhZSCqVokmTJjW2ft5du3ZwP9ce7uvawf1cO7ifa0dN7eeKjhTp8eRrIiIiolIMRkRERESlGIzqCIVCgblz50KhUFh7KvUa93Pt4b6uHdzPtYP7uXbUhf3Mk6+JiIiISvGIEREREVEpBiMiIiKiUgxGRERERKUYjIiIiIhKMRjVorVr1yIwMBBKpRKhoaE4fPhwheMTExPRpk0bKJVKBAcHY8eOHbU0U9tmyX7++OOP8fjjj8PDwwMeHh6IiIh46L8L3Wfpf9N6CQkJkEgkiIqKqtkJ1hOW7ufs7GxMmjQJvr6+UCgUaNWqFf//oxIs3c+rVq1C69at4eDggICAAEydOhX5+fm1NFvb9Msvv+DZZ5+Fn58fJBIJtmzZ8tDX7N27F127doVCoUCLFi0QHx9fs5MUVCsSEhKEXC4X69evF6dPnxbjx48X7u7uIisry+T4/fv3C5lMJpYsWSJSU1PFu+++K+zt7cXJkydreea2xdL9/NJLL4m1a9eK48ePizNnzojRo0cLNzc3ceXKlVqeue2xdF/rpaenC39/f/H444+LwYMH185kbZil+7mgoEB069ZNDBw4UPz6668iPT1d7N27V6SkpNTyzG2Lpfv5iy++EAqFQnzxxRciPT1d/Pjjj8LX11dMnTq1lmduW3bs2CHeeecd8e233woAYvPmzRWOv3DhgnB0dBQxMTEiNTVVrFmzRshkMrFz584amyODUS3p0aOHmDRpkuHvkpIS4efnJ2JjY02Of/HFF8WgQYOMHgsNDRUTJ06s0XnaOkv384OKi4uFi4uL+Oyzz2pqivVGVfZ1cXGx6NWrl/jkk0/EqFGjGIwqwdL9/O9//1s0a9ZMFBYW1tYU6wVL9/OkSZPEU089ZfRYTEyM6N27d43Osz6pTDCaPn26aN++vdFjQ4cOFZGRkTU2L36VVgsKCwtx9OhRREREGB6TSqWIiIhAcnKyydckJycbjQeAyMhIs+Opavv5QXfv3kVRURE8PT1rapr1QlX39fz58+Ht7Y2xY8fWxjRtXlX289atWxEWFoZJkybBx8cHHTp0wOLFi1FSUlJb07Y5VdnPvXr1wtGjRw1ft124cAE7duzAwIEDa2XODYU1PgtZIlsLbt68iZKSEvj4+Bg97uPjg7Nnz5p8jVqtNjlerVbX2DxtXVX284NmzJgBPz+/cv9DJGNV2de//vorPv30U6SkpNTCDOuHquznCxcuYPfu3Xj55ZexY8cOnDt3Dv/85z9RVFSEuXPn1sa0bU5V9vNLL72Emzdvok+fPhBCoLi4GK+99hrefvvt2phyg2Hus1Cj0eDevXtwcHCo9m3yiBFRqbi4OCQkJGDz5s1QKpXWnk69kpubixEjRuDjjz+Gl5eXtadTr2m1Wnh7e+Ojjz5CSEgIhg4dinfeeQfr1q2z9tTqlb1792Lx4sX44IMPcOzYMXz77bfYvn07FixYYO2p0SPiEaNa4OXlBZlMhqysLKPHs7KyoFKpTL5GpVJZNJ6qtp/1li1bhri4OPz888/o2LFjTU6zXrB0X58/fx4ZGRl49tlnDY9ptVoAgJ2dHdLS0tC8efOanbQNqsp/076+vrC3t4dMJjM81rZtW6jVahQWFkIul9fonG1RVfbz7NmzMWLECIwbNw4AEBwcjLy8PEyYMAHvvPMOpFIed6gO5j4LXV1da+RoEcAjRrVCLpcjJCQESUlJhse0Wi2SkpIQFhZm8jVhYWFG4wFg165dZsdT1fYzACxZsgQLFizAzp070a1bt9qYqs2zdF+3adMGJ0+eREpKimF57rnn8OSTTyIlJQUBAQG1OX2bUZX/pnv37o1z584ZgicA/PHHH/D19WUoMqMq+/nu3bvlwo8+jApWkFYbq3wW1thp3WQkISFBKBQKER8fL1JTU8WECROEu7u7UKvVQgghRowYIWbOnGkYv3//fmFnZyeWLVsmzpw5I+bOncvL9SvB0v0cFxcn5HK52LRpk8jMzDQsubm51noLNsPSff0gXpVWOZbu50uXLgkXFxfx+uuvi7S0NLFt2zbh7e0tFi5caK23YBMs3c9z584VLi4u4j//+Y+4cOGC+Omnn0Tz5s3Fiy++aK23YBNyc3PF8ePHxfHjxwUAsWLFCnH8+HFx8eJFIYQQM2fOFCNGjDCM11+u/9Zbb4kzZ86ItWvX8nL9+mTNmjXiscceE3K5XPTo0UMcPHjQ8Fx4eLgYNWqU0fivv/5atGrVSsjlctG+fXuxffv2Wp6xbbJkPzdt2lQAKLfMnTu39idugyz9b7osBqPKs3Q/HzhwQISGhgqFQiGaNWsmFi1aJIqLi2t51rbHkv1cVFQk5s2bJ5o3by6USqUICAgQ//znP8Xt27drf+I2ZM+ePSb/P1e/b0eNGiXCw8PLvaZz585CLpeLZs2aiQ0bNtToHCVC8JgfEREREcBzjIiIiIgMGIyIiIiISjEYEREREZViMCIiIiIqxWBEREREVIrBiIiIiKgUgxERERFRKQYjIiIiolIMRkRERESlGIyIiIiISjEYEREREZViMCIiIiIq9f/Pfb9+Jli0AwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(experiment.train_loss_mse[-200:], label=\"Train MSE\")\n",
    "plt.plot(experiment.test_loss_mse[-200:], label=\"Test MSE\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.005405354864743291"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "experiment.test_loss_mse[-1]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Convolutional Autoencoder\n",
    "Convolutional autoencoder implementation."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[16]\n",
      "ConvAE(\n",
      "  (encoder): Sequential(\n",
      "    (0): Conv1d(1, 32, kernel_size=(1,), stride=(1,))\n",
      "    (1): ReLU()\n",
      "    (2): Conv1d(32, 64, kernel_size=(1,), stride=(1,))\n",
      "    (3): ReLU()\n",
      "    (4): Flatten(start_dim=1, end_dim=-1)\n",
      "    (5): Linear(in_features=1984, out_features=31, bias=True)\n",
      "    (6): ReLU()\n",
      "    (7): Linear(in_features=31, out_features=16, bias=True)\n",
      "    (8): Tanh()\n",
      "  )\n",
      "  (decoder): Sequential(\n",
      "    (0): Linear(in_features=16, out_features=31, bias=True)\n",
      "    (1): ReLU()\n",
      "    (2): Linear(in_features=31, out_features=1984, bias=True)\n",
      "    (3): ReLU()\n",
      "    (4): Unflatten(dim=1, unflattened_size=(64, 31))\n",
      "    (5): ConvTranspose1d(64, 32, kernel_size=(1,), stride=(1,))\n",
      "    (6): ReLU()\n",
      "    (7): ConvTranspose1d(32, 1, kernel_size=(1,), stride=(1,))\n",
      "    (8): Tanh()\n",
      "  )\n",
      ")\n"
     ]
    }
   ],
   "source": [
    "# Model init\n",
    "from models import ConvAE\n",
    "\n",
    "hidden_spec = model_configs['ConvAE']['hidden_spec']\n",
    "hidden_spec[-1] = round(input_dim * dim_reduction)\n",
    "print(hidden_spec)\n",
    "model = ConvAE(\n",
    "    input_dim=input_dim, \n",
    "    hidden_spec=hidden_spec, \n",
    "    channel_spec=model_configs['ConvAE']['channel_spec']\n",
    ")\n",
    "model_name = model.__class__.__name__\n",
    "print(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "21120 - INFO - Step 50 loss: 0.00712072\n",
      "21120 - INFO - Step 100 loss: 0.00548403\n",
      "21120 - INFO - Step 150 loss: 0.00526876\n",
      "21120 - INFO - Step 200 loss: 0.00463885\n",
      "21120 - INFO - Step 250 loss: 0.00578132\n",
      "21120 - INFO - Step 300 loss: 0.00538849\n",
      "21120 - INFO - Step 350 loss: 0.00494924\n",
      "21120 - INFO - Step 400 loss: 0.00512485\n",
      "21120 - INFO - Epoch [1/100], Train Loss: 0.02086483, Test Loss: 0.00534502\n",
      "\n",
      "21120 - INFO - Step 450 loss: 0.00545259\n",
      "21120 - INFO - Step 500 loss: 0.00566984\n",
      "21120 - INFO - Step 550 loss: 0.00512880\n",
      "21120 - INFO - Step 600 loss: 0.00348200\n",
      "21120 - INFO - Step 650 loss: 0.00324222\n",
      "21120 - INFO - Step 700 loss: 0.00292829\n",
      "21120 - INFO - Step 750 loss: 0.00245209\n",
      "21120 - INFO - Step 800 loss: 0.00227316\n",
      "21120 - INFO - Step 850 loss: 0.00236751\n",
      "21120 - INFO - Epoch [2/100], Train Loss: 0.00366151, Test Loss: 0.00221511\n",
      "\n",
      "21120 - INFO - Step 900 loss: 0.00220702\n",
      "21120 - INFO - Step 950 loss: 0.00208801\n",
      "21120 - INFO - Step 1000 loss: 0.00187660\n",
      "21120 - INFO - Step 1050 loss: 0.00185994\n",
      "21120 - INFO - Step 1100 loss: 0.00229403\n",
      "21120 - INFO - Step 1150 loss: 0.00185852\n",
      "21120 - INFO - Step 1200 loss: 0.00165612\n",
      "21120 - INFO - Step 1250 loss: 0.00208662\n",
      "21120 - INFO - Step 1300 loss: 0.00187973\n",
      "21120 - INFO - Epoch [3/100], Train Loss: 0.00190033, Test Loss: 0.00175846\n",
      "\n",
      "21120 - INFO - Step 1350 loss: 0.00176666\n",
      "21120 - INFO - Step 1400 loss: 0.00147492\n",
      "21120 - INFO - Step 1450 loss: 0.00179471\n",
      "21120 - INFO - Step 1500 loss: 0.00161261\n",
      "21120 - INFO - Step 1550 loss: 0.00177184\n",
      "21120 - INFO - Step 1600 loss: 0.00160524\n",
      "21120 - INFO - Step 1650 loss: 0.00157729\n",
      "21120 - INFO - Step 1700 loss: 0.00160843\n",
      "21120 - INFO - Epoch [4/100], Train Loss: 0.00168125, Test Loss: 0.00164553\n",
      "\n",
      "21120 - INFO - Step 1750 loss: 0.00171589\n",
      "21120 - INFO - Step 1800 loss: 0.00153563\n",
      "21120 - INFO - Step 1850 loss: 0.00180156\n",
      "21120 - INFO - Step 1900 loss: 0.00141132\n",
      "21120 - INFO - Step 1950 loss: 0.00151810\n",
      "21120 - INFO - Step 2000 loss: 0.00166591\n",
      "21120 - INFO - Step 2050 loss: 0.00155006\n",
      "21120 - INFO - Step 2100 loss: 0.00149886\n",
      "21120 - INFO - Step 2150 loss: 0.00171912\n",
      "21120 - INFO - Epoch [5/100], Train Loss: 0.00166519, Test Loss: 0.00162694\n",
      "\n",
      "21120 - INFO - Step 2200 loss: 0.00181825\n",
      "21120 - INFO - Step 2250 loss: 0.00167140\n",
      "21120 - INFO - Step 2300 loss: 0.00163539\n",
      "21120 - INFO - Step 2350 loss: 0.00145159\n",
      "21120 - INFO - Step 2400 loss: 0.00172077\n",
      "21120 - INFO - Step 2450 loss: 0.00153312\n",
      "21120 - INFO - Step 2500 loss: 0.00157869\n",
      "21120 - INFO - Step 2550 loss: 0.00169726\n",
      "21120 - INFO - Step 2600 loss: 0.00158326\n",
      "21120 - INFO - Epoch [6/100], Train Loss: 0.00161254, Test Loss: 0.00160646\n",
      "\n",
      "21120 - INFO - Step 2650 loss: 0.00146723\n",
      "21120 - INFO - Step 2700 loss: 0.00150864\n",
      "21120 - INFO - Step 2750 loss: 0.00151514\n",
      "21120 - INFO - Step 2800 loss: 0.00148822\n",
      "21120 - INFO - Step 2850 loss: 0.00153460\n",
      "21120 - INFO - Step 2900 loss: 0.00155460\n",
      "21120 - INFO - Step 2950 loss: 0.00157641\n",
      "21120 - INFO - Step 3000 loss: 0.00146549\n",
      "21120 - INFO - Epoch [7/100], Train Loss: 0.00158277, Test Loss: 0.00158539\n",
      "\n",
      "21120 - INFO - Step 3050 loss: 0.00161654\n",
      "21120 - INFO - Step 3100 loss: 0.00156682\n",
      "21120 - INFO - Step 3150 loss: 0.00164708\n",
      "21120 - INFO - Step 3200 loss: 0.00170136\n",
      "21120 - INFO - Step 3250 loss: 0.00148881\n",
      "21120 - INFO - Step 3300 loss: 0.00161268\n",
      "21120 - INFO - Step 3350 loss: 0.00149123\n",
      "21120 - INFO - Step 3400 loss: 0.00184583\n",
      "21120 - INFO - Step 3450 loss: 0.00161609\n",
      "21120 - INFO - Epoch [8/100], Train Loss: 0.00156066, Test Loss: 0.00160474\n",
      "\n",
      "21120 - INFO - Step 3500 loss: 0.00161669\n",
      "21120 - INFO - Step 3550 loss: 0.00150098\n",
      "21120 - INFO - Step 3600 loss: 0.00160287\n",
      "21120 - INFO - Step 3650 loss: 0.00150454\n",
      "21120 - INFO - Step 3700 loss: 0.00145460\n",
      "21120 - INFO - Step 3750 loss: 0.00146447\n",
      "21120 - INFO - Step 3800 loss: 0.00129003\n",
      "21120 - INFO - Step 3850 loss: 0.00159015\n",
      "21120 - INFO - Step 3900 loss: 0.00159774\n",
      "21120 - INFO - Epoch [9/100], Train Loss: 0.00155409, Test Loss: 0.00169604\n",
      "\n",
      "21120 - INFO - Step 3950 loss: 0.00168444\n",
      "21120 - INFO - Step 4000 loss: 0.00146000\n",
      "21120 - INFO - Step 4050 loss: 0.00146157\n",
      "21120 - INFO - Step 4100 loss: 0.00166852\n",
      "21120 - INFO - Step 4150 loss: 0.00154804\n",
      "21120 - INFO - Step 4200 loss: 0.00157217\n",
      "21120 - INFO - Step 4250 loss: 0.00172737\n",
      "21120 - INFO - Step 4300 loss: 0.00133818\n",
      "21120 - INFO - Epoch [10/100], Train Loss: 0.00152903, Test Loss: 0.00152752\n",
      "\n",
      "21120 - INFO - Step 4350 loss: 0.00148214\n",
      "21120 - INFO - Step 4400 loss: 0.00169514\n",
      "21120 - INFO - Step 4450 loss: 0.00128352\n",
      "21120 - INFO - Step 4500 loss: 0.00152013\n",
      "21120 - INFO - Step 4550 loss: 0.00189157\n",
      "21120 - INFO - Step 4600 loss: 0.00161128\n",
      "21120 - INFO - Step 4650 loss: 0.00165675\n",
      "21120 - INFO - Step 4700 loss: 0.00152609\n",
      "21120 - INFO - Step 4750 loss: 0.00153921\n",
      "21120 - INFO - Epoch [11/100], Train Loss: 0.00150514, Test Loss: 0.00148520\n",
      "\n",
      "21120 - INFO - Step 4800 loss: 0.00157133\n",
      "21120 - INFO - Step 4850 loss: 0.00166758\n",
      "21120 - INFO - Step 4900 loss: 0.00148295\n",
      "21120 - INFO - Step 4950 loss: 0.00147117\n",
      "21120 - INFO - Step 5000 loss: 0.00132528\n",
      "21120 - INFO - Step 5050 loss: 0.00159546\n",
      "21120 - INFO - Step 5100 loss: 0.00155003\n",
      "21120 - INFO - Step 5150 loss: 0.00125944\n",
      "21120 - INFO - Step 5200 loss: 0.00134088\n",
      "21120 - INFO - Epoch [12/100], Train Loss: 0.00147675, Test Loss: 0.00145526\n",
      "\n",
      "21120 - INFO - Step 5250 loss: 0.00160364\n",
      "21120 - INFO - Step 5300 loss: 0.00140090\n",
      "21120 - INFO - Step 5350 loss: 0.00128479\n",
      "21120 - INFO - Step 5400 loss: 0.00149140\n",
      "21120 - INFO - Step 5450 loss: 0.00167767\n",
      "21120 - INFO - Step 5500 loss: 0.00143946\n",
      "21120 - INFO - Step 5550 loss: 0.00152870\n",
      "21120 - INFO - Step 5600 loss: 0.00124456\n",
      "21120 - INFO - Epoch [13/100], Train Loss: 0.00147153, Test Loss: 0.00146894\n",
      "\n",
      "21120 - INFO - Step 5650 loss: 0.00144781\n",
      "21120 - INFO - Step 5700 loss: 0.00120665\n",
      "21120 - INFO - Step 5750 loss: 0.00121215\n",
      "21120 - INFO - Step 5800 loss: 0.00142887\n",
      "21120 - INFO - Step 5850 loss: 0.00129482\n",
      "21120 - INFO - Step 5900 loss: 0.00156664\n",
      "21120 - INFO - Step 5950 loss: 0.00133035\n",
      "21120 - INFO - Step 6000 loss: 0.00144977\n",
      "21120 - INFO - Step 6050 loss: 0.00164251\n",
      "21120 - INFO - Epoch [14/100], Train Loss: 0.00145318, Test Loss: 0.00145017\n",
      "\n",
      "21120 - INFO - Step 6100 loss: 0.00127203\n",
      "21120 - INFO - Step 6150 loss: 0.00142846\n",
      "21120 - INFO - Step 6200 loss: 0.00164078\n",
      "21120 - INFO - Step 6250 loss: 0.00140362\n",
      "21120 - INFO - Step 6300 loss: 0.00142407\n",
      "21120 - INFO - Step 6350 loss: 0.00132993\n",
      "21120 - INFO - Step 6400 loss: 0.00151561\n",
      "21120 - INFO - Step 6450 loss: 0.00144420\n",
      "21120 - INFO - Step 6500 loss: 0.00134504\n",
      "21120 - INFO - Epoch [15/100], Train Loss: 0.00144281, Test Loss: 0.00144059\n",
      "\n",
      "21120 - INFO - Step 6550 loss: 0.00130533\n",
      "21120 - INFO - Step 6600 loss: 0.00131219\n",
      "21120 - INFO - Step 6650 loss: 0.00140836\n",
      "21120 - INFO - Step 6700 loss: 0.00159047\n",
      "21120 - INFO - Step 6750 loss: 0.00161559\n",
      "21120 - INFO - Step 6800 loss: 0.00145828\n",
      "21120 - INFO - Step 6850 loss: 0.00159710\n",
      "21120 - INFO - Step 6900 loss: 0.00140275\n",
      "21120 - INFO - Epoch [16/100], Train Loss: 0.00143327, Test Loss: 0.00151783\n",
      "\n",
      "21120 - INFO - Step 6950 loss: 0.00163027\n",
      "21120 - INFO - Step 7000 loss: 0.00124632\n",
      "21120 - INFO - Step 7050 loss: 0.00140624\n",
      "21120 - INFO - Step 7100 loss: 0.00146992\n",
      "21120 - INFO - Step 7150 loss: 0.00121155\n",
      "21120 - INFO - Step 7200 loss: 0.00139421\n",
      "21120 - INFO - Step 7250 loss: 0.00141895\n",
      "21120 - INFO - Step 7300 loss: 0.00143453\n",
      "21120 - INFO - Step 7350 loss: 0.00152215\n",
      "21120 - INFO - Epoch [17/100], Train Loss: 0.00141638, Test Loss: 0.00139414\n",
      "\n",
      "21120 - INFO - Step 7400 loss: 0.00151529\n",
      "21120 - INFO - Step 7450 loss: 0.00149580\n",
      "21120 - INFO - Step 7500 loss: 0.00146773\n",
      "21120 - INFO - Step 7550 loss: 0.00134812\n",
      "21120 - INFO - Step 7600 loss: 0.00133036\n",
      "21120 - INFO - Step 7650 loss: 0.00157248\n",
      "21120 - INFO - Step 7700 loss: 0.00136644\n",
      "21120 - INFO - Step 7750 loss: 0.00129749\n",
      "21120 - INFO - Step 7800 loss: 0.00139947\n",
      "21120 - INFO - Epoch [18/100], Train Loss: 0.00141419, Test Loss: 0.00142852\n",
      "\n",
      "21120 - INFO - Step 7850 loss: 0.00137983\n",
      "21120 - INFO - Step 7900 loss: 0.00147283\n",
      "21120 - INFO - Step 7950 loss: 0.00133667\n",
      "21120 - INFO - Step 8000 loss: 0.00142705\n",
      "21120 - INFO - Step 8050 loss: 0.00148418\n",
      "21120 - INFO - Step 8100 loss: 0.00132298\n",
      "21120 - INFO - Step 8150 loss: 0.00154736\n",
      "21120 - INFO - Step 8200 loss: 0.00135202\n",
      "21120 - INFO - Epoch [19/100], Train Loss: 0.00141012, Test Loss: 0.00155943\n",
      "\n",
      "21120 - INFO - Step 8250 loss: 0.00163071\n",
      "21120 - INFO - Step 8300 loss: 0.00128273\n",
      "21120 - INFO - Step 8350 loss: 0.00140166\n",
      "21120 - INFO - Step 8400 loss: 0.00160266\n",
      "21120 - INFO - Step 8450 loss: 0.00129875\n",
      "21120 - INFO - Step 8500 loss: 0.00119397\n",
      "21120 - INFO - Step 8550 loss: 0.00158828\n",
      "21120 - INFO - Step 8600 loss: 0.00127762\n",
      "21120 - INFO - Step 8650 loss: 0.00118502\n",
      "21120 - INFO - Epoch [20/100], Train Loss: 0.00139007, Test Loss: 0.00139540\n",
      "\n",
      "21120 - INFO - Step 8700 loss: 0.00144895\n",
      "21120 - INFO - Step 8750 loss: 0.00161419\n",
      "21120 - INFO - Step 8800 loss: 0.00130049\n",
      "21120 - INFO - Step 8850 loss: 0.00145079\n",
      "21120 - INFO - Step 8900 loss: 0.00147594\n",
      "21120 - INFO - Step 8950 loss: 0.00142440\n",
      "21120 - INFO - Step 9000 loss: 0.00141333\n",
      "21120 - INFO - Step 9050 loss: 0.00147659\n",
      "21120 - INFO - Step 9100 loss: 0.00130983\n",
      "21120 - INFO - Epoch [21/100], Train Loss: 0.00137758, Test Loss: 0.00140813\n",
      "\n",
      "21120 - INFO - Step 9150 loss: 0.00146357\n",
      "21120 - INFO - Step 9200 loss: 0.00118102\n",
      "21120 - INFO - Step 9250 loss: 0.00134564\n",
      "21120 - INFO - Step 9300 loss: 0.00142028\n",
      "21120 - INFO - Step 9350 loss: 0.00160727\n",
      "21120 - INFO - Step 9400 loss: 0.00141208\n",
      "21120 - INFO - Step 9450 loss: 0.00140259\n",
      "21120 - INFO - Step 9500 loss: 0.00143981\n",
      "21120 - INFO - Epoch [22/100], Train Loss: 0.00137015, Test Loss: 0.00140354\n",
      "\n",
      "21120 - INFO - Step 9550 loss: 0.00137283\n",
      "21120 - INFO - Step 9600 loss: 0.00141599\n",
      "21120 - INFO - Step 9650 loss: 0.00133465\n",
      "21120 - INFO - Step 9700 loss: 0.00136980\n",
      "21120 - INFO - Step 9750 loss: 0.00163778\n",
      "21120 - INFO - Step 9800 loss: 0.00151402\n",
      "21120 - INFO - Step 9850 loss: 0.00119147\n",
      "21120 - INFO - Step 9900 loss: 0.00129241\n",
      "21120 - INFO - Step 9950 loss: 0.00129601\n",
      "21120 - INFO - Epoch [23/100], Train Loss: 0.00135950, Test Loss: 0.00137010\n",
      "\n",
      "21120 - INFO - Step 10000 loss: 0.00126431\n",
      "21120 - INFO - Step 10050 loss: 0.00156878\n",
      "21120 - INFO - Step 10100 loss: 0.00139841\n",
      "21120 - INFO - Step 10150 loss: 0.00122802\n",
      "21120 - INFO - Step 10200 loss: 0.00128707\n",
      "21120 - INFO - Step 10250 loss: 0.00177460\n",
      "21120 - INFO - Step 10300 loss: 0.00147377\n",
      "21120 - INFO - Step 10350 loss: 0.00151321\n",
      "21120 - INFO - Step 10400 loss: 0.00144094\n",
      "21120 - INFO - Epoch [24/100], Train Loss: 0.00134825, Test Loss: 0.00141576\n",
      "\n",
      "21120 - INFO - Step 10450 loss: 0.00114449\n",
      "21120 - INFO - Step 10500 loss: 0.00135084\n",
      "21120 - INFO - Step 10550 loss: 0.00134594\n",
      "21120 - INFO - Step 10600 loss: 0.00136141\n",
      "21120 - INFO - Step 10650 loss: 0.00139940\n",
      "21120 - INFO - Step 10700 loss: 0.00136048\n",
      "21120 - INFO - Step 10750 loss: 0.00132831\n",
      "21120 - INFO - Step 10800 loss: 0.00134907\n",
      "21120 - INFO - Step 10850 loss: 0.00149202\n",
      "21120 - INFO - Epoch [25/100], Train Loss: 0.00134816, Test Loss: 0.00141006\n",
      "\n",
      "21120 - INFO - Step 10900 loss: 0.00128075\n",
      "21120 - INFO - Step 10950 loss: 0.00129737\n",
      "21120 - INFO - Step 11000 loss: 0.00133988\n",
      "21120 - INFO - Step 11050 loss: 0.00118989\n",
      "21120 - INFO - Step 11100 loss: 0.00124219\n",
      "21120 - INFO - Step 11150 loss: 0.00133423\n",
      "21120 - INFO - Step 11200 loss: 0.00141165\n",
      "21120 - INFO - Step 11250 loss: 0.00130218\n",
      "21120 - INFO - Epoch [26/100], Train Loss: 0.00133484, Test Loss: 0.00136669\n",
      "\n",
      "21120 - INFO - Step 11300 loss: 0.00125401\n",
      "21120 - INFO - Step 11350 loss: 0.00113385\n",
      "21120 - INFO - Step 11400 loss: 0.00142705\n",
      "21120 - INFO - Step 11450 loss: 0.00150837\n",
      "21120 - INFO - Step 11500 loss: 0.00120184\n",
      "21120 - INFO - Step 11550 loss: 0.00115546\n",
      "21120 - INFO - Step 11600 loss: 0.00123677\n",
      "21120 - INFO - Step 11650 loss: 0.00130972\n",
      "21120 - INFO - Step 11700 loss: 0.00132919\n",
      "21120 - INFO - Epoch [27/100], Train Loss: 0.00133154, Test Loss: 0.00132084\n",
      "\n",
      "21120 - INFO - Step 11750 loss: 0.00144046\n",
      "21120 - INFO - Step 11800 loss: 0.00111146\n",
      "21120 - INFO - Step 11850 loss: 0.00135580\n",
      "21120 - INFO - Step 11900 loss: 0.00122838\n",
      "21120 - INFO - Step 11950 loss: 0.00129211\n",
      "21120 - INFO - Step 12000 loss: 0.00138829\n",
      "21120 - INFO - Step 12050 loss: 0.00132418\n",
      "21120 - INFO - Step 12100 loss: 0.00127959\n",
      "21120 - INFO - Step 12150 loss: 0.00155365\n",
      "21120 - INFO - Epoch [28/100], Train Loss: 0.00132113, Test Loss: 0.00134738\n",
      "\n",
      "21120 - INFO - Step 12200 loss: 0.00157126\n",
      "21120 - INFO - Step 12250 loss: 0.00110437\n",
      "21120 - INFO - Step 12300 loss: 0.00140264\n",
      "21120 - INFO - Step 12350 loss: 0.00129631\n",
      "21120 - INFO - Step 12400 loss: 0.00138549\n",
      "21120 - INFO - Step 12450 loss: 0.00147433\n",
      "21120 - INFO - Step 12500 loss: 0.00137123\n",
      "21120 - INFO - Step 12550 loss: 0.00122416\n",
      "21120 - INFO - Epoch [29/100], Train Loss: 0.00131921, Test Loss: 0.00137089\n",
      "\n",
      "21120 - INFO - Step 12600 loss: 0.00146610\n",
      "21120 - INFO - Step 12650 loss: 0.00131381\n",
      "21120 - INFO - Step 12700 loss: 0.00132773\n",
      "21120 - INFO - Step 12750 loss: 0.00128628\n",
      "21120 - INFO - Step 12800 loss: 0.00143908\n",
      "21120 - INFO - Step 12850 loss: 0.00123409\n",
      "21120 - INFO - Step 12900 loss: 0.00120680\n",
      "21120 - INFO - Step 12950 loss: 0.00127970\n",
      "21120 - INFO - Step 13000 loss: 0.00149605\n",
      "21120 - INFO - Epoch [30/100], Train Loss: 0.00131249, Test Loss: 0.00133937\n",
      "\n",
      "21120 - INFO - Step 13050 loss: 0.00125040\n",
      "21120 - INFO - Step 13100 loss: 0.00139369\n",
      "21120 - INFO - Step 13150 loss: 0.00135149\n",
      "21120 - INFO - Step 13200 loss: 0.00135290\n",
      "21120 - INFO - Step 13250 loss: 0.00129963\n",
      "21120 - INFO - Step 13300 loss: 0.00113681\n",
      "21120 - INFO - Step 13350 loss: 0.00124692\n",
      "21120 - INFO - Step 13400 loss: 0.00126952\n",
      "21120 - INFO - Step 13450 loss: 0.00142500\n",
      "21120 - INFO - Epoch [31/100], Train Loss: 0.00130993, Test Loss: 0.00130518\n",
      "\n",
      "21120 - INFO - Step 13500 loss: 0.00105609\n",
      "21120 - INFO - Step 13550 loss: 0.00130447\n",
      "21120 - INFO - Step 13600 loss: 0.00118301\n",
      "21120 - INFO - Step 13650 loss: 0.00139510\n",
      "21120 - INFO - Step 13700 loss: 0.00125098\n",
      "21120 - INFO - Step 13750 loss: 0.00113897\n",
      "21120 - INFO - Step 13800 loss: 0.00146068\n",
      "21120 - INFO - Step 13850 loss: 0.00129464\n",
      "21120 - INFO - Epoch [32/100], Train Loss: 0.00130079, Test Loss: 0.00131094\n",
      "\n",
      "21120 - INFO - Step 13900 loss: 0.00121795\n",
      "21120 - INFO - Step 13950 loss: 0.00136982\n",
      "21120 - INFO - Step 14000 loss: 0.00127120\n",
      "21120 - INFO - Step 14050 loss: 0.00140534\n",
      "21120 - INFO - Step 14100 loss: 0.00122805\n",
      "21120 - INFO - Step 14150 loss: 0.00119099\n",
      "21120 - INFO - Step 14200 loss: 0.00130132\n",
      "21120 - INFO - Step 14250 loss: 0.00107698\n",
      "21120 - INFO - Step 14300 loss: 0.00147572\n",
      "21120 - INFO - Epoch [33/100], Train Loss: 0.00129364, Test Loss: 0.00131420\n",
      "\n",
      "21120 - INFO - Step 14350 loss: 0.00120832\n",
      "21120 - INFO - Step 14400 loss: 0.00137037\n",
      "21120 - INFO - Step 14450 loss: 0.00131694\n",
      "21120 - INFO - Step 14500 loss: 0.00149010\n",
      "21120 - INFO - Step 14550 loss: 0.00108840\n",
      "21120 - INFO - Step 14600 loss: 0.00126429\n",
      "21120 - INFO - Step 14650 loss: 0.00135432\n",
      "21120 - INFO - Step 14700 loss: 0.00128035\n",
      "21120 - INFO - Step 14750 loss: 0.00146903\n",
      "21120 - INFO - Epoch [34/100], Train Loss: 0.00129025, Test Loss: 0.00130227\n",
      "\n",
      "21120 - INFO - Step 14800 loss: 0.00121261\n",
      "21120 - INFO - Step 14850 loss: 0.00141518\n",
      "21120 - INFO - Step 14900 loss: 0.00128764\n",
      "21120 - INFO - Step 14950 loss: 0.00128141\n",
      "21120 - INFO - Step 15000 loss: 0.00127542\n",
      "21120 - INFO - Step 15050 loss: 0.00136166\n",
      "21120 - INFO - Step 15100 loss: 0.00119036\n",
      "21120 - INFO - Step 15150 loss: 0.00148269\n",
      "21120 - INFO - Epoch [35/100], Train Loss: 0.00128056, Test Loss: 0.00128811\n",
      "\n",
      "21120 - INFO - Step 15200 loss: 0.00133390\n",
      "21120 - INFO - Step 15250 loss: 0.00144235\n",
      "21120 - INFO - Step 15300 loss: 0.00128034\n",
      "21120 - INFO - Step 15350 loss: 0.00134342\n",
      "21120 - INFO - Step 15400 loss: 0.00144290\n",
      "21120 - INFO - Step 15450 loss: 0.00136290\n",
      "21120 - INFO - Step 15500 loss: 0.00151339\n",
      "21120 - INFO - Step 15550 loss: 0.00122055\n",
      "21120 - INFO - Step 15600 loss: 0.00142055\n",
      "21120 - INFO - Epoch [36/100], Train Loss: 0.00127703, Test Loss: 0.00130923\n",
      "\n",
      "21120 - INFO - Step 15650 loss: 0.00137453\n",
      "21120 - INFO - Step 15700 loss: 0.00117534\n",
      "21120 - INFO - Step 15750 loss: 0.00120957\n",
      "21120 - INFO - Step 15800 loss: 0.00114462\n",
      "21120 - INFO - Step 15850 loss: 0.00133271\n",
      "21120 - INFO - Step 15900 loss: 0.00129124\n",
      "21120 - INFO - Step 15950 loss: 0.00136218\n",
      "21120 - INFO - Step 16000 loss: 0.00124529\n",
      "21120 - INFO - Step 16050 loss: 0.00145592\n",
      "21120 - INFO - Epoch [37/100], Train Loss: 0.00127745, Test Loss: 0.00139280\n",
      "\n",
      "21120 - INFO - Step 16100 loss: 0.00133422\n",
      "21120 - INFO - Step 16150 loss: 0.00119423\n",
      "21120 - INFO - Step 16200 loss: 0.00137398\n",
      "21120 - INFO - Step 16250 loss: 0.00131722\n",
      "21120 - INFO - Step 16300 loss: 0.00115267\n",
      "21120 - INFO - Step 16350 loss: 0.00112690\n",
      "21120 - INFO - Step 16400 loss: 0.00128459\n",
      "21120 - INFO - Step 16450 loss: 0.00115242\n",
      "21120 - INFO - Epoch [38/100], Train Loss: 0.00127011, Test Loss: 0.00128743\n",
      "\n",
      "21120 - INFO - Step 16500 loss: 0.00116848\n",
      "21120 - INFO - Step 16550 loss: 0.00137332\n",
      "21120 - INFO - Step 16600 loss: 0.00115995\n",
      "21120 - INFO - Step 16650 loss: 0.00133512\n",
      "21120 - INFO - Step 16700 loss: 0.00115102\n",
      "21120 - INFO - Step 16750 loss: 0.00124367\n",
      "21120 - INFO - Step 16800 loss: 0.00121396\n",
      "21120 - INFO - Step 16850 loss: 0.00127207\n",
      "21120 - INFO - Step 16900 loss: 0.00131004\n",
      "21120 - INFO - Epoch [39/100], Train Loss: 0.00126753, Test Loss: 0.00129364\n",
      "\n",
      "21120 - INFO - Step 16950 loss: 0.00129669\n",
      "21120 - INFO - Step 17000 loss: 0.00116265\n",
      "21120 - INFO - Step 17050 loss: 0.00135992\n",
      "21120 - INFO - Step 17100 loss: 0.00111841\n",
      "21120 - INFO - Step 17150 loss: 0.00115290\n",
      "21120 - INFO - Step 17200 loss: 0.00125090\n",
      "21120 - INFO - Step 17250 loss: 0.00117443\n",
      "21120 - INFO - Step 17300 loss: 0.00135036\n",
      "21120 - INFO - Step 17350 loss: 0.00124239\n",
      "21120 - INFO - Epoch [40/100], Train Loss: 0.00125740, Test Loss: 0.00126538\n",
      "\n",
      "21120 - INFO - Step 17400 loss: 0.00137347\n",
      "21120 - INFO - Step 17450 loss: 0.00116277\n",
      "21120 - INFO - Step 17500 loss: 0.00123431\n",
      "21120 - INFO - Step 17550 loss: 0.00117036\n",
      "21120 - INFO - Step 17600 loss: 0.00135022\n",
      "21120 - INFO - Step 17650 loss: 0.00123050\n",
      "21120 - INFO - Step 17700 loss: 0.00142006\n",
      "21120 - INFO - Step 17750 loss: 0.00137286\n",
      "21120 - INFO - Epoch [41/100], Train Loss: 0.00125986, Test Loss: 0.00125970\n",
      "\n",
      "21120 - INFO - Step 17800 loss: 0.00131394\n",
      "21120 - INFO - Step 17850 loss: 0.00132011\n",
      "21120 - INFO - Step 17900 loss: 0.00145096\n",
      "21120 - INFO - Step 17950 loss: 0.00132498\n",
      "21120 - INFO - Step 18000 loss: 0.00128700\n",
      "21120 - INFO - Step 18050 loss: 0.00130740\n",
      "21120 - INFO - Step 18100 loss: 0.00146211\n",
      "21120 - INFO - Step 18150 loss: 0.00123540\n",
      "21120 - INFO - Step 18200 loss: 0.00118890\n",
      "21120 - INFO - Epoch [42/100], Train Loss: 0.00125404, Test Loss: 0.00132117\n",
      "\n",
      "21120 - INFO - Step 18250 loss: 0.00117311\n",
      "21120 - INFO - Step 18300 loss: 0.00116993\n",
      "21120 - INFO - Step 18350 loss: 0.00101877\n",
      "21120 - INFO - Step 18400 loss: 0.00119059\n",
      "21120 - INFO - Step 18450 loss: 0.00115319\n",
      "21120 - INFO - Step 18500 loss: 0.00137926\n",
      "21120 - INFO - Step 18550 loss: 0.00121933\n",
      "21120 - INFO - Step 18600 loss: 0.00126742\n",
      "21120 - INFO - Step 18650 loss: 0.00154576\n",
      "21120 - INFO - Epoch [43/100], Train Loss: 0.00125477, Test Loss: 0.00126846\n",
      "\n",
      "21120 - INFO - Step 18700 loss: 0.00134685\n",
      "21120 - INFO - Step 18750 loss: 0.00107998\n",
      "21120 - INFO - Step 18800 loss: 0.00136801\n",
      "21120 - INFO - Step 18850 loss: 0.00127975\n",
      "21120 - INFO - Step 18900 loss: 0.00127555\n",
      "21120 - INFO - Step 18950 loss: 0.00114289\n",
      "21120 - INFO - Step 19000 loss: 0.00138280\n",
      "21120 - INFO - Step 19050 loss: 0.00134173\n",
      "21120 - INFO - Epoch [44/100], Train Loss: 0.00124725, Test Loss: 0.00135835\n",
      "\n",
      "21120 - INFO - Step 19100 loss: 0.00139914\n",
      "21120 - INFO - Step 19150 loss: 0.00139691\n",
      "21120 - INFO - Step 19200 loss: 0.00108117\n",
      "21120 - INFO - Step 19250 loss: 0.00121647\n",
      "21120 - INFO - Step 19300 loss: 0.00140961\n",
      "21120 - INFO - Step 19350 loss: 0.00127309\n",
      "21120 - INFO - Step 19400 loss: 0.00124856\n",
      "21120 - INFO - Step 19450 loss: 0.00142780\n",
      "21120 - INFO - Step 19500 loss: 0.00128810\n",
      "21120 - INFO - Epoch [45/100], Train Loss: 0.00125061, Test Loss: 0.00138219\n",
      "\n",
      "21120 - INFO - Step 19550 loss: 0.00117331\n",
      "21120 - INFO - Step 19600 loss: 0.00121021\n",
      "21120 - INFO - Step 19650 loss: 0.00140663\n",
      "21120 - INFO - Step 19700 loss: 0.00138351\n",
      "21120 - INFO - Step 19750 loss: 0.00130104\n",
      "21120 - INFO - Step 19800 loss: 0.00118220\n",
      "21120 - INFO - Step 19850 loss: 0.00122646\n",
      "21120 - INFO - Step 19900 loss: 0.00121295\n",
      "21120 - INFO - Step 19950 loss: 0.00132274\n",
      "21120 - INFO - Epoch [46/100], Train Loss: 0.00123954, Test Loss: 0.00127041\n",
      "\n",
      "21120 - INFO - Step 20000 loss: 0.00111456\n",
      "21120 - INFO - Step 20050 loss: 0.00114215\n",
      "21120 - INFO - Step 20100 loss: 0.00138704\n",
      "21120 - INFO - Step 20150 loss: 0.00121465\n",
      "21120 - INFO - Step 20200 loss: 0.00111804\n",
      "21120 - INFO - Step 20250 loss: 0.00133844\n",
      "21120 - INFO - Step 20300 loss: 0.00117058\n",
      "21120 - INFO - Step 20350 loss: 0.00122649\n",
      "21120 - INFO - Epoch [47/100], Train Loss: 0.00123847, Test Loss: 0.00123971\n",
      "\n",
      "21120 - INFO - Step 20400 loss: 0.00120808\n",
      "21120 - INFO - Step 20450 loss: 0.00120709\n",
      "21120 - INFO - Step 20500 loss: 0.00139830\n",
      "21120 - INFO - Step 20550 loss: 0.00119770\n",
      "21120 - INFO - Step 20600 loss: 0.00112518\n",
      "21120 - INFO - Step 20650 loss: 0.00127750\n",
      "21120 - INFO - Step 20700 loss: 0.00123106\n",
      "21120 - INFO - Step 20750 loss: 0.00129034\n",
      "21120 - INFO - Step 20800 loss: 0.00112088\n",
      "21120 - INFO - Epoch [48/100], Train Loss: 0.00123047, Test Loss: 0.00125240\n",
      "\n",
      "21120 - INFO - Step 20850 loss: 0.00103903\n",
      "21120 - INFO - Step 20900 loss: 0.00128923\n",
      "21120 - INFO - Step 20950 loss: 0.00145060\n",
      "21120 - INFO - Step 21000 loss: 0.00117234\n",
      "21120 - INFO - Step 21050 loss: 0.00106487\n",
      "21120 - INFO - Step 21100 loss: 0.00118207\n",
      "21120 - INFO - Step 21150 loss: 0.00128607\n",
      "21120 - INFO - Step 21200 loss: 0.00127160\n",
      "21120 - INFO - Step 21250 loss: 0.00105611\n",
      "21120 - INFO - Epoch [49/100], Train Loss: 0.00122879, Test Loss: 0.00125588\n",
      "\n",
      "21120 - INFO - Step 21300 loss: 0.00144189\n",
      "21120 - INFO - Step 21350 loss: 0.00122686\n",
      "21120 - INFO - Step 21400 loss: 0.00121703\n",
      "21120 - INFO - Step 21450 loss: 0.00128881\n",
      "21120 - INFO - Step 21500 loss: 0.00133171\n",
      "21120 - INFO - Step 21550 loss: 0.00120413\n",
      "21120 - INFO - Step 21600 loss: 0.00116051\n",
      "21120 - INFO - Step 21650 loss: 0.00112419\n",
      "21120 - INFO - Step 21700 loss: 0.00107654\n",
      "21120 - INFO - Epoch [50/100], Train Loss: 0.00121387, Test Loss: 0.00121668\n",
      "\n",
      "21120 - INFO - Step 21750 loss: 0.00114834\n",
      "21120 - INFO - Step 21800 loss: 0.00123177\n",
      "21120 - INFO - Step 21850 loss: 0.00112306\n",
      "21120 - INFO - Step 21900 loss: 0.00126828\n",
      "21120 - INFO - Step 21950 loss: 0.00140795\n",
      "21120 - INFO - Step 22000 loss: 0.00124659\n",
      "21120 - INFO - Step 22050 loss: 0.00114989\n",
      "21120 - INFO - Step 22100 loss: 0.00114043\n",
      "21120 - INFO - Epoch [51/100], Train Loss: 0.00120146, Test Loss: 0.00133305\n",
      "\n",
      "21120 - INFO - Step 22150 loss: 0.00122822\n",
      "21120 - INFO - Step 22200 loss: 0.00108279\n",
      "21120 - INFO - Step 22250 loss: 0.00128452\n",
      "21120 - INFO - Step 22300 loss: 0.00128137\n",
      "21120 - INFO - Step 22350 loss: 0.00116392\n",
      "21120 - INFO - Step 22400 loss: 0.00119580\n",
      "21120 - INFO - Step 22450 loss: 0.00121009\n",
      "21120 - INFO - Step 22500 loss: 0.00128500\n",
      "21120 - INFO - Step 22550 loss: 0.00117136\n",
      "21120 - INFO - Epoch [52/100], Train Loss: 0.00119527, Test Loss: 0.00120443\n",
      "\n",
      "21120 - INFO - Step 22600 loss: 0.00137683\n",
      "21120 - INFO - Step 22650 loss: 0.00131987\n",
      "21120 - INFO - Step 22700 loss: 0.00113372\n",
      "21120 - INFO - Step 22750 loss: 0.00120800\n",
      "21120 - INFO - Step 22800 loss: 0.00119737\n",
      "21120 - INFO - Step 22850 loss: 0.00142663\n",
      "21120 - INFO - Step 22900 loss: 0.00110398\n",
      "21120 - INFO - Step 22950 loss: 0.00136532\n",
      "21120 - INFO - Step 23000 loss: 0.00110945\n",
      "21120 - INFO - Epoch [53/100], Train Loss: 0.00117778, Test Loss: 0.00119355\n",
      "\n",
      "21120 - INFO - Step 23050 loss: 0.00118530\n",
      "21120 - INFO - Step 23100 loss: 0.00124368\n",
      "21120 - INFO - Step 23150 loss: 0.00119484\n",
      "21120 - INFO - Step 23200 loss: 0.00111153\n",
      "21120 - INFO - Step 23250 loss: 0.00133479\n",
      "21120 - INFO - Step 23300 loss: 0.00125714\n",
      "21120 - INFO - Step 23350 loss: 0.00122578\n",
      "21120 - INFO - Step 23400 loss: 0.00114767\n",
      "21120 - INFO - Epoch [54/100], Train Loss: 0.00117528, Test Loss: 0.00116582\n",
      "\n",
      "21120 - INFO - Step 23450 loss: 0.00105539\n",
      "21120 - INFO - Step 23500 loss: 0.00108848\n",
      "21120 - INFO - Step 23550 loss: 0.00106545\n",
      "21120 - INFO - Step 23600 loss: 0.00117834\n",
      "21120 - INFO - Step 23650 loss: 0.00113889\n",
      "21120 - INFO - Step 23700 loss: 0.00130897\n",
      "21120 - INFO - Step 23750 loss: 0.00140379\n",
      "21120 - INFO - Step 23800 loss: 0.00112042\n",
      "21120 - INFO - Step 23850 loss: 0.00127254\n",
      "21120 - INFO - Epoch [55/100], Train Loss: 0.00116875, Test Loss: 0.00119738\n",
      "\n",
      "21120 - INFO - Step 23900 loss: 0.00126593\n",
      "21120 - INFO - Step 23950 loss: 0.00105591\n",
      "21120 - INFO - Step 24000 loss: 0.00104805\n",
      "21120 - INFO - Step 24050 loss: 0.00110091\n",
      "21120 - INFO - Step 24100 loss: 0.00121823\n",
      "21120 - INFO - Step 24150 loss: 0.00104336\n",
      "21120 - INFO - Step 24200 loss: 0.00116995\n",
      "21120 - INFO - Step 24250 loss: 0.00110855\n",
      "21120 - INFO - Step 24300 loss: 0.00100712\n",
      "21120 - INFO - Epoch [56/100], Train Loss: 0.00114750, Test Loss: 0.00119304\n",
      "\n",
      "21120 - INFO - Step 24350 loss: 0.00113572\n",
      "21120 - INFO - Step 24400 loss: 0.00124012\n",
      "21120 - INFO - Step 24450 loss: 0.00125661\n",
      "21120 - INFO - Step 24500 loss: 0.00123210\n",
      "21120 - INFO - Step 24550 loss: 0.00105217\n",
      "21120 - INFO - Step 24600 loss: 0.00135450\n",
      "21120 - INFO - Step 24650 loss: 0.00102790\n",
      "21120 - INFO - Step 24700 loss: 0.00127896\n",
      "21120 - INFO - Epoch [57/100], Train Loss: 0.00114475, Test Loss: 0.00118172\n",
      "\n",
      "21120 - INFO - Step 24750 loss: 0.00117019\n",
      "21120 - INFO - Step 24800 loss: 0.00124385\n",
      "21120 - INFO - Step 24850 loss: 0.00109341\n",
      "21120 - INFO - Step 24900 loss: 0.00098178\n",
      "21120 - INFO - Step 24950 loss: 0.00116143\n",
      "21120 - INFO - Step 25000 loss: 0.00099085\n",
      "21120 - INFO - Step 25050 loss: 0.00111692\n",
      "21120 - INFO - Step 25100 loss: 0.00107399\n",
      "21120 - INFO - Step 25150 loss: 0.00107616\n",
      "21120 - INFO - Epoch [58/100], Train Loss: 0.00113519, Test Loss: 0.00116027\n",
      "\n",
      "21120 - INFO - Step 25200 loss: 0.00113327\n",
      "21120 - INFO - Step 25250 loss: 0.00115642\n",
      "21120 - INFO - Step 25300 loss: 0.00118737\n",
      "21120 - INFO - Step 25350 loss: 0.00128929\n",
      "21120 - INFO - Step 25400 loss: 0.00131322\n",
      "21120 - INFO - Step 25450 loss: 0.00125871\n",
      "21120 - INFO - Step 25500 loss: 0.00112372\n",
      "21120 - INFO - Step 25550 loss: 0.00098374\n",
      "21120 - INFO - Step 25600 loss: 0.00132713\n",
      "21120 - INFO - Epoch [59/100], Train Loss: 0.00113470, Test Loss: 0.00119644\n",
      "\n",
      "21120 - INFO - Step 25650 loss: 0.00115668\n",
      "21120 - INFO - Step 25700 loss: 0.00111287\n",
      "21120 - INFO - Step 25750 loss: 0.00112279\n",
      "21120 - INFO - Step 25800 loss: 0.00107655\n",
      "21120 - INFO - Step 25850 loss: 0.00114354\n",
      "21120 - INFO - Step 25900 loss: 0.00105504\n",
      "21120 - INFO - Step 25950 loss: 0.00098920\n",
      "21120 - INFO - Step 26000 loss: 0.00113035\n",
      "21120 - INFO - Epoch [60/100], Train Loss: 0.00112949, Test Loss: 0.00114538\n",
      "\n",
      "21120 - INFO - Step 26050 loss: 0.00121160\n",
      "21120 - INFO - Step 26100 loss: 0.00108698\n",
      "21120 - INFO - Step 26150 loss: 0.00127019\n",
      "21120 - INFO - Step 26200 loss: 0.00117703\n",
      "21120 - INFO - Step 26250 loss: 0.00115430\n",
      "21120 - INFO - Step 26300 loss: 0.00103911\n",
      "21120 - INFO - Step 26350 loss: 0.00113396\n",
      "21120 - INFO - Step 26400 loss: 0.00122166\n",
      "21120 - INFO - Step 26450 loss: 0.00117135\n",
      "21120 - INFO - Epoch [61/100], Train Loss: 0.00112816, Test Loss: 0.00112169\n",
      "\n",
      "21120 - INFO - Step 26500 loss: 0.00104179\n",
      "21120 - INFO - Step 26550 loss: 0.00108221\n",
      "21120 - INFO - Step 26600 loss: 0.00106347\n",
      "21120 - INFO - Step 26650 loss: 0.00102828\n",
      "21120 - INFO - Step 26700 loss: 0.00104085\n",
      "21120 - INFO - Step 26750 loss: 0.00118139\n",
      "21120 - INFO - Step 26800 loss: 0.00110285\n",
      "21120 - INFO - Step 26850 loss: 0.00120654\n",
      "21120 - INFO - Step 26900 loss: 0.00104365\n",
      "21120 - INFO - Epoch [62/100], Train Loss: 0.00111911, Test Loss: 0.00114527\n",
      "\n",
      "21120 - INFO - Step 26950 loss: 0.00108826\n",
      "21120 - INFO - Step 27000 loss: 0.00102891\n",
      "21120 - INFO - Step 27050 loss: 0.00098057\n",
      "21120 - INFO - Step 27100 loss: 0.00117023\n",
      "21120 - INFO - Step 27150 loss: 0.00111523\n",
      "21120 - INFO - Step 27200 loss: 0.00109352\n",
      "21120 - INFO - Step 27250 loss: 0.00105613\n",
      "21120 - INFO - Step 27300 loss: 0.00121445\n",
      "21120 - INFO - Epoch [63/100], Train Loss: 0.00111363, Test Loss: 0.00116766\n",
      "\n",
      "21120 - INFO - Step 27350 loss: 0.00114698\n",
      "21120 - INFO - Step 27400 loss: 0.00100760\n",
      "21120 - INFO - Step 27450 loss: 0.00115622\n",
      "21120 - INFO - Step 27500 loss: 0.00108784\n",
      "21120 - INFO - Step 27550 loss: 0.00129114\n",
      "21120 - INFO - Step 27600 loss: 0.00107392\n",
      "21120 - INFO - Step 27650 loss: 0.00115380\n",
      "21120 - INFO - Step 27700 loss: 0.00099018\n",
      "21120 - INFO - Step 27750 loss: 0.00119127\n",
      "21120 - INFO - Epoch [64/100], Train Loss: 0.00110447, Test Loss: 0.00118905\n",
      "\n",
      "21120 - INFO - Step 27800 loss: 0.00103561\n",
      "21120 - INFO - Step 27850 loss: 0.00113955\n",
      "21120 - INFO - Step 27900 loss: 0.00107282\n",
      "21120 - INFO - Step 27950 loss: 0.00105599\n",
      "21120 - INFO - Step 28000 loss: 0.00120218\n",
      "21120 - INFO - Step 28050 loss: 0.00132620\n",
      "21120 - INFO - Step 28100 loss: 0.00105292\n",
      "21120 - INFO - Step 28150 loss: 0.00113852\n",
      "21120 - INFO - Step 28200 loss: 0.00126315\n",
      "21120 - INFO - Epoch [65/100], Train Loss: 0.00110155, Test Loss: 0.00112355\n",
      "\n",
      "21120 - INFO - Step 28250 loss: 0.00122120\n",
      "21120 - INFO - Step 28300 loss: 0.00098902\n",
      "21120 - INFO - Step 28350 loss: 0.00093083\n",
      "21120 - INFO - Step 28400 loss: 0.00107549\n",
      "21120 - INFO - Step 28450 loss: 0.00103222\n",
      "21120 - INFO - Step 28500 loss: 0.00113942\n",
      "21120 - INFO - Step 28550 loss: 0.00093684\n",
      "21120 - INFO - Step 28600 loss: 0.00100873\n",
      "21120 - INFO - Epoch [66/100], Train Loss: 0.00109870, Test Loss: 0.00113369\n",
      "\n",
      "21120 - INFO - Step 28650 loss: 0.00107357\n",
      "21120 - INFO - Step 28700 loss: 0.00117287\n",
      "21120 - INFO - Step 28750 loss: 0.00102634\n",
      "21120 - INFO - Step 28800 loss: 0.00125859\n",
      "21120 - INFO - Step 28850 loss: 0.00114033\n",
      "21120 - INFO - Step 28900 loss: 0.00111148\n",
      "21120 - INFO - Step 28950 loss: 0.00118224\n",
      "21120 - INFO - Step 29000 loss: 0.00097140\n",
      "21120 - INFO - Step 29050 loss: 0.00119834\n",
      "21120 - INFO - Epoch [67/100], Train Loss: 0.00109721, Test Loss: 0.00111708\n",
      "\n",
      "21120 - INFO - Step 29100 loss: 0.00106065\n",
      "21120 - INFO - Step 29150 loss: 0.00138537\n",
      "21120 - INFO - Step 29200 loss: 0.00107256\n",
      "21120 - INFO - Step 29250 loss: 0.00114069\n",
      "21120 - INFO - Step 29300 loss: 0.00101670\n",
      "21120 - INFO - Step 29350 loss: 0.00098374\n",
      "21120 - INFO - Step 29400 loss: 0.00104451\n",
      "21120 - INFO - Step 29450 loss: 0.00099523\n",
      "21120 - INFO - Step 29500 loss: 0.00109778\n",
      "21120 - INFO - Epoch [68/100], Train Loss: 0.00109582, Test Loss: 0.00112756\n",
      "\n",
      "21120 - INFO - Step 29550 loss: 0.00110953\n",
      "21120 - INFO - Step 29600 loss: 0.00096539\n",
      "21120 - INFO - Step 29650 loss: 0.00111615\n",
      "21120 - INFO - Step 29700 loss: 0.00099060\n",
      "21120 - INFO - Step 29750 loss: 0.00119631\n",
      "21120 - INFO - Step 29800 loss: 0.00123022\n",
      "21120 - INFO - Step 29850 loss: 0.00119741\n",
      "21120 - INFO - Step 29900 loss: 0.00116431\n",
      "21120 - INFO - Epoch [69/100], Train Loss: 0.00109271, Test Loss: 0.00108715\n",
      "\n",
      "21120 - INFO - Step 29950 loss: 0.00107690\n",
      "21120 - INFO - Step 30000 loss: 0.00104516\n",
      "21120 - INFO - Step 30050 loss: 0.00127391\n",
      "21120 - INFO - Step 30100 loss: 0.00113571\n",
      "21120 - INFO - Step 30150 loss: 0.00100341\n",
      "21120 - INFO - Step 30200 loss: 0.00105660\n",
      "21120 - INFO - Step 30250 loss: 0.00110669\n",
      "21120 - INFO - Step 30300 loss: 0.00102193\n",
      "21120 - INFO - Step 30350 loss: 0.00115793\n",
      "21120 - INFO - Epoch [70/100], Train Loss: 0.00108908, Test Loss: 0.00116652\n",
      "\n",
      "21120 - INFO - Step 30400 loss: 0.00105789\n",
      "21120 - INFO - Step 30450 loss: 0.00102604\n",
      "21120 - INFO - Step 30500 loss: 0.00129746\n",
      "21120 - INFO - Step 30550 loss: 0.00112589\n",
      "21120 - INFO - Step 30600 loss: 0.00110715\n",
      "21120 - INFO - Step 30650 loss: 0.00110670\n",
      "21120 - INFO - Step 30700 loss: 0.00116546\n",
      "21120 - INFO - Step 30750 loss: 0.00128211\n",
      "21120 - INFO - Step 30800 loss: 0.00092325\n",
      "21120 - INFO - Epoch [71/100], Train Loss: 0.00108679, Test Loss: 0.00114089\n",
      "\n",
      "21120 - INFO - Step 30850 loss: 0.00100963\n",
      "21120 - INFO - Step 30900 loss: 0.00109324\n",
      "21120 - INFO - Step 30950 loss: 0.00101266\n",
      "21120 - INFO - Step 31000 loss: 0.00110623\n",
      "21120 - INFO - Step 31050 loss: 0.00115718\n",
      "21120 - INFO - Step 31100 loss: 0.00102914\n",
      "21120 - INFO - Step 31150 loss: 0.00126124\n",
      "21120 - INFO - Step 31200 loss: 0.00124127\n",
      "21120 - INFO - Epoch [72/100], Train Loss: 0.00108362, Test Loss: 0.00112230\n",
      "\n",
      "21120 - INFO - Step 31250 loss: 0.00102164\n",
      "21120 - INFO - Step 31300 loss: 0.00107851\n",
      "21120 - INFO - Step 31350 loss: 0.00110637\n",
      "21120 - INFO - Step 31400 loss: 0.00117248\n",
      "21120 - INFO - Step 31450 loss: 0.00102577\n",
      "21120 - INFO - Step 31500 loss: 0.00111230\n",
      "21120 - INFO - Step 31550 loss: 0.00116767\n",
      "21120 - INFO - Step 31600 loss: 0.00106847\n",
      "21120 - INFO - Step 31650 loss: 0.00109632\n",
      "21120 - INFO - Epoch [73/100], Train Loss: 0.00108395, Test Loss: 0.00109594\n",
      "\n",
      "21120 - INFO - Step 31700 loss: 0.00099028\n",
      "21120 - INFO - Step 31750 loss: 0.00109907\n",
      "21120 - INFO - Step 31800 loss: 0.00122684\n",
      "21120 - INFO - Step 31850 loss: 0.00094862\n",
      "21120 - INFO - Step 31900 loss: 0.00105962\n",
      "21120 - INFO - Step 31950 loss: 0.00098605\n",
      "21120 - INFO - Step 32000 loss: 0.00111103\n",
      "21120 - INFO - Step 32050 loss: 0.00107752\n",
      "21120 - INFO - Step 32100 loss: 0.00112502\n",
      "21120 - INFO - Epoch [74/100], Train Loss: 0.00108151, Test Loss: 0.00115824\n",
      "\n",
      "21120 - INFO - Step 32150 loss: 0.00110280\n",
      "21120 - INFO - Step 32200 loss: 0.00113105\n",
      "21120 - INFO - Step 32250 loss: 0.00116230\n",
      "21120 - INFO - Step 32300 loss: 0.00105991\n",
      "21120 - INFO - Step 32350 loss: 0.00115225\n",
      "21120 - INFO - Step 32400 loss: 0.00111468\n",
      "21120 - INFO - Step 32450 loss: 0.00095132\n",
      "21120 - INFO - Step 32500 loss: 0.00113485\n",
      "21120 - INFO - Step 32550 loss: 0.00095497\n",
      "21120 - INFO - Epoch [75/100], Train Loss: 0.00108545, Test Loss: 0.00107682\n",
      "\n",
      "21120 - INFO - Step 32600 loss: 0.00127208\n",
      "21120 - INFO - Step 32650 loss: 0.00101767\n",
      "21120 - INFO - Step 32700 loss: 0.00101263\n",
      "21120 - INFO - Step 32750 loss: 0.00100142\n",
      "21120 - INFO - Step 32800 loss: 0.00114627\n",
      "21120 - INFO - Step 32850 loss: 0.00129918\n",
      "21120 - INFO - Step 32900 loss: 0.00112075\n",
      "21120 - INFO - Step 32950 loss: 0.00128609\n",
      "21120 - INFO - Epoch [76/100], Train Loss: 0.00108056, Test Loss: 0.00108360\n",
      "\n",
      "21120 - INFO - Step 33000 loss: 0.00111747\n",
      "21120 - INFO - Step 33050 loss: 0.00095152\n",
      "21120 - INFO - Step 33100 loss: 0.00100002\n",
      "21120 - INFO - Step 33150 loss: 0.00096579\n",
      "21120 - INFO - Step 33200 loss: 0.00097918\n",
      "21120 - INFO - Step 33250 loss: 0.00093471\n",
      "21120 - INFO - Step 33300 loss: 0.00104181\n",
      "21120 - INFO - Step 33350 loss: 0.00122673\n",
      "21120 - INFO - Step 33400 loss: 0.00101505\n",
      "21120 - INFO - Epoch [77/100], Train Loss: 0.00108018, Test Loss: 0.00109399\n",
      "\n",
      "21120 - INFO - Step 33450 loss: 0.00096004\n",
      "21120 - INFO - Step 33500 loss: 0.00100556\n",
      "21120 - INFO - Step 33550 loss: 0.00101736\n",
      "21120 - INFO - Step 33600 loss: 0.00110555\n",
      "21120 - INFO - Step 33650 loss: 0.00102591\n",
      "21120 - INFO - Step 33700 loss: 0.00119414\n",
      "21120 - INFO - Step 33750 loss: 0.00117124\n",
      "21120 - INFO - Step 33800 loss: 0.00091901\n",
      "21120 - INFO - Step 33850 loss: 0.00115386\n",
      "21120 - INFO - Epoch [78/100], Train Loss: 0.00107907, Test Loss: 0.00111677\n",
      "\n",
      "21120 - INFO - Step 33900 loss: 0.00109867\n",
      "21120 - INFO - Step 33950 loss: 0.00111033\n",
      "21120 - INFO - Step 34000 loss: 0.00117043\n",
      "21120 - INFO - Step 34050 loss: 0.00112653\n",
      "21120 - INFO - Step 34100 loss: 0.00115957\n",
      "21120 - INFO - Step 34150 loss: 0.00109505\n",
      "21120 - INFO - Step 34200 loss: 0.00100437\n",
      "21120 - INFO - Step 34250 loss: 0.00101931\n",
      "21120 - INFO - Epoch [79/100], Train Loss: 0.00107647, Test Loss: 0.00106643\n",
      "\n",
      "21120 - INFO - Step 34300 loss: 0.00120373\n",
      "21120 - INFO - Step 34350 loss: 0.00103752\n",
      "21120 - INFO - Step 34400 loss: 0.00103694\n",
      "21120 - INFO - Step 34450 loss: 0.00107696\n",
      "21120 - INFO - Step 34500 loss: 0.00103792\n",
      "21120 - INFO - Step 34550 loss: 0.00117343\n",
      "21120 - INFO - Step 34600 loss: 0.00091651\n",
      "21120 - INFO - Step 34650 loss: 0.00108988\n",
      "21120 - INFO - Step 34700 loss: 0.00114832\n",
      "21120 - INFO - Epoch [80/100], Train Loss: 0.00107287, Test Loss: 0.00108065\n",
      "\n",
      "21120 - INFO - Step 34750 loss: 0.00104562\n",
      "21120 - INFO - Step 34800 loss: 0.00099577\n",
      "21120 - INFO - Step 34850 loss: 0.00103387\n",
      "21120 - INFO - Step 34900 loss: 0.00105425\n",
      "21120 - INFO - Step 34950 loss: 0.00114736\n",
      "21120 - INFO - Step 35000 loss: 0.00116053\n",
      "21120 - INFO - Step 35050 loss: 0.00128171\n",
      "21120 - INFO - Step 35100 loss: 0.00105509\n",
      "21120 - INFO - Step 35150 loss: 0.00098126\n",
      "21120 - INFO - Epoch [81/100], Train Loss: 0.00107133, Test Loss: 0.00108361\n",
      "\n",
      "21120 - INFO - Step 35200 loss: 0.00109183\n",
      "21120 - INFO - Step 35250 loss: 0.00094980\n",
      "21120 - INFO - Step 35300 loss: 0.00101303\n",
      "21120 - INFO - Step 35350 loss: 0.00118692\n",
      "21120 - INFO - Step 35400 loss: 0.00101026\n",
      "21120 - INFO - Step 35450 loss: 0.00111696\n",
      "21120 - INFO - Step 35500 loss: 0.00119781\n",
      "21120 - INFO - Step 35550 loss: 0.00112610\n",
      "21120 - INFO - Epoch [82/100], Train Loss: 0.00107260, Test Loss: 0.00106692\n",
      "\n",
      "21120 - INFO - Step 35600 loss: 0.00105016\n",
      "21120 - INFO - Step 35650 loss: 0.00104355\n",
      "21120 - INFO - Step 35700 loss: 0.00118742\n",
      "21120 - INFO - Step 35750 loss: 0.00118400\n",
      "21120 - INFO - Step 35800 loss: 0.00101627\n",
      "21120 - INFO - Step 35850 loss: 0.00112420\n",
      "21120 - INFO - Step 35900 loss: 0.00097850\n",
      "21120 - INFO - Step 35950 loss: 0.00115101\n",
      "21120 - INFO - Step 36000 loss: 0.00117579\n",
      "21120 - INFO - Epoch [83/100], Train Loss: 0.00107004, Test Loss: 0.00110359\n",
      "\n",
      "21120 - INFO - Step 36050 loss: 0.00113233\n",
      "21120 - INFO - Step 36100 loss: 0.00108939\n",
      "21120 - INFO - Step 36150 loss: 0.00104058\n",
      "21120 - INFO - Step 36200 loss: 0.00091891\n",
      "21120 - INFO - Step 36250 loss: 0.00103664\n",
      "21120 - INFO - Step 36300 loss: 0.00104743\n",
      "21120 - INFO - Step 36350 loss: 0.00113323\n",
      "21120 - INFO - Step 36400 loss: 0.00112867\n",
      "21120 - INFO - Step 36450 loss: 0.00117284\n",
      "21120 - INFO - Epoch [84/100], Train Loss: 0.00106826, Test Loss: 0.00109402\n",
      "\n",
      "21120 - INFO - Step 36500 loss: 0.00099383\n",
      "21120 - INFO - Step 36550 loss: 0.00111689\n",
      "21120 - INFO - Step 36600 loss: 0.00096470\n",
      "21120 - INFO - Step 36650 loss: 0.00097250\n",
      "21120 - INFO - Step 36700 loss: 0.00105045\n",
      "21120 - INFO - Step 36750 loss: 0.00109611\n",
      "21120 - INFO - Step 36800 loss: 0.00104430\n",
      "21120 - INFO - Step 36850 loss: 0.00097538\n",
      "21120 - INFO - Epoch [85/100], Train Loss: 0.00106566, Test Loss: 0.00110969\n",
      "\n",
      "21120 - INFO - Step 36900 loss: 0.00107160\n",
      "21120 - INFO - Step 36950 loss: 0.00102323\n",
      "21120 - INFO - Step 37000 loss: 0.00112398\n",
      "21120 - INFO - Step 37050 loss: 0.00090655\n",
      "21120 - INFO - Step 37100 loss: 0.00100812\n",
      "21120 - INFO - Step 37150 loss: 0.00098256\n",
      "21120 - INFO - Step 37200 loss: 0.00107440\n",
      "21120 - INFO - Step 37250 loss: 0.00104022\n",
      "21120 - INFO - Step 37300 loss: 0.00104381\n",
      "21120 - INFO - Epoch [86/100], Train Loss: 0.00106803, Test Loss: 0.00108269\n",
      "\n",
      "21120 - INFO - Step 37350 loss: 0.00125845\n",
      "21120 - INFO - Step 37400 loss: 0.00104073\n",
      "21120 - INFO - Step 37450 loss: 0.00098345\n",
      "21120 - INFO - Step 37500 loss: 0.00085851\n",
      "21120 - INFO - Step 37550 loss: 0.00105000\n",
      "21120 - INFO - Step 37600 loss: 0.00103412\n",
      "21120 - INFO - Step 37650 loss: 0.00103641\n",
      "21120 - INFO - Step 37700 loss: 0.00105149\n",
      "21120 - INFO - Step 37750 loss: 0.00108184\n",
      "21120 - INFO - Epoch [87/100], Train Loss: 0.00106241, Test Loss: 0.00106983\n",
      "\n",
      "21120 - INFO - Step 37800 loss: 0.00125094\n",
      "21120 - INFO - Step 37850 loss: 0.00102165\n",
      "21120 - INFO - Step 37900 loss: 0.00093796\n",
      "21120 - INFO - Step 37950 loss: 0.00100129\n",
      "21120 - INFO - Step 38000 loss: 0.00110594\n",
      "21120 - INFO - Step 38050 loss: 0.00091539\n",
      "21120 - INFO - Step 38100 loss: 0.00107941\n",
      "21120 - INFO - Step 38150 loss: 0.00111660\n",
      "21120 - INFO - Epoch [88/100], Train Loss: 0.00105941, Test Loss: 0.00111973\n",
      "\n",
      "21120 - INFO - Step 38200 loss: 0.00100263\n",
      "21120 - INFO - Step 38250 loss: 0.00110064\n",
      "21120 - INFO - Step 38300 loss: 0.00101704\n",
      "21120 - INFO - Step 38350 loss: 0.00102583\n",
      "21120 - INFO - Step 38400 loss: 0.00107798\n",
      "21120 - INFO - Step 38450 loss: 0.00099320\n",
      "21120 - INFO - Step 38500 loss: 0.00102562\n",
      "21120 - INFO - Step 38550 loss: 0.00106249\n",
      "21120 - INFO - Step 38600 loss: 0.00097933\n",
      "21120 - INFO - Epoch [89/100], Train Loss: 0.00105919, Test Loss: 0.00105906\n",
      "\n",
      "21120 - INFO - Step 38650 loss: 0.00094449\n",
      "21120 - INFO - Step 38700 loss: 0.00108315\n",
      "21120 - INFO - Step 38750 loss: 0.00101997\n",
      "21120 - INFO - Step 38800 loss: 0.00101302\n",
      "21120 - INFO - Step 38850 loss: 0.00110684\n",
      "21120 - INFO - Step 38900 loss: 0.00096481\n",
      "21120 - INFO - Step 38950 loss: 0.00112706\n",
      "21120 - INFO - Step 39000 loss: 0.00096330\n",
      "21120 - INFO - Step 39050 loss: 0.00093851\n",
      "21120 - INFO - Epoch [90/100], Train Loss: 0.00106504, Test Loss: 0.00106398\n",
      "\n",
      "21120 - INFO - Step 39100 loss: 0.00102229\n",
      "21120 - INFO - Step 39150 loss: 0.00111510\n",
      "21120 - INFO - Step 39200 loss: 0.00109882\n",
      "21120 - INFO - Step 39250 loss: 0.00111445\n",
      "21120 - INFO - Step 39300 loss: 0.00112774\n",
      "21120 - INFO - Step 39350 loss: 0.00104431\n",
      "21120 - INFO - Step 39400 loss: 0.00109315\n",
      "21120 - INFO - Step 39450 loss: 0.00097233\n",
      "21120 - INFO - Epoch [91/100], Train Loss: 0.00105894, Test Loss: 0.00105853\n",
      "\n",
      "21120 - INFO - Step 39500 loss: 0.00111663\n",
      "21120 - INFO - Step 39550 loss: 0.00107707\n",
      "21120 - INFO - Step 39600 loss: 0.00105015\n",
      "21120 - INFO - Step 39650 loss: 0.00113599\n",
      "21120 - INFO - Step 39700 loss: 0.00091145\n",
      "21120 - INFO - Step 39750 loss: 0.00107428\n",
      "21120 - INFO - Step 39800 loss: 0.00112669\n",
      "21120 - INFO - Step 39850 loss: 0.00095098\n",
      "21120 - INFO - Step 39900 loss: 0.00095140\n",
      "21120 - INFO - Epoch [92/100], Train Loss: 0.00106203, Test Loss: 0.00114100\n",
      "\n",
      "21120 - INFO - Step 39950 loss: 0.00117551\n",
      "21120 - INFO - Step 40000 loss: 0.00112393\n",
      "21120 - INFO - Step 40050 loss: 0.00109025\n",
      "21120 - INFO - Step 40100 loss: 0.00099874\n",
      "21120 - INFO - Step 40150 loss: 0.00098084\n",
      "21120 - INFO - Step 40200 loss: 0.00108441\n",
      "21120 - INFO - Step 40250 loss: 0.00119055\n",
      "21120 - INFO - Step 40300 loss: 0.00098059\n",
      "21120 - INFO - Step 40350 loss: 0.00109804\n",
      "21120 - INFO - Epoch [93/100], Train Loss: 0.00105944, Test Loss: 0.00107607\n",
      "\n",
      "21120 - INFO - Step 40400 loss: 0.00103616\n",
      "21120 - INFO - Step 40450 loss: 0.00102161\n",
      "21120 - INFO - Step 40500 loss: 0.00097556\n",
      "21120 - INFO - Step 40550 loss: 0.00103778\n",
      "21120 - INFO - Step 40600 loss: 0.00109085\n",
      "21120 - INFO - Step 40650 loss: 0.00112244\n",
      "21120 - INFO - Step 40700 loss: 0.00111425\n",
      "21120 - INFO - Step 40750 loss: 0.00109186\n",
      "21120 - INFO - Epoch [94/100], Train Loss: 0.00105924, Test Loss: 0.00117779\n",
      "\n",
      "21120 - INFO - Step 40800 loss: 0.00122297\n",
      "21120 - INFO - Step 40850 loss: 0.00108297\n",
      "21120 - INFO - Step 40900 loss: 0.00104795\n",
      "21120 - INFO - Step 40950 loss: 0.00096083\n",
      "21120 - INFO - Step 41000 loss: 0.00118226\n",
      "21120 - INFO - Step 41050 loss: 0.00106181\n",
      "21120 - INFO - Step 41100 loss: 0.00110792\n",
      "21120 - INFO - Step 41150 loss: 0.00091879\n",
      "21120 - INFO - Step 41200 loss: 0.00090415\n",
      "21120 - INFO - Epoch [95/100], Train Loss: 0.00105760, Test Loss: 0.00107493\n",
      "\n",
      "21120 - INFO - Step 41250 loss: 0.00097856\n",
      "21120 - INFO - Step 41300 loss: 0.00099639\n",
      "21120 - INFO - Step 41350 loss: 0.00111883\n",
      "21120 - INFO - Step 41400 loss: 0.00099377\n",
      "21120 - INFO - Step 41450 loss: 0.00091580\n",
      "21120 - INFO - Step 41500 loss: 0.00115113\n",
      "21120 - INFO - Step 41550 loss: 0.00092233\n",
      "21120 - INFO - Step 41600 loss: 0.00124839\n",
      "21120 - INFO - Step 41650 loss: 0.00101659\n",
      "21120 - INFO - Epoch [96/100], Train Loss: 0.00105327, Test Loss: 0.00110270\n",
      "\n",
      "21120 - INFO - Step 41700 loss: 0.00104755\n",
      "21120 - INFO - Step 41750 loss: 0.00101940\n",
      "21120 - INFO - Step 41800 loss: 0.00097370\n",
      "21120 - INFO - Step 41850 loss: 0.00092879\n",
      "21120 - INFO - Step 41900 loss: 0.00109236\n",
      "21120 - INFO - Step 41950 loss: 0.00110401\n",
      "21120 - INFO - Step 42000 loss: 0.00104755\n",
      "21120 - INFO - Step 42050 loss: 0.00100317\n",
      "21120 - INFO - Epoch [97/100], Train Loss: 0.00105345, Test Loss: 0.00105150\n",
      "\n",
      "21120 - INFO - Step 42100 loss: 0.00097672\n",
      "21120 - INFO - Step 42150 loss: 0.00112714\n",
      "21120 - INFO - Step 42200 loss: 0.00105184\n",
      "21120 - INFO - Step 42250 loss: 0.00101796\n",
      "21120 - INFO - Step 42300 loss: 0.00089879\n",
      "21120 - INFO - Step 42350 loss: 0.00120652\n",
      "21120 - INFO - Step 42400 loss: 0.00095526\n",
      "21120 - INFO - Step 42450 loss: 0.00110133\n",
      "21120 - INFO - Step 42500 loss: 0.00101061\n",
      "21120 - INFO - Epoch [98/100], Train Loss: 0.00105341, Test Loss: 0.00107218\n",
      "\n",
      "21120 - INFO - Step 42550 loss: 0.00097124\n",
      "21120 - INFO - Step 42600 loss: 0.00110082\n",
      "21120 - INFO - Step 42650 loss: 0.00111083\n",
      "21120 - INFO - Step 42700 loss: 0.00092138\n",
      "21120 - INFO - Step 42750 loss: 0.00113865\n",
      "21120 - INFO - Step 42800 loss: 0.00104415\n",
      "21120 - INFO - Step 42850 loss: 0.00107182\n",
      "21120 - INFO - Step 42900 loss: 0.00101607\n",
      "21120 - INFO - Step 42950 loss: 0.00121793\n",
      "21120 - INFO - Epoch [99/100], Train Loss: 0.00105574, Test Loss: 0.00108289\n",
      "\n",
      "21120 - INFO - Step 43000 loss: 0.00120746\n",
      "21120 - INFO - Step 43050 loss: 0.00101814\n",
      "21120 - INFO - Step 43100 loss: 0.00119656\n",
      "21120 - INFO - Step 43150 loss: 0.00106029\n",
      "21120 - INFO - Step 43200 loss: 0.00094479\n",
      "21120 - INFO - Step 43250 loss: 0.00123867\n",
      "21120 - INFO - Step 43300 loss: 0.00095733\n",
      "21120 - INFO - Step 43350 loss: 0.00098159\n",
      "21120 - INFO - Step 43400 loss: 0.00078672\n",
      "21120 - INFO - Epoch [100/100], Train Loss: 0.00105181, Test Loss: 0.00109009\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Trainer definition\n",
    "from models import ConvAETrainer\n",
    "from benchmarking.utils import Experiment\n",
    "\n",
    "experiment = Experiment({}, f\"{model_name} Example\", '1.0', model, dataset_name)\n",
    "trainer = ConvAETrainer(model=model)\n",
    "trainer.train(\n",
    "    train_loader=train_loader, \n",
    "    test_loader=test_loader, \n",
    "    epochs=100, \n",
    "    lr=model_configs['ConvAE']['lr'], \n",
    "    experiment=experiment\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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j8FgwODBg1FQUOBfJ8syCgoKkJGR0eRnMjIyAtoDQH5+fkD7xsDz/fff49NPP0VMTMxF+6ipqUFRUZF/3WeffQZZlpGenu5vs3XrVrjd7oDj9O7dG126dAnmNNsdZ28REdGlSJLU4rJgwYLL2veGDRta3YdvvvkmYL3T6URMTAwkScIXX3zhX//ll1/i5ptvRnR0NEJDQ5GamopJkyb53/L+xRdfNHs+zQ096UhB397KycnB22+/jXfffRcHDhzAb37zGzgcDv/7MyZOnIhZs2b520+fPh1btmzBkiVLcPDgQSxYsAC7du3C448/DsAXeO69917s2rUL7733HrxeL6xWK6xWq/+iXXvttRgzZgweffRR7NixA19//TUef/xxPPDAA0hISADge+urwWDAlClTsG/fPqxbtw5//OMfkZOTc9kX6XLxOT1ERHQp5eXl/mXp0qUwm80B655++mlF+pGUlIRVq1YFrPvggw8QHh4esG7//v0YM2YMhgwZgq1bt+K7777DG2+8AYPBAK/XG9D20KFDAedSXl5+0VhdRbRl2tgbb7whevToIQwGgxg2bJj45ptv/NtGjRolJk2aFND+/fffF9dcc40wGAyib9++4qOPPvJvKykpEQCaXD7//HN/u1OnTonx48eL8PBwYTabxeTJk0VtbW3Acf7973+LkSNHCqPRKBITE8XLL78c1Hl11JT14tIzoufMTeKGlwvadb9ERNS0n/qU9VWrVonIyMiAdW+//bZIS0sTRqNR9O7dWyxbtsy/zel0imnTpgmLxSKMRqPo0aOHeOmll4QQQvTs2TPgu7Vnz57NHheAmDNnjjCbzaKurs6//tZbbxVz584N+G7+wx/+IJKTk1s8j88//1wAEGfOnAnq/JvSHlPW2/SW9ccff9xfqflvF5a9Gt1333247777mmyfnJwM0Yp3nkZHR2PNmjUttrnuuuvwr3/965L7UhrH9BARqUwIwF2nzrH1oYAkXdYu3nvvPcybNw9vvvkmBg0ahOLiYjz66KMICwvDpEmT8Prrr2Pjxo14//330aNHDxw/ftw/OWfnzp3o1q0bVq1ahTFjxkCr1bZ4rMGDByM5ORn/93//h4ceegilpaXYunUrli1bhoULF/rbWSwWlJeXY+vWrbjxxhsv6/yU0qbQQ8Hhu7eIiFTmrgNeSlDn2LPLAEPYZe1i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ckyaNEnl3l1Z3n//fbz33ntYs2YN+vbtiz179uCpp55CQkICr/UVjLe3OlBsbCy0Wu1Fs1gqKipgsVhU6tWV5fHHH8emTZvw+eefo3v37v71FosFLpcLNTU1Ae157YNXVFSEyspKXH/99dDpdNDpdPjyyy/x+uuvQ6fTIS4ujte6ncTHx6NPnz4B66699lqUlpYCgP968r8pl++ZZ57Bc889hwceeAD9+/fHww8/jBkzZiA3NxcAr3VHac11tVgsF0328Xg8OH369GVfe4aeDmQwGDB48GAUFBT418myjIKCAmRkZKjYs58+IQQef/xxfPDBB/jss8+QkpISsH3w4MHQ6/UB1/7QoUMoLS3ltQ/SLbfcgu+++w579uzxL0OGDMGECRP8f+a1bh833HDDRY9e+M9//oOePXsCAFJSUmCxWAKutd1ux/bt23mtg1RXVweNJvArUKvVQpZlALzWHaU11zUjIwM1NTUoKiryt/nss88gyzLS09MvrwOXNQyaLmnt2rXCaDSK1atXi/3794upU6eKqKgoYbVa1e7aT9pvfvMbERkZKb744gtRXl7uX+rq6vxtfv3rX4sePXqIzz77TOzatUtkZGSIjIwMFXt95bhw9pYQvNbtZceOHUKn04nf//734vvvvxfvvfeeCA0NFX/729/8bV5++WURFRUl/t//+3/i22+/FXfddZdISUkR9fX1Kvb8p2fSpEkiMTFRbNq0SZSUlIj169eL2NhY8eyzz/rb8Fq3TW1trSguLhbFxcUCgHjttddEcXGxOHbsmBCiddd1zJgxYtCgQWL79u3iq6++EqmpqWL8+PGX3TeGHgW88cYbokePHsJgMIhhw4aJb775Ru0u/eQBaHJZtWqVv019fb347W9/K7p06SJCQ0PF3XffLcrLy9Xr9BXkv0MPr3X7+fDDD0W/fv2E0WgUaWlpYsWKFQHbZVkWc+fOFXFxccJoNIpbbrlFHDp0SKXe/nTZ7XYxffp00aNHD2EymcRVV10l/vd//1c4nU5/G17rtvn888+b/O/zpEmThBCtu66nTp0S48ePF+Hh4cJsNovJkyeL2tray+6bJMQFj58kIiIiukJxTA8RERF1Cgw9RERE1Ckw9BAREVGnwNBDREREnQJDDxEREXUKDD1ERETUKTD0EBERUafA0ENERESdAkMPERERdQoMPURERNQpMPQQERFRp8DQQ0RERJ3C/w8GMJA4fvdjAwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(experiment.train_loss_mse[-100:], label=\"Train MSE\")\n",
    "plt.plot(experiment.test_loss_mse[-100:], label=\"Test MSE\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# TransformerAE\n",
    "A Transformer based AE."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "16\n",
      "TransformerAE(\n",
      "  (encoder): Sequential(\n",
      "    (0): TransformerEncoderLayer(\n",
      "      (self_attn): MultiheadAttention(\n",
      "        (out_proj): NonDynamicallyQuantizableLinear(in_features=1, out_features=1, bias=True)\n",
      "      )\n",
      "      (linear1): Linear(in_features=1, out_features=512, bias=True)\n",
      "      (dropout): Dropout(p=0.1, inplace=False)\n",
      "      (linear2): Linear(in_features=512, out_features=1, bias=True)\n",
      "      (norm1): LayerNorm((1,), eps=1e-05, elementwise_affine=True)\n",
      "      (norm2): LayerNorm((1,), eps=1e-05, elementwise_affine=True)\n",
      "      (dropout1): Dropout(p=0.1, inplace=False)\n",
      "      (dropout2): Dropout(p=0.1, inplace=False)\n",
      "    )\n",
      "    (1): Flatten(start_dim=1, end_dim=-1)\n",
      "    (2): Linear(in_features=31, out_features=256, bias=True)\n",
      "    (3): Tanh()\n",
      "  )\n",
      "  (decoder): Sequential(\n",
      "    (0): Unflatten(dim=1, unflattened_size=(256, 1))\n",
      "    (1): TransformerEncoderLayer(\n",
      "      (self_attn): MultiheadAttention(\n",
      "        (out_proj): NonDynamicallyQuantizableLinear(in_features=1, out_features=1, bias=True)\n",
      "      )\n",
      "      (linear1): Linear(in_features=1, out_features=512, bias=True)\n",
      "      (dropout): Dropout(p=0.1, inplace=False)\n",
      "      (linear2): Linear(in_features=512, out_features=1, bias=True)\n",
      "      (norm1): LayerNorm((1,), eps=1e-05, elementwise_affine=True)\n",
      "      (norm2): LayerNorm((1,), eps=1e-05, elementwise_affine=True)\n",
      "      (dropout1): Dropout(p=0.1, inplace=False)\n",
      "      (dropout2): Dropout(p=0.1, inplace=False)\n",
      "    )\n",
      "    (2): Flatten(start_dim=1, end_dim=-1)\n",
      "    (3): Linear(in_features=256, out_features=31, bias=True)\n",
      "    (4): Tanh()\n",
      "  )\n",
      ")\n"
     ]
    }
   ],
   "source": [
    "# Model init\n",
    "from models import TransformerAE\n",
    "\n",
    "hidden_dim = round(input_dim * dim_reduction)\n",
    "print(hidden_dim)\n",
    "model = TransformerAE(\n",
    "    input_dim=input_dim, \n",
    "    hidden_spec=model_configs['TransformerAE']['hidden_spec']\n",
    ")\n",
    "model_name = model.__class__.__name__\n",
    "print(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "21120 - INFO - Step 10 loss: 0.00534\n",
      "21120 - INFO - Step 20 loss: 0.00466\n",
      "21120 - INFO - Step 30 loss: 0.00546\n",
      "21120 - INFO - Step 40 loss: 0.00521\n",
      "21120 - INFO - Step 50 loss: 0.00588\n",
      "21120 - INFO - Step 60 loss: 0.00538\n",
      "21120 - INFO - Step 70 loss: 0.00569\n",
      "21120 - INFO - Step 80 loss: 0.00557\n",
      "21120 - INFO - Step 90 loss: 0.00515\n",
      "21120 - INFO - Step 100 loss: 0.00519\n",
      "21120 - INFO - Step 110 loss: 0.00494\n",
      "21120 - INFO - Step 120 loss: 0.00547\n",
      "21120 - INFO - Step 130 loss: 0.00461\n",
      "21120 - INFO - Step 140 loss: 0.00527\n",
      "21120 - INFO - Step 150 loss: 0.00606\n",
      "21120 - INFO - Step 160 loss: 0.00560\n",
      "21120 - INFO - Step 170 loss: 0.00524\n",
      "21120 - INFO - Step 180 loss: 0.00522\n",
      "21120 - INFO - Step 190 loss: 0.00529\n",
      "21120 - INFO - Step 200 loss: 0.00477\n",
      "21120 - INFO - Step 210 loss: 0.00553\n",
      "21120 - INFO - Step 220 loss: 0.00534\n",
      "21120 - INFO - Step 230 loss: 0.00608\n",
      "21120 - INFO - Step 240 loss: 0.00500\n",
      "21120 - INFO - Step 250 loss: 0.00509\n",
      "21120 - INFO - Step 260 loss: 0.00513\n",
      "21120 - INFO - Step 270 loss: 0.00563\n",
      "21120 - INFO - Step 280 loss: 0.00558\n",
      "21120 - INFO - Step 290 loss: 0.00604\n",
      "21120 - INFO - Step 300 loss: 0.00558\n",
      "21120 - INFO - Step 310 loss: 0.00573\n",
      "21120 - INFO - Step 320 loss: 0.00547\n",
      "21120 - INFO - Step 330 loss: 0.00536\n",
      "21120 - INFO - Step 340 loss: 0.00581\n",
      "21120 - INFO - Step 350 loss: 0.00515\n",
      "21120 - INFO - Step 360 loss: 0.00563\n",
      "21120 - INFO - Step 370 loss: 0.00459\n",
      "21120 - INFO - Step 380 loss: 0.00558\n",
      "21120 - INFO - Step 390 loss: 0.00494\n",
      "21120 - INFO - Step 400 loss: 0.00528\n",
      "21120 - INFO - Step 410 loss: 0.00546\n",
      "21120 - INFO - Step 420 loss: 0.00537\n",
      "21120 - INFO - Step 430 loss: 0.00485\n",
      "21120 - INFO - Step 440 loss: 0.00530\n",
      "21120 - INFO - Step 450 loss: 0.00520\n",
      "21120 - INFO - Step 460 loss: 0.00509\n",
      "21120 - INFO - Step 470 loss: 0.00545\n",
      "21120 - INFO - Step 480 loss: 0.00535\n",
      "21120 - INFO - Step 490 loss: 0.00569\n",
      "21120 - INFO - Step 500 loss: 0.00548\n",
      "21120 - INFO - Step 510 loss: 0.00557\n",
      "21120 - INFO - Step 520 loss: 0.00539\n",
      "21120 - INFO - Step 530 loss: 0.00579\n",
      "21120 - INFO - Step 540 loss: 0.00605\n",
      "21120 - INFO - Step 550 loss: 0.00539\n",
      "21120 - INFO - Step 560 loss: 0.00529\n",
      "21120 - INFO - Step 570 loss: 0.00504\n",
      "21120 - INFO - Step 580 loss: 0.00539\n",
      "21120 - INFO - Step 590 loss: 0.00556\n",
      "21120 - INFO - Step 600 loss: 0.00571\n",
      "21120 - INFO - Step 610 loss: 0.00532\n",
      "21120 - INFO - Step 620 loss: 0.00574\n",
      "21120 - INFO - Step 630 loss: 0.00562\n",
      "21120 - INFO - Step 640 loss: 0.00504\n",
      "21120 - INFO - Step 650 loss: 0.00501\n",
      "21120 - INFO - Step 660 loss: 0.00521\n",
      "21120 - INFO - Step 670 loss: 0.00518\n",
      "21120 - INFO - Step 680 loss: 0.00477\n",
      "21120 - INFO - Step 690 loss: 0.00578\n",
      "21120 - INFO - Step 700 loss: 0.00595\n",
      "21120 - INFO - Step 710 loss: 0.00554\n",
      "21120 - INFO - Step 720 loss: 0.00600\n",
      "21120 - INFO - Step 730 loss: 0.00598\n",
      "21120 - INFO - Step 740 loss: 0.00549\n",
      "21120 - INFO - Step 750 loss: 0.00544\n",
      "21120 - INFO - Step 760 loss: 0.00517\n",
      "21120 - INFO - Step 770 loss: 0.00529\n",
      "21120 - INFO - Step 780 loss: 0.00624\n",
      "21120 - INFO - Step 790 loss: 0.00595\n",
      "21120 - INFO - Step 800 loss: 0.00498\n",
      "21120 - INFO - Step 810 loss: 0.00642\n",
      "21120 - INFO - Step 820 loss: 0.00578\n",
      "21120 - INFO - Step 830 loss: 0.00553\n",
      "21120 - INFO - Step 840 loss: 0.00601\n",
      "21120 - INFO - Step 850 loss: 0.00575\n",
      "21120 - INFO - Step 860 loss: 0.00539\n",
      "21120 - INFO - Step 870 loss: 0.00561\n",
      "21120 - INFO - Step 880 loss: 0.00578\n",
      "21120 - INFO - Step 890 loss: 0.00543\n",
      "21120 - INFO - Step 900 loss: 0.00554\n",
      "21120 - INFO - Step 910 loss: 0.00614\n",
      "21120 - INFO - Step 920 loss: 0.00487\n",
      "21120 - INFO - Step 930 loss: 0.00609\n",
      "21120 - INFO - Step 940 loss: 0.00558\n",
      "21120 - INFO - Step 950 loss: 0.00564\n",
      "21120 - INFO - Step 960 loss: 0.00533\n",
      "21120 - INFO - Step 970 loss: 0.00508\n",
      "21120 - INFO - Step 980 loss: 0.00528\n",
      "21120 - INFO - Step 990 loss: 0.00495\n",
      "21120 - INFO - Step 1000 loss: 0.00500\n",
      "21120 - INFO - Step 1010 loss: 0.00547\n",
      "21120 - INFO - Step 1020 loss: 0.00566\n",
      "21120 - INFO - Step 1030 loss: 0.00518\n",
      "21120 - INFO - Step 1040 loss: 0.00604\n",
      "21120 - INFO - Step 1050 loss: 0.00559\n",
      "21120 - INFO - Step 1060 loss: 0.00543\n",
      "21120 - INFO - Step 1070 loss: 0.00479\n",
      "21120 - INFO - Step 1080 loss: 0.00565\n",
      "21120 - INFO - Step 1090 loss: 0.00527\n",
      "21120 - INFO - Step 1100 loss: 0.00545\n",
      "21120 - INFO - Step 1110 loss: 0.00584\n",
      "21120 - INFO - Step 1120 loss: 0.00503\n",
      "21120 - INFO - Step 1130 loss: 0.00483\n",
      "21120 - INFO - Step 1140 loss: 0.00535\n",
      "21120 - INFO - Step 1150 loss: 0.00525\n",
      "21120 - INFO - Step 1160 loss: 0.00536\n",
      "21120 - INFO - Step 1170 loss: 0.00567\n",
      "21120 - INFO - Step 1180 loss: 0.00561\n",
      "21120 - INFO - Step 1190 loss: 0.00535\n",
      "21120 - INFO - Step 1200 loss: 0.00517\n",
      "21120 - INFO - Step 1210 loss: 0.00527\n",
      "21120 - INFO - Step 1220 loss: 0.00506\n",
      "21120 - INFO - Step 1230 loss: 0.00589\n",
      "21120 - INFO - Step 1240 loss: 0.00581\n",
      "21120 - INFO - Step 1250 loss: 0.00508\n",
      "21120 - INFO - Step 1260 loss: 0.00508\n",
      "21120 - INFO - Step 1270 loss: 0.00557\n",
      "21120 - INFO - Step 1280 loss: 0.00664\n",
      "21120 - INFO - Step 1290 loss: 0.00604\n",
      "21120 - INFO - Step 1300 loss: 0.00549\n",
      "21120 - INFO - Step 1310 loss: 0.00492\n",
      "21120 - INFO - Step 1320 loss: 0.00535\n",
      "21120 - INFO - Step 1330 loss: 0.00576\n",
      "21120 - INFO - Step 1340 loss: 0.00563\n",
      "21120 - INFO - Step 1350 loss: 0.00540\n",
      "21120 - INFO - Step 1360 loss: 0.00480\n",
      "21120 - INFO - Step 1370 loss: 0.00583\n",
      "21120 - INFO - Step 1380 loss: 0.00518\n",
      "21120 - INFO - Step 1390 loss: 0.00474\n",
      "21120 - INFO - Step 1400 loss: 0.00557\n",
      "21120 - INFO - Step 1410 loss: 0.00463\n",
      "21120 - INFO - Step 1420 loss: 0.00546\n",
      "21120 - INFO - Step 1430 loss: 0.00530\n",
      "21120 - INFO - Step 1440 loss: 0.00553\n",
      "21120 - INFO - Step 1450 loss: 0.00563\n",
      "21120 - INFO - Step 1460 loss: 0.00543\n",
      "21120 - INFO - Step 1470 loss: 0.00515\n",
      "21120 - INFO - Step 1480 loss: 0.00559\n",
      "21120 - INFO - Step 1490 loss: 0.00508\n",
      "21120 - INFO - Step 1500 loss: 0.00548\n",
      "21120 - INFO - Step 1510 loss: 0.00498\n",
      "21120 - INFO - Step 1520 loss: 0.00558\n",
      "21120 - INFO - Step 1530 loss: 0.00555\n",
      "21120 - INFO - Step 1540 loss: 0.00509\n",
      "21120 - INFO - Step 1550 loss: 0.00515\n",
      "21120 - INFO - Step 1560 loss: 0.00568\n",
      "21120 - INFO - Step 1570 loss: 0.00580\n",
      "21120 - INFO - Step 1580 loss: 0.00565\n",
      "21120 - INFO - Step 1590 loss: 0.00589\n",
      "21120 - INFO - Step 1600 loss: 0.00532\n",
      "21120 - INFO - Step 1610 loss: 0.00476\n",
      "21120 - INFO - Step 1620 loss: 0.00541\n",
      "21120 - INFO - Step 1630 loss: 0.00560\n",
      "21120 - INFO - Step 1640 loss: 0.00569\n",
      "21120 - INFO - Step 1650 loss: 0.00521\n",
      "21120 - INFO - Step 1660 loss: 0.00508\n",
      "21120 - INFO - Step 1670 loss: 0.00564\n",
      "21120 - INFO - Step 1680 loss: 0.00583\n",
      "21120 - INFO - Step 1690 loss: 0.00545\n",
      "21120 - INFO - Step 1700 loss: 0.00482\n",
      "21120 - INFO - Step 1710 loss: 0.00625\n",
      "21120 - INFO - Step 1720 loss: 0.00528\n",
      "21120 - INFO - Step 1730 loss: 0.00498\n",
      "21120 - INFO - Step 1740 loss: 0.00523\n",
      "21120 - INFO - Step 1750 loss: 0.00530\n",
      "21120 - INFO - Step 1760 loss: 0.00605\n",
      "21120 - INFO - Step 1770 loss: 0.00534\n",
      "21120 - INFO - Step 1780 loss: 0.00594\n",
      "21120 - INFO - Step 1790 loss: 0.00624\n",
      "21120 - INFO - Step 1800 loss: 0.00478\n",
      "21120 - INFO - Step 1810 loss: 0.00589\n",
      "21120 - INFO - Step 1820 loss: 0.00520\n",
      "21120 - INFO - Step 1830 loss: 0.00511\n",
      "21120 - INFO - Step 1840 loss: 0.00569\n",
      "21120 - INFO - Step 1850 loss: 0.00514\n",
      "21120 - INFO - Step 1860 loss: 0.00474\n",
      "21120 - INFO - Step 1870 loss: 0.00548\n",
      "21120 - INFO - Step 1880 loss: 0.00501\n",
      "21120 - INFO - Step 1890 loss: 0.00578\n",
      "21120 - INFO - Step 1900 loss: 0.00584\n",
      "21120 - INFO - Step 1910 loss: 0.00516\n",
      "21120 - INFO - Step 1920 loss: 0.00540\n",
      "21120 - INFO - Step 1930 loss: 0.00521\n",
      "21120 - INFO - Step 1940 loss: 0.00562\n",
      "21120 - INFO - Step 1950 loss: 0.00487\n",
      "21120 - INFO - Step 1960 loss: 0.00544\n",
      "21120 - INFO - Step 1970 loss: 0.00568\n",
      "21120 - INFO - Step 1980 loss: 0.00565\n",
      "21120 - INFO - Step 1990 loss: 0.00581\n",
      "21120 - INFO - Step 2000 loss: 0.00563\n",
      "21120 - INFO - Step 2010 loss: 0.00580\n",
      "21120 - INFO - Step 2020 loss: 0.00543\n",
      "21120 - INFO - Step 2030 loss: 0.00571\n",
      "21120 - INFO - Step 2040 loss: 0.00534\n",
      "21120 - INFO - Step 2050 loss: 0.00520\n",
      "21120 - INFO - Step 2060 loss: 0.00573\n",
      "21120 - INFO - Step 2070 loss: 0.00575\n",
      "21120 - INFO - Step 2080 loss: 0.00534\n",
      "21120 - INFO - Step 2090 loss: 0.00480\n",
      "21120 - INFO - Step 2100 loss: 0.00532\n",
      "21120 - INFO - Step 2110 loss: 0.00545\n",
      "21120 - INFO - Step 2120 loss: 0.00542\n",
      "21120 - INFO - Step 2130 loss: 0.00527\n",
      "21120 - INFO - Step 2140 loss: 0.00522\n",
      "21120 - INFO - Step 2150 loss: 0.00568\n",
      "21120 - INFO - Step 2160 loss: 0.00499\n",
      "21120 - INFO - Step 2170 loss: 0.00456\n",
      "21120 - INFO - Step 2180 loss: 0.00538\n",
      "21120 - INFO - Step 2190 loss: 0.00530\n",
      "21120 - INFO - Step 2200 loss: 0.00508\n",
      "21120 - INFO - Step 2210 loss: 0.00524\n",
      "21120 - INFO - Step 2220 loss: 0.00550\n",
      "21120 - INFO - Step 2230 loss: 0.00599\n",
      "21120 - INFO - Step 2240 loss: 0.00530\n",
      "21120 - INFO - Step 2250 loss: 0.00563\n",
      "21120 - INFO - Step 2260 loss: 0.00487\n",
      "21120 - INFO - Step 2270 loss: 0.00500\n",
      "21120 - INFO - Step 2280 loss: 0.00585\n",
      "21120 - INFO - Step 2290 loss: 0.00515\n",
      "21120 - INFO - Step 2300 loss: 0.00577\n",
      "21120 - INFO - Step 2310 loss: 0.00619\n",
      "21120 - INFO - Step 2320 loss: 0.00596\n",
      "21120 - INFO - Step 2330 loss: 0.00547\n",
      "21120 - INFO - Step 2340 loss: 0.00510\n",
      "21120 - INFO - Step 2350 loss: 0.00496\n",
      "21120 - INFO - Step 2360 loss: 0.00531\n",
      "21120 - INFO - Step 2370 loss: 0.00626\n",
      "21120 - INFO - Step 2380 loss: 0.00492\n",
      "21120 - INFO - Step 2390 loss: 0.00587\n",
      "21120 - INFO - Step 2400 loss: 0.00534\n",
      "21120 - INFO - Step 2410 loss: 0.00546\n",
      "21120 - INFO - Step 2420 loss: 0.00576\n",
      "21120 - INFO - Step 2430 loss: 0.00527\n",
      "21120 - INFO - Step 2440 loss: 0.00593\n",
      "21120 - INFO - Step 2450 loss: 0.00619\n",
      "21120 - INFO - Step 2460 loss: 0.00550\n",
      "21120 - INFO - Step 2470 loss: 0.00504\n",
      "21120 - INFO - Step 2480 loss: 0.00490\n",
      "21120 - INFO - Step 2490 loss: 0.00521\n",
      "21120 - INFO - Step 2500 loss: 0.00523\n",
      "21120 - INFO - Step 2510 loss: 0.00459\n",
      "21120 - INFO - Step 2520 loss: 0.00589\n",
      "21120 - INFO - Step 2530 loss: 0.00580\n",
      "21120 - INFO - Step 2540 loss: 0.00564\n",
      "21120 - INFO - Step 2550 loss: 0.00513\n",
      "21120 - INFO - Step 2560 loss: 0.00496\n",
      "21120 - INFO - Step 2570 loss: 0.00537\n",
      "21120 - INFO - Step 2580 loss: 0.00511\n",
      "21120 - INFO - Step 2590 loss: 0.00623\n",
      "21120 - INFO - Step 2600 loss: 0.00581\n",
      "21120 - INFO - Step 2610 loss: 0.00568\n",
      "21120 - INFO - Step 2620 loss: 0.00531\n",
      "21120 - INFO - Step 2630 loss: 0.00528\n",
      "21120 - INFO - Step 2640 loss: 0.00509\n",
      "21120 - INFO - Step 2650 loss: 0.00499\n",
      "21120 - INFO - Step 2660 loss: 0.00600\n",
      "21120 - INFO - Step 2670 loss: 0.00475\n",
      "21120 - INFO - Step 2680 loss: 0.00563\n",
      "21120 - INFO - Step 2690 loss: 0.00533\n",
      "21120 - INFO - Step 2700 loss: 0.00530\n",
      "21120 - INFO - Step 2710 loss: 0.00582\n",
      "21120 - INFO - Step 2720 loss: 0.00521\n",
      "21120 - INFO - Step 2730 loss: 0.00563\n",
      "21120 - INFO - Step 2740 loss: 0.00542\n",
      "21120 - INFO - Step 2750 loss: 0.00507\n",
      "21120 - INFO - Step 2760 loss: 0.00547\n",
      "21120 - INFO - Step 2770 loss: 0.00591\n",
      "21120 - INFO - Step 2780 loss: 0.00505\n",
      "21120 - INFO - Step 2790 loss: 0.00545\n",
      "21120 - INFO - Step 2800 loss: 0.00577\n",
      "21120 - INFO - Step 2810 loss: 0.00551\n",
      "21120 - INFO - Step 2820 loss: 0.00620\n",
      "21120 - INFO - Step 2830 loss: 0.00505\n",
      "21120 - INFO - Step 2840 loss: 0.00587\n",
      "21120 - INFO - Step 2850 loss: 0.00554\n",
      "21120 - INFO - Step 2860 loss: 0.00637\n",
      "21120 - INFO - Step 2870 loss: 0.00540\n",
      "21120 - INFO - Step 2880 loss: 0.00531\n",
      "21120 - INFO - Step 2890 loss: 0.00546\n",
      "21120 - INFO - Step 2900 loss: 0.00605\n",
      "21120 - INFO - Step 2910 loss: 0.00550\n",
      "21120 - INFO - Step 2920 loss: 0.00554\n",
      "21120 - INFO - Step 2930 loss: 0.00549\n",
      "21120 - INFO - Step 2940 loss: 0.00599\n",
      "21120 - INFO - Step 2950 loss: 0.00576\n",
      "21120 - INFO - Step 2960 loss: 0.00504\n",
      "21120 - INFO - Step 2970 loss: 0.00544\n",
      "21120 - INFO - Step 2980 loss: 0.00512\n",
      "21120 - INFO - Step 2990 loss: 0.00521\n",
      "21120 - INFO - Step 3000 loss: 0.00623\n",
      "21120 - INFO - Step 3010 loss: 0.00564\n",
      "21120 - INFO - Step 3020 loss: 0.00577\n",
      "21120 - INFO - Step 3030 loss: 0.00575\n",
      "21120 - INFO - Step 3040 loss: 0.00545\n",
      "21120 - INFO - Step 3050 loss: 0.00520\n",
      "21120 - INFO - Step 3060 loss: 0.00573\n",
      "21120 - INFO - Step 3070 loss: 0.00534\n",
      "21120 - INFO - Step 3080 loss: 0.00523\n",
      "21120 - INFO - Step 3090 loss: 0.00555\n",
      "21120 - INFO - Step 3100 loss: 0.00552\n",
      "21120 - INFO - Step 3110 loss: 0.00571\n",
      "21120 - INFO - Step 3120 loss: 0.00541\n",
      "21120 - INFO - Step 3130 loss: 0.00520\n",
      "21120 - INFO - Step 3140 loss: 0.00604\n",
      "21120 - INFO - Step 3150 loss: 0.00555\n",
      "21120 - INFO - Step 3160 loss: 0.00547\n",
      "21120 - INFO - Step 3170 loss: 0.00552\n",
      "21120 - INFO - Step 3180 loss: 0.00493\n",
      "21120 - INFO - Step 3190 loss: 0.00546\n",
      "21120 - INFO - Step 3200 loss: 0.00555\n",
      "21120 - INFO - Step 3210 loss: 0.00607\n",
      "21120 - INFO - Step 3220 loss: 0.00548\n",
      "21120 - INFO - Step 3230 loss: 0.00540\n",
      "21120 - INFO - Step 3240 loss: 0.00531\n",
      "21120 - INFO - Step 3250 loss: 0.00497\n",
      "21120 - INFO - Step 3260 loss: 0.00566\n",
      "21120 - INFO - Step 3270 loss: 0.00496\n",
      "21120 - INFO - Step 3280 loss: 0.00505\n",
      "21120 - INFO - Step 3290 loss: 0.00549\n",
      "21120 - INFO - Step 3300 loss: 0.00569\n",
      "21120 - INFO - Step 3310 loss: 0.00569\n",
      "21120 - INFO - Step 3320 loss: 0.00601\n",
      "21120 - INFO - Step 3330 loss: 0.00489\n",
      "21120 - INFO - Step 3340 loss: 0.00528\n",
      "21120 - INFO - Step 3350 loss: 0.00483\n",
      "21120 - INFO - Step 3360 loss: 0.00515\n",
      "21120 - INFO - Step 3370 loss: 0.00549\n",
      "21120 - INFO - Step 3380 loss: 0.00567\n",
      "21120 - INFO - Step 3390 loss: 0.00509\n",
      "21120 - INFO - Step 3400 loss: 0.00590\n",
      "21120 - INFO - Step 3410 loss: 0.00588\n",
      "21120 - INFO - Step 3420 loss: 0.00578\n",
      "21120 - INFO - Step 3430 loss: 0.00486\n",
      "21120 - INFO - Step 3440 loss: 0.00543\n",
      "21120 - INFO - Step 3450 loss: 0.00508\n",
      "21120 - INFO - Step 3460 loss: 0.00605\n",
      "21120 - INFO - Step 3470 loss: 0.00553\n",
      "21120 - INFO - Step 3480 loss: 0.00543\n",
      "21120 - INFO - Step 3490 loss: 0.00547\n",
      "21120 - INFO - Step 3500 loss: 0.00549\n",
      "21120 - INFO - Step 3510 loss: 0.00530\n",
      "21120 - INFO - Step 3520 loss: 0.00551\n",
      "21120 - INFO - Step 3530 loss: 0.00534\n",
      "21120 - INFO - Step 3540 loss: 0.00552\n",
      "21120 - INFO - Step 3550 loss: 0.00524\n",
      "21120 - INFO - Step 3560 loss: 0.00572\n",
      "21120 - INFO - Step 3570 loss: 0.00589\n",
      "21120 - INFO - Step 3580 loss: 0.00535\n",
      "21120 - INFO - Step 3590 loss: 0.00517\n",
      "21120 - INFO - Step 3600 loss: 0.00585\n",
      "21120 - INFO - Step 3610 loss: 0.00497\n",
      "21120 - INFO - Step 3620 loss: 0.00520\n",
      "21120 - INFO - Step 3630 loss: 0.00604\n",
      "21120 - INFO - Step 3640 loss: 0.00547\n",
      "21120 - INFO - Step 3650 loss: 0.00551\n",
      "21120 - INFO - Step 3660 loss: 0.00562\n",
      "21120 - INFO - Step 3670 loss: 0.00571\n",
      "21120 - INFO - Step 3680 loss: 0.00539\n",
      "21120 - INFO - Step 3690 loss: 0.00533\n",
      "21120 - INFO - Step 3700 loss: 0.00518\n",
      "21120 - INFO - Step 3710 loss: 0.00542\n",
      "21120 - INFO - Step 3720 loss: 0.00487\n",
      "21120 - INFO - Step 3730 loss: 0.00480\n",
      "21120 - INFO - Step 3740 loss: 0.00639\n",
      "21120 - INFO - Step 3750 loss: 0.00455\n",
      "21120 - INFO - Step 3760 loss: 0.00668\n",
      "21120 - INFO - Step 3770 loss: 0.00575\n",
      "21120 - INFO - Step 3780 loss: 0.00591\n",
      "21120 - INFO - Step 3790 loss: 0.00562\n",
      "21120 - INFO - Step 3800 loss: 0.00575\n",
      "21120 - INFO - Step 3810 loss: 0.00560\n",
      "21120 - INFO - Step 3820 loss: 0.00637\n",
      "21120 - INFO - Step 3830 loss: 0.00554\n",
      "21120 - INFO - Step 3840 loss: 0.00573\n",
      "21120 - INFO - Step 3850 loss: 0.00487\n",
      "21120 - INFO - Step 3860 loss: 0.00558\n",
      "21120 - INFO - Step 3870 loss: 0.00529\n",
      "21120 - INFO - Step 3880 loss: 0.00548\n",
      "21120 - INFO - Step 3890 loss: 0.00566\n",
      "21120 - INFO - Step 3900 loss: 0.00626\n",
      "21120 - INFO - Step 3910 loss: 0.00538\n",
      "21120 - INFO - Step 3920 loss: 0.00554\n",
      "21120 - INFO - Step 3930 loss: 0.00521\n",
      "21120 - INFO - Step 3940 loss: 0.00523\n",
      "21120 - INFO - Step 3950 loss: 0.00561\n",
      "21120 - INFO - Step 3960 loss: 0.00571\n",
      "21120 - INFO - Step 3970 loss: 0.00598\n",
      "21120 - INFO - Step 3980 loss: 0.00539\n",
      "21120 - INFO - Step 3990 loss: 0.00551\n",
      "21120 - INFO - Step 4000 loss: 0.00567\n",
      "21120 - INFO - Step 4010 loss: 0.00552\n",
      "21120 - INFO - Step 4020 loss: 0.00571\n",
      "21120 - INFO - Step 4030 loss: 0.00518\n",
      "21120 - INFO - Step 4040 loss: 0.00554\n",
      "21120 - INFO - Step 4050 loss: 0.00578\n",
      "21120 - INFO - Step 4060 loss: 0.00560\n",
      "21120 - INFO - Step 4070 loss: 0.00570\n",
      "21120 - INFO - Step 4080 loss: 0.00524\n",
      "21120 - INFO - Step 4090 loss: 0.00556\n",
      "21120 - INFO - Step 4100 loss: 0.00582\n",
      "21120 - INFO - Step 4110 loss: 0.00581\n",
      "21120 - INFO - Step 4120 loss: 0.00531\n",
      "21120 - INFO - Step 4130 loss: 0.00500\n",
      "21120 - INFO - Step 4140 loss: 0.00473\n",
      "21120 - INFO - Step 4150 loss: 0.00589\n",
      "21120 - INFO - Step 4160 loss: 0.00528\n",
      "21120 - INFO - Step 4170 loss: 0.00451\n",
      "21120 - INFO - Step 4180 loss: 0.00535\n",
      "21120 - INFO - Step 4190 loss: 0.00562\n",
      "21120 - INFO - Step 4200 loss: 0.00544\n",
      "21120 - INFO - Step 4210 loss: 0.00538\n",
      "21120 - INFO - Step 4220 loss: 0.00589\n",
      "21120 - INFO - Step 4230 loss: 0.00579\n",
      "21120 - INFO - Step 4240 loss: 0.00538\n",
      "21120 - INFO - Step 4250 loss: 0.00527\n",
      "21120 - INFO - Step 4260 loss: 0.00459\n",
      "21120 - INFO - Step 4270 loss: 0.00546\n",
      "21120 - INFO - Step 4280 loss: 0.00533\n",
      "21120 - INFO - Step 4290 loss: 0.00574\n",
      "21120 - INFO - Step 4300 loss: 0.00568\n",
      "21120 - INFO - Step 4310 loss: 0.00518\n",
      "21120 - INFO - Step 4320 loss: 0.00553\n",
      "21120 - INFO - Step 4330 loss: 0.00535\n",
      "21120 - INFO - Step 4340 loss: 0.00511\n"
     ]
    }
   ],
   "source": [
    "# Trainer definition\n",
    "from models import TransformerAETrainer\n",
    "from benchmarking.utils import Experiment\n",
    "\n",
    "experiment = Experiment({}, f\"{model_name} Example\", '1.0', model, dataset_name)\n",
    "# NOTE: The capacity values are intuition based defaults and have to be tuned.\n",
    "trainer = TransformerAETrainer(model=model)\n",
    "trainer.train(\n",
    "    train_loader=train_loader, \n",
    "    test_loader=test_loader, \n",
    "    epochs=10, # model_configs[model_name]['epochs'], \n",
    "    lr=model_configs[model_name]['lr'], \n",
    "    experiment=experiment\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkYAAAGdCAYAAAD3zLwdAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy80BEi2AAAACXBIWXMAAA9hAAAPYQGoP6dpAAB6V0lEQVR4nO3deXxU1fn48c9M9n0lmQQCCRAIYV8ksiiiKFREsLVa3BCpy7eu8Ks7oqICRbFURVHrUlspFlspVkQRxAViWIPsOwTIzpJAINvM/P44mUnGJJBJZubO8rxfr3ndw8yde58kwDw55znn6MxmsxkhhBBCCIFe6wCEEEIIIdyFJEZCCCGEEHUkMRJCCCGEqCOJkRBCCCFEHUmMhBBCCCHqSGIkhBBCCFFHEiMhhBBCiDqSGAkhhBBC1PHXOgBPYzKZyM/PJyIiAp1Op3U4QgghhGgBs9nMmTNnSE5ORq9vvl9IEiM75efnk5KSonUYQgghhGiFo0eP0qFDh2Zfl8TIThEREYD6xkZGRmocjRBCCCFaory8nJSUFOvneHMkMbKTZfgsMjJSEiMhhBDCw1ysDEaKr4UQQggh6khiJIQQQghRRxIjIYQQQog6UmMkhBDCZ5nNZmprazEajVqHItrIz88Pf3//Ni+lI4mREEIIn1RdXU1BQQHnzp3TOhThIKGhoSQlJREYGNjqa0hiJIQQwueYTCYOHTqEn58fycnJBAYGyqK9HsxsNlNdXU1JSQmHDh0iPT39gos4XogkRkIIIXxOdXU1JpOJlJQUQkNDtQ5HOEBISAgBAQEcOXKE6upqgoODW3UdKb4WQgjhs1rbqyDckyN+nvI3QgghhBCijiRGQgghhBB1JDESQgghfFxqairz58/XOgy3IImREEII4SF0Ot0FH88991yrrrthwwbuueeeNsV2xRVXoNPpmDNnTqPXxo4d2yi+Q4cOccstt5CcnExwcDAdOnRg/Pjx7N6923pOc1/n4sWL2xTrhcisNCGEEPb7+V8Q1QE6DdU6Ep9SUFBgbX/yySfMmDGDPXv2WJ8LDw+3ts1mM0ajEX//i3/Ut2vXziHxpaSk8OGHH/LEE09Ynzt+/DirVq0iKSnJ+lxNTQ1XX3013bt35z//+Q9JSUkcO3aML7/8ktOnT9tc84MPPmDMmDE2z0VHRzsk3qZIj5EQQgj7FO2A/9wNi26Gmkqto3EYs9nMuepaTR5ms7lFMRoMBusjKioKnU5n/fPu3buJiIjgyy+/ZODAgQQFBfHjjz9y4MABxo8fT2JiIuHh4VxyySV88803Ntf95VCaTqfjr3/9KzfccAOhoaGkp6ezbNmyi8Z33XXXUVpaytq1a63P/e1vf+Oaa64hISHB+tyOHTs4cOAAb775JpdeeimdOnVi2LBhvPjii1x66aU214yOjrb5ug0GQ6un4reE9BgJIYSwz/FN6lhVDgdWQcZYbeNxkPM1RjJnfKXJvXfOHE1ooGM+kp944gleeeUVOnfuTExMDEePHuXaa6/lpZdeIigoiI8++ohx48axZ88eOnbs2Ox1nn/+eebOncvLL7/M66+/zq233sqRI0eIjY1t9j2BgYHceuutfPDBBwwbNgyADz/8kLlz59oMo7Vr1w69Xs+nn37KI488gp+fn0O+dkeQHiMhhBD2Kfi5vr3zv9rFIZo0c+ZMrr76arp06UJsbCx9+/bl3nvvpVevXqSnp/PCCy/QpUuXi/YA3XnnnUycOJGuXbsya9Yszp49y/r16y96/7vuuot//etfVFRU8P3331NWVsZ1111nc0779u157bXXmDFjBjExMVx55ZW88MILHDx4sNH1Jk6cSHh4uM0jLy/Pvm+KHaTHSAghhH0KGyRGe76E2irwD9IuHgcJCfBj58zRmt3bUQYNGmTz57Nnz/Lcc8/xxRdfUFBQQG1tLefPn79octGnTx9rOywsjMjISIqLiy96/759+5Kens6nn37Kt99+y+23395kndP999/PHXfcwZo1a/jpp59YsmQJs2bNYtmyZVx99dXW8/785z8zatQom/cmJydfNI7WksRICCFEy5mMULhNtf1D6obTvoXuYy78Pg+g0+kcNpylpbCwMJs///GPf2TlypW88sordO3alZCQEG688Uaqq6sveJ2AgACbP+t0OkwmU4tiuOuuu1iwYAE7d+68YC9TREQE48aNY9y4cbz44ouMHj2aF1980SYxMhgMdO3atUX3dQQZShNCeIbjm6GyXOsoxIkDUHMOAkKh/63qORlOc2tr167lzjvv5IYbbqB3794YDAYOHz7s1HvecsstbNu2jV69epGZmdmi9+h0OjIyMqioqHBqbBcjiZEQwv1t+hDeHQlfPqZ1JMIyjJbYE3r9RrX3fAG1F+59ENpJT0/nP//5D7m5uWzdupVbbrmlxT0/rRUTE0NBQQGrVq1q8vXc3FzGjx/Pp59+ys6dO9m/fz/vvfce77//PuPHj7c59/Tp0xQWFto8nJk8eX6foRDCu50/Dd88r9oHv9M0FAEUbFVHQx9IyYLwRDhbBIe+g/SrL/xeoYlXX32Vu+66i6FDhxIfH8/jjz9Oebnze18vtNZQhw4dSE1N5fnnn+fw4cPodDrrn6dOnWpz7uTJkxu9f/bs2TZrJTmSztzSxRMEAOXl5URFRVFWVkZkZKTW4Qjh/b56GrLfqP/zH/dBeELz5wvn+mg8HFwD416DgZPgiz/Chneh320wYYHW0bVYZWUlhw4dIi0tzalr4gjXutDPtaWf3zKUJoRwX6X7IWehageEqmPDqeLCtczm+h6jpLoZS5l1wx67/wfGGm3iEsKBJDESQrivr6eDqRbSr6lfRLBgi7Yx+bKyY3D+FOj9IaGuoLbTUAhrB5Wn1XCaEB5OEiMhhHs6sBr2fqk+hK95CZL6quctPRbC9SyF1+0y6tct0vtBj3GqLbPThBeQxEgI4X6MtbDiKdW+5G5o1w2S+qk/50tipBnLMKYlSbXInKCOu/6nfnZCeDBJjIQQ7mfzh1CyC0JiYETdFH1LTUtZHpw7qVloPq3hjLSGOg2D0Dg4fxIO/+D6uIRwIEmMhBDu5fwpWP2Sal/xFITWbVgZHAWxnVW7IFeT0HyeZSgt6ReJkZ+/DKcJryGJkRDCvXz3sup5aJcBg+6yfU3qjLRTcQLKj6t2Yq/Gr1tmp+36XIbThEeTxEgI4T5K98P6t1V79EuqJ6IhSYy0U1j3PY/tDMFNrAGTepka+jxXCnnrXBubEA4kiZEQwn18/XT99Pyuoxq/bi3AznVlVAKaL7y28AuAjOtUe8dSl4QkhDNIYiSEcA/7V8HeFfXT85ti+VA+dUhtFSJcp7nC64ass9M+B5PR6SH5Ip1Od8HHc88916ZrL126tMUx/PTTTzbPV1VVERcXh06nY82aNdbnv/vuO6688kpiY2MJDQ0lPT2dSZMmUV2t9tdbs2ZNs19PYWFhq7+e1pLESAihPWOt2voD6qfnNyU0FqI7qnahrIDtUs0VXjfUeQQER0NFMeRluyQsX1NQUGB9zJ8/n8jISJvn/vjHP7okjpSUFD744AOb5z777DPCw8Ntntu5cydjxoxh0KBBfP/992zbto3XX3+dwMBAjEbb5HnPnj02X0tBQQEJCa7f/kcSIyGE9jZ9UD89/4rHL3yu1Bm5XtVZOHFAtQ3NDKVB3XBa3QrlMjvNKQwGg/URFRWFTqezeW7x4sX06NGD4OBgMjIyePPNN63vra6u5oEHHiApKYng4GA6derE7NmzAUhNTQXghhtusG7oeiGTJk1i8eLFnD9/3vrc+++/z6RJk2zO+/rrrzEYDMydO5devXrRpUsXxowZw7vvvktISIjNuQkJCTZfi8FgQK93fZoiiZEQQlvnT8G3s1R75NMqOboQqTNyvaLtgBkikiG83YXPtQyn7VwGJpOzI3MssxmqK7R5OGA/948//pgZM2bw0ksvsWvXLmbNmsUzzzzD3/72NwBee+01li1bxr/+9S/27NnDxx9/bE2ANmzYAMAHH3xAQUGB9c/NGThwIKmpqfz73/8GIC8vj++//57bb7/d5jyDwUBBQQHff/99m78+V/G/+ClCCOFE382tn54/cPLFz7ckRtJj5Dq/3Dj2QjpfAUFRcLYQjuZApyFODc2has7BrGRt7v1UPgSGtekSzz77LPPmzePXv/41AGlpaezcuZO3336bSZMmkZeXR3p6OsOHD0en09GpUyfre9u1UwlvdHQ0BoOhRfe76667eP/997ntttv48MMPufbaa63Xsfjtb3/LV199xYgRIzAYDFx66aVcddVV3HHHHY12uO/QoYPNnzt16sSOHTvs/j60lfQYCSG0U7oP1r+j2qNnNZ6e3xTLUNqJ/VB1xnmxiXqWGWkXKry28A+EjGtVW4bTXKaiooIDBw4wZcoUwsPDrY8XX3yRAwfUMOidd95Jbm4u3bt356GHHuLrr79u0z1vu+02srOzOXjwIB9++CF33XVXo3P8/Pz44IMPOHbsGHPnzqV9+/bMmjWLnj17UlBQYHPuDz/8QG5urvWxfPnyNsXXWtJjJITQztfT66bnj4auV7XsPeHtILK9WmywcJva3V04V6EdPUagFnvc+k+VGI2eBRrUibRKQKjqudHq3m1w9uxZAN59912ysrJsXvPz8wNgwIABHDp0iC+//JJvvvmGm266iVGjRvHpp5+26p5xcXFcd911TJkyhcrKSn71q19x5kzTv6y0b9+e22+/ndtvv50XXniBbt26sXDhQp5//nnrOWlpaURHR7cqFkeS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6NChrFq1ir179wKwdetWfvzxR371q19pHJnnkk1kNVZaWorRaCQxMdHm+cTERHbv3q1RVAJUz90jjzzCsGHD6NWrl9bh+KzFixezefNmNmzYoHUoPu/gwYO89dZbTJs2jaeeeooNGzbw0EMPERgYyKRJk7QOzyc98cQTlJeXk5GRgZ+fH0ajkZdeeolbb71V69A8liRGQjTj/vvvZ/v27fz4449ah+Kzjh49ysMPP8zKlSsJDg7WOhyfZzKZGDRoELNmzQKgf//+bN++nYULF0pipJF//etffPzxxyxatIiePXuSm5vLI488QnJysvxMWkkSI43Fx8fj5+dHUVGRzfNFRUUYDAaNohIPPPAA//vf//j+++/p0KGD1uH4rE2bNlFcXMyAAQOszxmNRr7//nveeOMNqqqq8PPz0zBC35KUlERmZqbNcz169ODf//63RhGJRx99lCeeeILf/e53APTu3ZsjR44we/ZsSYxaSWqMNBYYGMjAgQNZtWqV9TmTycSqVasYMmSIhpH5JrPZzAMPPMBnn33G6tWrSUtL0zokn3bVVVexbds2cnNzrY9BgwZx6623kpubK0mRiw0bNqzR8hV79+6lU6dOGkUkzp07h15v+1Hu5+eHyWTSKCLPJz1GbmDatGlMmjSJQYMGMXjwYObPn09FRQWTJ0/WOjSfc//997No0SL++9//EhERQWFhIQBRUVGEhIRoHJ3viYiIaFTfFRYWRlxcnNR9aWDq1KkMHTqUWbNmcdNNN7F+/Xreeecd3nnnHa1D81njxo3jpZdeomPHjvTs2ZMtW7bw6quvctddd2kdmseS6fpu4o033uDll1+msLCQfv368dprr5GVlaV1WD5Hp9M1+fwHH3zAnXfe6dpgRJOuuOIKma6vof/97388+eST7Nu3j7S0NKZNm8bdd9+tdVg+68yZMzzzzDN89tlnFBcXk5yczMSJE5kxYwaBgYFah+eRJDESQgghhKgjNUZCCCGEEHUkMRJCCCGEqCOJkRBCCCFEHUmMhBBCCCHqSGIkhBBCCFFHEiMhhBBCiDqSGAkhhBBC1JHESAghhBCijiRGQgghhBB1JDESQgghhKgjiZEQQgghRB1JjIQQQggh6vx/ZZND7rmC4MgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(experiment.train_loss_mse[:], label=\"Train MSE\")\n",
    "plt.plot(experiment.test_loss_mse[:], label=\"Test MSE\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train loss:  0.005459316315189484\n",
      "Test loss:  0.005415716949774295\n"
     ]
    }
   ],
   "source": [
    "print(\"Train loss: \", experiment.train_loss_mse[-1])\n",
    "print(\"Test loss: \", experiment.test_loss_mse[-1])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# JointVAE\n",
    "A disentangled Variational Autoencoder (VAE) with both discrete and continuous latent variables."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "16\n",
      "JointVAE(\n",
      "  (img_to_features): Sequential(\n",
      "    (0): Conv1d(1, 32, kernel_size=(1,), stride=(1,))\n",
      "    (1): ReLU()\n",
      "    (2): Conv1d(32, 64, kernel_size=(1,), stride=(1,))\n",
      "    (3): ReLU()\n",
      "    (4): Conv1d(64, 64, kernel_size=(1,), stride=(1,))\n",
      "    (5): ReLU()\n",
      "  )\n",
      "  (features_to_hidden): Sequential(\n",
      "    (0): Linear(in_features=1984, out_features=31, bias=True)\n",
      "    (1): ReLU()\n",
      "    (2): Linear(in_features=31, out_features=16, bias=True)\n",
      "    (3): ReLU()\n",
      "  )\n",
      "  (fc_mean): Linear(in_features=16, out_features=16, bias=True)\n",
      "  (fc_log_var): Linear(in_features=16, out_features=16, bias=True)\n",
      "  (latent_to_features): Sequential(\n",
      "    (0): Linear(in_features=16, out_features=16, bias=True)\n",
      "    (1): ReLU()\n",
      "    (2): Linear(in_features=16, out_features=31, bias=True)\n",
      "    (3): ReLU()\n",
      "    (4): Linear(in_features=31, out_features=1984, bias=True)\n",
      "    (5): ReLU()\n",
      "  )\n",
      "  (features_to_img): Sequential(\n",
      "    (0): ConvTranspose1d(64, 32, kernel_size=(1,), stride=(1,))\n",
      "    (1): ReLU()\n",
      "    (2): ConvTranspose1d(32, 32, kernel_size=(1,), stride=(1,))\n",
      "    (3): ReLU()\n",
      "    (4): ConvTranspose1d(32, 1, kernel_size=(1,), stride=(1,))\n",
      "    (5): Tanh()\n",
      "  )\n",
      ")\n"
     ]
    }
   ],
   "source": [
    "# Model init\n",
    "from models import JointVAE\n",
    "\n",
    "hidden_dim = round(input_dim * dim_reduction)\n",
    "print(hidden_dim)\n",
    "model = JointVAE(\n",
    "    input_dim=input_dim, \n",
    "    latent_spec={\n",
    "    'cont': hidden_dim,\n",
    "    }, \n",
    "    hidden_dim=hidden_dim, \n",
    "    channel_spec=model_configs['JointVAE']['channel_spec']\n",
    ")\n",
    "model_name = model.__class__.__name__\n",
    "print(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "21120 - INFO - 0/27721\tLoss: 38.614483\n",
      "21120 - INFO - 3200/27721\tLoss: 4.858552\n",
      "21120 - INFO - 6400/27721\tLoss: 0.212800\n",
      "21120 - INFO - 9600/27721\tLoss: 0.183056\n",
      "21120 - INFO - 12800/27721\tLoss: 0.178510\n",
      "21120 - INFO - 16000/27721\tLoss: 0.176134\n",
      "21120 - INFO - 19200/27721\tLoss: 0.171687\n",
      "21120 - INFO - 22400/27721\tLoss: 0.171671\n",
      "21120 - INFO - 25600/27721\tLoss: 0.169953\n",
      "21120 - INFO - Epoch [1/40]: Avg. Train Loss: 0.02603540, Avg. Test Loss: 0.00546760\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.180183\n",
      "21120 - INFO - 3200/27721\tLoss: 0.169061\n",
      "21120 - INFO - 6400/27721\tLoss: 0.170159\n",
      "21120 - INFO - 9600/27721\tLoss: 0.168808\n",
      "21120 - INFO - 12800/27721\tLoss: 0.165741\n",
      "21120 - INFO - 16000/27721\tLoss: 0.168340\n",
      "21120 - INFO - 19200/27721\tLoss: 0.165211\n",
      "21120 - INFO - 22400/27721\tLoss: 0.168608\n",
      "21120 - INFO - 25600/27721\tLoss: 0.162611\n",
      "21120 - INFO - Epoch [2/40]: Avg. Train Loss: 0.00538250, Avg. Test Loss: 0.00524166\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.172209\n",
      "21120 - INFO - 3200/27721\tLoss: 0.157474\n",
      "21120 - INFO - 6400/27721\tLoss: 0.140703\n",
      "21120 - INFO - 9600/27721\tLoss: 0.112031\n",
      "21120 - INFO - 12800/27721\tLoss: 0.098705\n",
      "21120 - INFO - 16000/27721\tLoss: 0.090577\n",
      "21120 - INFO - 19200/27721\tLoss: 0.086076\n",
      "21120 - INFO - 22400/27721\tLoss: 0.083937\n",
      "21120 - INFO - 25600/27721\tLoss: 0.083457\n",
      "21120 - INFO - Epoch [3/40]: Avg. Train Loss: 0.00338407, Avg. Test Loss: 0.00268382\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.082408\n",
      "21120 - INFO - 3200/27721\tLoss: 0.081029\n",
      "21120 - INFO - 6400/27721\tLoss: 0.079794\n",
      "21120 - INFO - 9600/27721\tLoss: 0.079697\n",
      "21120 - INFO - 12800/27721\tLoss: 0.079164\n",
      "21120 - INFO - 16000/27721\tLoss: 0.078666\n",
      "21120 - INFO - 19200/27721\tLoss: 0.078594\n",
      "21120 - INFO - 22400/27721\tLoss: 0.077930\n",
      "21120 - INFO - 25600/27721\tLoss: 0.075817\n",
      "21120 - INFO - Epoch [4/40]: Avg. Train Loss: 0.00252851, Avg. Test Loss: 0.00232928\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.066192\n",
      "21120 - INFO - 3200/27721\tLoss: 0.069985\n",
      "21120 - INFO - 6400/27721\tLoss: 0.067265\n",
      "21120 - INFO - 9600/27721\tLoss: 0.067293\n",
      "21120 - INFO - 12800/27721\tLoss: 0.063209\n",
      "21120 - INFO - 16000/27721\tLoss: 0.063825\n",
      "21120 - INFO - 19200/27721\tLoss: 0.063762\n",
      "21120 - INFO - 22400/27721\tLoss: 0.063623\n",
      "21120 - INFO - 25600/27721\tLoss: 0.062504\n",
      "21120 - INFO - Epoch [5/40]: Avg. Train Loss: 0.00209689, Avg. Test Loss: 0.00200699\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.068526\n",
      "21120 - INFO - 3200/27721\tLoss: 0.062293\n",
      "21120 - INFO - 6400/27721\tLoss: 0.060858\n",
      "21120 - INFO - 9600/27721\tLoss: 0.059932\n",
      "21120 - INFO - 12800/27721\tLoss: 0.057598\n",
      "21120 - INFO - 16000/27721\tLoss: 0.054241\n",
      "21120 - INFO - 19200/27721\tLoss: 0.052059\n",
      "21120 - INFO - 22400/27721\tLoss: 0.051649\n",
      "21120 - INFO - 25600/27721\tLoss: 0.050871\n",
      "21120 - INFO - Epoch [6/40]: Avg. Train Loss: 0.00180029, Avg. Test Loss: 0.00167409\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.056686\n",
      "21120 - INFO - 3200/27721\tLoss: 0.049639\n",
      "21120 - INFO - 6400/27721\tLoss: 0.049848\n",
      "21120 - INFO - 9600/27721\tLoss: 0.049274\n",
      "21120 - INFO - 12800/27721\tLoss: 0.049722\n",
      "21120 - INFO - 16000/27721\tLoss: 0.048471\n",
      "21120 - INFO - 19200/27721\tLoss: 0.050336\n",
      "21120 - INFO - 22400/27721\tLoss: 0.047354\n",
      "21120 - INFO - 25600/27721\tLoss: 0.048435\n",
      "21120 - INFO - Epoch [7/40]: Avg. Train Loss: 0.00158208, Avg. Test Loss: 0.00151738\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.046832\n",
      "21120 - INFO - 3200/27721\tLoss: 0.047391\n",
      "21120 - INFO - 6400/27721\tLoss: 0.049198\n",
      "21120 - INFO - 9600/27721\tLoss: 0.046308\n",
      "21120 - INFO - 12800/27721\tLoss: 0.047411\n",
      "21120 - INFO - 16000/27721\tLoss: 0.046564\n",
      "21120 - INFO - 19200/27721\tLoss: 0.045292\n",
      "21120 - INFO - 22400/27721\tLoss: 0.044868\n",
      "21120 - INFO - 25600/27721\tLoss: 0.043755\n",
      "21120 - INFO - Epoch [8/40]: Avg. Train Loss: 0.00149225, Avg. Test Loss: 0.00157669\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.053923\n",
      "21120 - INFO - 3200/27721\tLoss: 0.045277\n",
      "21120 - INFO - 6400/27721\tLoss: 0.043926\n",
      "21120 - INFO - 9600/27721\tLoss: 0.043844\n",
      "21120 - INFO - 12800/27721\tLoss: 0.043111\n",
      "21120 - INFO - 16000/27721\tLoss: 0.041722\n",
      "21120 - INFO - 19200/27721\tLoss: 0.040416\n",
      "21120 - INFO - 22400/27721\tLoss: 0.041283\n",
      "21120 - INFO - 25600/27721\tLoss: 0.040399\n",
      "21120 - INFO - Epoch [9/40]: Avg. Train Loss: 0.00136616, Avg. Test Loss: 0.00133763\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.040056\n",
      "21120 - INFO - 3200/27721\tLoss: 0.041037\n",
      "21120 - INFO - 6400/27721\tLoss: 0.039388\n",
      "21120 - INFO - 9600/27721\tLoss: 0.039149\n",
      "21120 - INFO - 12800/27721\tLoss: 0.039701\n",
      "21120 - INFO - 16000/27721\tLoss: 0.040335\n",
      "21120 - INFO - 19200/27721\tLoss: 0.038586\n",
      "21120 - INFO - 22400/27721\tLoss: 0.038738\n",
      "21120 - INFO - 25600/27721\tLoss: 0.038804\n",
      "21120 - INFO - Epoch [10/40]: Avg. Train Loss: 0.00127167, Avg. Test Loss: 0.00129346\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.044712\n",
      "21120 - INFO - 3200/27721\tLoss: 0.038407\n",
      "21120 - INFO - 6400/27721\tLoss: 0.038641\n",
      "21120 - INFO - 9600/27721\tLoss: 0.037850\n",
      "21120 - INFO - 12800/27721\tLoss: 0.038047\n",
      "21120 - INFO - 16000/27721\tLoss: 0.038282\n",
      "21120 - INFO - 19200/27721\tLoss: 0.038841\n",
      "21120 - INFO - 22400/27721\tLoss: 0.038351\n",
      "21120 - INFO - 25600/27721\tLoss: 0.037689\n",
      "21120 - INFO - Epoch [11/40]: Avg. Train Loss: 0.00123687, Avg. Test Loss: 0.00125126\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.044083\n",
      "21120 - INFO - 3200/27721\tLoss: 0.038110\n",
      "21120 - INFO - 6400/27721\tLoss: 0.036413\n",
      "21120 - INFO - 9600/27721\tLoss: 0.036798\n",
      "21120 - INFO - 12800/27721\tLoss: 0.037755\n",
      "21120 - INFO - 16000/27721\tLoss: 0.038076\n",
      "21120 - INFO - 19200/27721\tLoss: 0.037494\n",
      "21120 - INFO - 22400/27721\tLoss: 0.036678\n",
      "21120 - INFO - 25600/27721\tLoss: 0.037091\n",
      "21120 - INFO - Epoch [12/40]: Avg. Train Loss: 0.00120387, Avg. Test Loss: 0.00124632\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.038965\n",
      "21120 - INFO - 3200/27721\tLoss: 0.037067\n",
      "21120 - INFO - 6400/27721\tLoss: 0.036311\n",
      "21120 - INFO - 9600/27721\tLoss: 0.037079\n",
      "21120 - INFO - 12800/27721\tLoss: 0.036421\n",
      "21120 - INFO - 16000/27721\tLoss: 0.036323\n",
      "21120 - INFO - 19200/27721\tLoss: 0.036342\n",
      "21120 - INFO - 22400/27721\tLoss: 0.036220\n",
      "21120 - INFO - 25600/27721\tLoss: 0.035839\n",
      "21120 - INFO - Epoch [13/40]: Avg. Train Loss: 0.00117387, Avg. Test Loss: 0.00119692\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.032689\n",
      "21120 - INFO - 3200/27721\tLoss: 0.035890\n",
      "21120 - INFO - 6400/27721\tLoss: 0.035673\n",
      "21120 - INFO - 9600/27721\tLoss: 0.035643\n",
      "21120 - INFO - 12800/27721\tLoss: 0.035231\n",
      "21120 - INFO - 16000/27721\tLoss: 0.035775\n",
      "21120 - INFO - 19200/27721\tLoss: 0.036188\n",
      "21120 - INFO - 22400/27721\tLoss: 0.035663\n",
      "21120 - INFO - 25600/27721\tLoss: 0.035752\n",
      "21120 - INFO - Epoch [14/40]: Avg. Train Loss: 0.00115294, Avg. Test Loss: 0.00115686\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.036001\n",
      "21120 - INFO - 3200/27721\tLoss: 0.035657\n",
      "21120 - INFO - 6400/27721\tLoss: 0.034659\n",
      "21120 - INFO - 9600/27721\tLoss: 0.034324\n",
      "21120 - INFO - 12800/27721\tLoss: 0.034543\n",
      "21120 - INFO - 16000/27721\tLoss: 0.032988\n",
      "21120 - INFO - 19200/27721\tLoss: 0.033736\n",
      "21120 - INFO - 22400/27721\tLoss: 0.032717\n",
      "21120 - INFO - 25600/27721\tLoss: 0.032484\n",
      "21120 - INFO - Epoch [15/40]: Avg. Train Loss: 0.00108912, Avg. Test Loss: 0.00107061\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.028178\n",
      "21120 - INFO - 3200/27721\tLoss: 0.030812\n",
      "21120 - INFO - 6400/27721\tLoss: 0.032193\n",
      "21120 - INFO - 9600/27721\tLoss: 0.031441\n",
      "21120 - INFO - 12800/27721\tLoss: 0.031283\n",
      "21120 - INFO - 16000/27721\tLoss: 0.032062\n",
      "21120 - INFO - 19200/27721\tLoss: 0.031180\n",
      "21120 - INFO - 22400/27721\tLoss: 0.032057\n",
      "21120 - INFO - 25600/27721\tLoss: 0.030584\n",
      "21120 - INFO - Epoch [16/40]: Avg. Train Loss: 0.00101602, Avg. Test Loss: 0.00110123\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.033719\n",
      "21120 - INFO - 3200/27721\tLoss: 0.031383\n",
      "21120 - INFO - 6400/27721\tLoss: 0.030252\n",
      "21120 - INFO - 9600/27721\tLoss: 0.030133\n",
      "21120 - INFO - 12800/27721\tLoss: 0.030261\n",
      "21120 - INFO - 16000/27721\tLoss: 0.029981\n",
      "21120 - INFO - 19200/27721\tLoss: 0.030114\n",
      "21120 - INFO - 22400/27721\tLoss: 0.029728\n",
      "21120 - INFO - 25600/27721\tLoss: 0.029335\n",
      "21120 - INFO - Epoch [17/40]: Avg. Train Loss: 0.00097089, Avg. Test Loss: 0.00095432\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.026391\n",
      "21120 - INFO - 3200/27721\tLoss: 0.028623\n",
      "21120 - INFO - 6400/27721\tLoss: 0.028682\n",
      "21120 - INFO - 9600/27721\tLoss: 0.027744\n",
      "21120 - INFO - 12800/27721\tLoss: 0.028008\n",
      "21120 - INFO - 16000/27721\tLoss: 0.027859\n",
      "21120 - INFO - 19200/27721\tLoss: 0.027416\n",
      "21120 - INFO - 22400/27721\tLoss: 0.026672\n",
      "21120 - INFO - 25600/27721\tLoss: 0.027305\n",
      "21120 - INFO - Epoch [18/40]: Avg. Train Loss: 0.00089551, Avg. Test Loss: 0.00093474\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.027496\n",
      "21120 - INFO - 3200/27721\tLoss: 0.027628\n",
      "21120 - INFO - 6400/27721\tLoss: 0.026787\n",
      "21120 - INFO - 9600/27721\tLoss: 0.026372\n",
      "21120 - INFO - 12800/27721\tLoss: 0.025453\n",
      "21120 - INFO - 16000/27721\tLoss: 0.027035\n",
      "21120 - INFO - 19200/27721\tLoss: 0.026061\n",
      "21120 - INFO - 22400/27721\tLoss: 0.026155\n",
      "21120 - INFO - 25600/27721\tLoss: 0.025812\n",
      "21120 - INFO - Epoch [19/40]: Avg. Train Loss: 0.00085208, Avg. Test Loss: 0.00086216\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.027538\n",
      "21120 - INFO - 3200/27721\tLoss: 0.025622\n",
      "21120 - INFO - 6400/27721\tLoss: 0.025650\n",
      "21120 - INFO - 9600/27721\tLoss: 0.025725\n",
      "21120 - INFO - 12800/27721\tLoss: 0.025302\n",
      "21120 - INFO - 16000/27721\tLoss: 0.025709\n",
      "21120 - INFO - 19200/27721\tLoss: 0.025253\n",
      "21120 - INFO - 22400/27721\tLoss: 0.025825\n",
      "21120 - INFO - 25600/27721\tLoss: 0.026171\n",
      "21120 - INFO - Epoch [20/40]: Avg. Train Loss: 0.00082599, Avg. Test Loss: 0.00088678\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.027634\n",
      "21120 - INFO - 3200/27721\tLoss: 0.025796\n",
      "21120 - INFO - 6400/27721\tLoss: 0.025132\n",
      "21120 - INFO - 9600/27721\tLoss: 0.024755\n",
      "21120 - INFO - 12800/27721\tLoss: 0.025452\n",
      "21120 - INFO - 16000/27721\tLoss: 0.024430\n",
      "21120 - INFO - 19200/27721\tLoss: 0.025010\n",
      "21120 - INFO - 22400/27721\tLoss: 0.025155\n",
      "21120 - INFO - 25600/27721\tLoss: 0.024490\n",
      "21120 - INFO - Epoch [21/40]: Avg. Train Loss: 0.00080670, Avg. Test Loss: 0.00079640\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.024528\n",
      "21120 - INFO - 3200/27721\tLoss: 0.023992\n",
      "21120 - INFO - 6400/27721\tLoss: 0.024379\n",
      "21120 - INFO - 9600/27721\tLoss: 0.025146\n",
      "21120 - INFO - 12800/27721\tLoss: 0.024579\n",
      "21120 - INFO - 16000/27721\tLoss: 0.024421\n",
      "21120 - INFO - 19200/27721\tLoss: 0.024416\n",
      "21120 - INFO - 22400/27721\tLoss: 0.024105\n",
      "21120 - INFO - 25600/27721\tLoss: 0.023922\n",
      "21120 - INFO - Epoch [22/40]: Avg. Train Loss: 0.00078440, Avg. Test Loss: 0.00083423\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.029561\n",
      "21120 - INFO - 3200/27721\tLoss: 0.024048\n",
      "21120 - INFO - 6400/27721\tLoss: 0.023775\n",
      "21120 - INFO - 9600/27721\tLoss: 0.024362\n",
      "21120 - INFO - 12800/27721\tLoss: 0.024878\n",
      "21120 - INFO - 16000/27721\tLoss: 0.023969\n",
      "21120 - INFO - 19200/27721\tLoss: 0.024194\n",
      "21120 - INFO - 22400/27721\tLoss: 0.023905\n",
      "21120 - INFO - 25600/27721\tLoss: 0.023887\n",
      "21120 - INFO - Epoch [23/40]: Avg. Train Loss: 0.00077871, Avg. Test Loss: 0.00084711\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.027347\n",
      "21120 - INFO - 3200/27721\tLoss: 0.024221\n",
      "21120 - INFO - 6400/27721\tLoss: 0.024266\n",
      "21120 - INFO - 9600/27721\tLoss: 0.023716\n",
      "21120 - INFO - 12800/27721\tLoss: 0.023599\n",
      "21120 - INFO - 16000/27721\tLoss: 0.024091\n",
      "21120 - INFO - 19200/27721\tLoss: 0.023642\n",
      "21120 - INFO - 22400/27721\tLoss: 0.023443\n",
      "21120 - INFO - 25600/27721\tLoss: 0.023061\n",
      "21120 - INFO - Epoch [24/40]: Avg. Train Loss: 0.00076654, Avg. Test Loss: 0.00079446\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.024025\n",
      "21120 - INFO - 3200/27721\tLoss: 0.023561\n",
      "21120 - INFO - 6400/27721\tLoss: 0.023700\n",
      "21120 - INFO - 9600/27721\tLoss: 0.023356\n",
      "21120 - INFO - 12800/27721\tLoss: 0.024151\n",
      "21120 - INFO - 16000/27721\tLoss: 0.023739\n",
      "21120 - INFO - 19200/27721\tLoss: 0.023651\n",
      "21120 - INFO - 22400/27721\tLoss: 0.023029\n",
      "21120 - INFO - 25600/27721\tLoss: 0.023050\n",
      "21120 - INFO - Epoch [25/40]: Avg. Train Loss: 0.00075775, Avg. Test Loss: 0.00081153\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.025083\n",
      "21120 - INFO - 3200/27721\tLoss: 0.023794\n",
      "21120 - INFO - 6400/27721\tLoss: 0.023549\n",
      "21120 - INFO - 9600/27721\tLoss: 0.022839\n",
      "21120 - INFO - 12800/27721\tLoss: 0.023173\n",
      "21120 - INFO - 16000/27721\tLoss: 0.023426\n",
      "21120 - INFO - 19200/27721\tLoss: 0.022292\n",
      "21120 - INFO - 22400/27721\tLoss: 0.022786\n",
      "21120 - INFO - 25600/27721\tLoss: 0.023728\n",
      "21120 - INFO - Epoch [26/40]: Avg. Train Loss: 0.00074875, Avg. Test Loss: 0.00079640\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.024572\n",
      "21120 - INFO - 3200/27721\tLoss: 0.023155\n",
      "21120 - INFO - 6400/27721\tLoss: 0.023284\n",
      "21120 - INFO - 9600/27721\tLoss: 0.023459\n",
      "21120 - INFO - 12800/27721\tLoss: 0.023067\n",
      "21120 - INFO - 16000/27721\tLoss: 0.022946\n",
      "21120 - INFO - 19200/27721\tLoss: 0.022563\n",
      "21120 - INFO - 22400/27721\tLoss: 0.023233\n",
      "21120 - INFO - 25600/27721\tLoss: 0.023142\n",
      "21120 - INFO - Epoch [27/40]: Avg. Train Loss: 0.00074567, Avg. Test Loss: 0.00082877\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.026939\n",
      "21120 - INFO - 3200/27721\tLoss: 0.023428\n",
      "21120 - INFO - 6400/27721\tLoss: 0.022489\n",
      "21120 - INFO - 9600/27721\tLoss: 0.022853\n",
      "21120 - INFO - 12800/27721\tLoss: 0.023006\n",
      "21120 - INFO - 16000/27721\tLoss: 0.022567\n",
      "21120 - INFO - 19200/27721\tLoss: 0.022484\n",
      "21120 - INFO - 22400/27721\tLoss: 0.021965\n",
      "21120 - INFO - 25600/27721\tLoss: 0.023513\n",
      "21120 - INFO - Epoch [28/40]: Avg. Train Loss: 0.00073735, Avg. Test Loss: 0.00081227\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.024337\n",
      "21120 - INFO - 3200/27721\tLoss: 0.022532\n",
      "21120 - INFO - 6400/27721\tLoss: 0.022100\n",
      "21120 - INFO - 9600/27721\tLoss: 0.022813\n",
      "21120 - INFO - 12800/27721\tLoss: 0.022717\n",
      "21120 - INFO - 16000/27721\tLoss: 0.023038\n",
      "21120 - INFO - 19200/27721\tLoss: 0.022616\n",
      "21120 - INFO - 22400/27721\tLoss: 0.022603\n",
      "21120 - INFO - 25600/27721\tLoss: 0.022329\n",
      "21120 - INFO - Epoch [29/40]: Avg. Train Loss: 0.00072793, Avg. Test Loss: 0.00075041\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.022475\n",
      "21120 - INFO - 3200/27721\tLoss: 0.022751\n",
      "21120 - INFO - 6400/27721\tLoss: 0.022097\n",
      "21120 - INFO - 9600/27721\tLoss: 0.022417\n",
      "21120 - INFO - 12800/27721\tLoss: 0.022447\n",
      "21120 - INFO - 16000/27721\tLoss: 0.021682\n",
      "21120 - INFO - 19200/27721\tLoss: 0.021842\n",
      "21120 - INFO - 22400/27721\tLoss: 0.022651\n",
      "21120 - INFO - 25600/27721\tLoss: 0.022660\n",
      "21120 - INFO - Epoch [30/40]: Avg. Train Loss: 0.00071761, Avg. Test Loss: 0.00072092\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.021698\n",
      "21120 - INFO - 3200/27721\tLoss: 0.022115\n",
      "21120 - INFO - 6400/27721\tLoss: 0.021881\n",
      "21120 - INFO - 9600/27721\tLoss: 0.022702\n",
      "21120 - INFO - 12800/27721\tLoss: 0.022388\n",
      "21120 - INFO - 16000/27721\tLoss: 0.021958\n",
      "21120 - INFO - 19200/27721\tLoss: 0.021764\n",
      "21120 - INFO - 22400/27721\tLoss: 0.023054\n",
      "21120 - INFO - 25600/27721\tLoss: 0.021641\n",
      "21120 - INFO - Epoch [31/40]: Avg. Train Loss: 0.00071604, Avg. Test Loss: 0.00071816\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.023868\n",
      "21120 - INFO - 3200/27721\tLoss: 0.021949\n",
      "21120 - INFO - 6400/27721\tLoss: 0.021726\n",
      "21120 - INFO - 9600/27721\tLoss: 0.022278\n",
      "21120 - INFO - 12800/27721\tLoss: 0.021993\n",
      "21120 - INFO - 16000/27721\tLoss: 0.021887\n",
      "21120 - INFO - 19200/27721\tLoss: 0.022517\n",
      "21120 - INFO - 22400/27721\tLoss: 0.021921\n",
      "21120 - INFO - 25600/27721\tLoss: 0.021287\n",
      "21120 - INFO - Epoch [32/40]: Avg. Train Loss: 0.00070695, Avg. Test Loss: 0.00072048\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.023452\n",
      "21120 - INFO - 3200/27721\tLoss: 0.021914\n",
      "21120 - INFO - 6400/27721\tLoss: 0.021622\n",
      "21120 - INFO - 9600/27721\tLoss: 0.021427\n",
      "21120 - INFO - 12800/27721\tLoss: 0.022079\n",
      "21120 - INFO - 16000/27721\tLoss: 0.021193\n",
      "21120 - INFO - 19200/27721\tLoss: 0.021059\n",
      "21120 - INFO - 22400/27721\tLoss: 0.021216\n",
      "21120 - INFO - 25600/27721\tLoss: 0.021659\n",
      "21120 - INFO - Epoch [33/40]: Avg. Train Loss: 0.00069367, Avg. Test Loss: 0.00074841\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.025499\n",
      "21120 - INFO - 3200/27721\tLoss: 0.020984\n",
      "21120 - INFO - 6400/27721\tLoss: 0.022077\n",
      "21120 - INFO - 9600/27721\tLoss: 0.021905\n",
      "21120 - INFO - 12800/27721\tLoss: 0.020728\n",
      "21120 - INFO - 16000/27721\tLoss: 0.021445\n",
      "21120 - INFO - 19200/27721\tLoss: 0.021141\n",
      "21120 - INFO - 22400/27721\tLoss: 0.021435\n",
      "21120 - INFO - 25600/27721\tLoss: 0.020835\n",
      "21120 - INFO - Epoch [34/40]: Avg. Train Loss: 0.00069278, Avg. Test Loss: 0.00075676\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.022273\n",
      "21120 - INFO - 3200/27721\tLoss: 0.021555\n",
      "21120 - INFO - 6400/27721\tLoss: 0.021018\n",
      "21120 - INFO - 9600/27721\tLoss: 0.020594\n",
      "21120 - INFO - 12800/27721\tLoss: 0.020823\n",
      "21120 - INFO - 16000/27721\tLoss: 0.021144\n",
      "21120 - INFO - 19200/27721\tLoss: 0.020913\n",
      "21120 - INFO - 22400/27721\tLoss: 0.020831\n",
      "21120 - INFO - 25600/27721\tLoss: 0.020294\n",
      "21120 - INFO - Epoch [35/40]: Avg. Train Loss: 0.00067307, Avg. Test Loss: 0.00070991\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.021676\n",
      "21120 - INFO - 3200/27721\tLoss: 0.020910\n",
      "21120 - INFO - 6400/27721\tLoss: 0.020874\n",
      "21120 - INFO - 9600/27721\tLoss: 0.020989\n",
      "21120 - INFO - 12800/27721\tLoss: 0.020563\n",
      "21120 - INFO - 16000/27721\tLoss: 0.021640\n",
      "21120 - INFO - 19200/27721\tLoss: 0.020492\n",
      "21120 - INFO - 22400/27721\tLoss: 0.020048\n",
      "21120 - INFO - 25600/27721\tLoss: 0.019705\n",
      "21120 - INFO - Epoch [36/40]: Avg. Train Loss: 0.00066630, Avg. Test Loss: 0.00077761\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.024976\n",
      "21120 - INFO - 3200/27721\tLoss: 0.020587\n",
      "21120 - INFO - 6400/27721\tLoss: 0.019995\n",
      "21120 - INFO - 9600/27721\tLoss: 0.020637\n",
      "21120 - INFO - 12800/27721\tLoss: 0.021468\n",
      "21120 - INFO - 16000/27721\tLoss: 0.020523\n",
      "21120 - INFO - 19200/27721\tLoss: 0.020521\n",
      "21120 - INFO - 22400/27721\tLoss: 0.019892\n",
      "21120 - INFO - 25600/27721\tLoss: 0.019896\n",
      "21120 - INFO - Epoch [37/40]: Avg. Train Loss: 0.00066006, Avg. Test Loss: 0.00074890\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.021767\n",
      "21120 - INFO - 3200/27721\tLoss: 0.020404\n",
      "21120 - INFO - 6400/27721\tLoss: 0.020164\n",
      "21120 - INFO - 9600/27721\tLoss: 0.019835\n",
      "21120 - INFO - 12800/27721\tLoss: 0.020091\n",
      "21120 - INFO - 16000/27721\tLoss: 0.020048\n",
      "21120 - INFO - 19200/27721\tLoss: 0.020222\n",
      "21120 - INFO - 22400/27721\tLoss: 0.020130\n",
      "21120 - INFO - 25600/27721\tLoss: 0.020121\n",
      "21120 - INFO - Epoch [38/40]: Avg. Train Loss: 0.00064741, Avg. Test Loss: 0.00064883\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.023242\n",
      "21120 - INFO - 3200/27721\tLoss: 0.020248\n",
      "21120 - INFO - 6400/27721\tLoss: 0.020855\n",
      "21120 - INFO - 9600/27721\tLoss: 0.020596\n",
      "21120 - INFO - 12800/27721\tLoss: 0.020515\n",
      "21120 - INFO - 16000/27721\tLoss: 0.019663\n",
      "21120 - INFO - 19200/27721\tLoss: 0.019272\n",
      "21120 - INFO - 22400/27721\tLoss: 0.019949\n",
      "21120 - INFO - 25600/27721\tLoss: 0.020153\n",
      "21120 - INFO - Epoch [39/40]: Avg. Train Loss: 0.00064832, Avg. Test Loss: 0.00065307\n",
      "\n",
      "21120 - INFO - 0/27721\tLoss: 0.018271\n",
      "21120 - INFO - 3200/27721\tLoss: 0.018871\n",
      "21120 - INFO - 6400/27721\tLoss: 0.018930\n",
      "21120 - INFO - 9600/27721\tLoss: 0.018722\n",
      "21120 - INFO - 12800/27721\tLoss: 0.019980\n",
      "21120 - INFO - 16000/27721\tLoss: 0.019681\n",
      "21120 - INFO - 19200/27721\tLoss: 0.019268\n",
      "21120 - INFO - 22400/27721\tLoss: 0.019839\n",
      "21120 - INFO - 25600/27721\tLoss: 0.019678\n",
      "21120 - INFO - Epoch [40/40]: Avg. Train Loss: 0.00062560, Avg. Test Loss: 0.00069036\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Trainer definition\n",
    "from models import JointVAETrainer\n",
    "from benchmarking.utils import Experiment\n",
    "\n",
    "experiment = Experiment({}, f\"{model_name} Example\", '1.0', model, dataset_name)\n",
    "# NOTE: The capacity values are intuition based defaults and have to be tuned.\n",
    "trainer = JointVAETrainer(model=model, cont_capacity=[0.0, 1, 10, 0.0], disc_capacity=[0.0, 1, 10, 0.0])\n",
    "trainer.train(\n",
    "    train_loader=train_loader, \n",
    "    test_loader=test_loader, \n",
    "    epochs=40, \n",
    "    lr=model_configs[model_name]['lr'], \n",
    "    experiment=experiment\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjUAAAGdCAYAAADqsoKGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy80BEi2AAAACXBIWXMAAA9hAAAPYQGoP6dpAABKSElEQVR4nO3deXxU9aH//9eZSWYmewiBLBAgagSVTUFD1IpXoqEuFau3iFiocqV6larpAvhTwOWKF4u1Vlq0/am9vy8I0iq1VGkRFa8aUTYVFb6IrJKETbJMMvv5/THJ4EhYJpmFhPfz8TiPTM585pzPycHOu5/zWQzTNE1EREREOjlLoisgIiIiEg0KNSIiItIlKNSIiIhIl6BQIyIiIl2CQo2IiIh0CQo1IiIi0iUo1IiIiEiXoFAjIiIiXUJSoisQL4FAgD179pCRkYFhGImujoiIiJwA0zRpaGigsLAQi+XYbTGnTKjZs2cPRUVFia6GiIiItMOuXbvo3bv3McucMqEmIyMDCP5RMjMzE1wbERERORH19fUUFRWFvseP5ZQJNa2PnDIzMxVqREREOpkT6TqijsIiIiLSJSjUiIiISJegUCMiIiJdwinTp0ZERLoW0zTx+Xz4/f5EV0U6wGq1kpSUFJXpVhRqRESk0/F4PFRXV9PU1JToqkgUpKamUlBQgM1m69BxFGpERKRTCQQCbNu2DavVSmFhITabTZOqdlKmaeLxeNi3bx/btm2jpKTkuBPsHYtCjYiIdCoej4dAIEBRURGpqamJro50UEpKCsnJyezYsQOPx4PD4Wj3sdRRWEREOqWO/D96OblE617qX4SIiIh0CQo1IiIi0iUo1IiIiHRS/fr148knn0x0NU4aCjUiIiIxZhjGMbdZs2a167gfffQRkydP7lDdLr30UgzD4LHHHjvivauuuuqI+m3bto2bbrqJwsJCHA4HvXv35tprr2XTpk2hMke7zkWLFnWorsej0U8dtKW2gUUf7aJHhp3bR56e6OqIiMhJqLq6OvR68eLFzJgxg82bN4f2paenh16bponf7ycp6fhf0T169IhK/YqKinjhhReYNm1aaN/XX3/NypUrKSgoCO3zer1cfvnl9O/fn5dffpmCggJ2797N66+/zqFDh8KO+fzzzzN69OiwfdnZ2VGp79GopaaD9tS5+H/f3cbfNuxJdFVERE5JpmnS5PElZDNN84TqmJ+fH9qysrIwDCP0+6ZNm8jIyOD1119n2LBh2O123n33XbZu3cq1115LXl4e6enpnH/++bzxxhthx/3u4yfDMPjTn/7EddddR2pqKiUlJbz66qvHrd/VV1/N/v37ee+990L7/vznP3PFFVfQs2fP0L7PPvuMrVu38vvf/54RI0bQt29fLrroIh555BFGjBgRdszs7Oyw687Pz+/QcO0ToZaaDkq1WQFo9vgSXBMRkVNTs9fP2TP+mZBzf/5QBam26HyVTps2jV//+tecdtppdOvWjV27dnHllVfyX//1X9jtdv7nf/6Ha665hs2bN9OnT5+jHufBBx9kzpw5PP744/zud79j/Pjx7Nixg5ycnKN+xmazMX78eJ5//nkuuugiAF544QXmzJkT9uipR48eWCwW/vKXv3DPPfdgtVqjcu3RopaaDkpJDt7QJo/WHhERkfZ76KGHuPzyyzn99NPJyclhyJAh/PSnP2XgwIGUlJTw8MMPc/rppx+35eUnP/kJ48aN44wzzuDRRx+lsbGRDz/88Ljnv/XWW3nppZdwOp2888471NXVcfXVV4eV6dWrF0899RQzZsygW7duXHbZZTz88MN89dVXRxxv3LhxpKenh207d+6M7I8SIbXUdFCopcarUCMikggpyVY+f6giYeeOluHDh4f93tjYyKxZs/jHP/5BdXU1Pp+P5ubm4waDwYMHh16npaWRmZnJ3r17j3v+IUOGUFJSwl/+8hfeeustfvzjH7fZr+fOO+9kwoQJvP3223zwwQcsWbKERx99lFdffZXLL788VO43v/kN5eXlYZ8tLCw8bj06QqGmg1JCj58UakREEsEwjKg9AkqktLS0sN9/8YtfsGLFCn79619zxhlnkJKSwg033IDH4znmcZKTk8N+NwyDQCBwQnW49dZbmTdvHp9//vkxW3cyMjK45ppruOaaa3jkkUeoqKjgkUceCQs1+fn5nHHGGSd03mjR46cOSk0O/ofkC5h4fCf2j0ZEROR43nvvPX7yk59w3XXXMWjQIPLz89m+fXtMz3nTTTfx6aefMnDgQM4+++wT+oxhGAwYMACn0xnTup2Izh9tE6y1pQaCrTW2JOVEERHpuJKSEl5++WWuueYaDMPggQceOOEWl/bq1q0b1dXVR7T2tNqwYQMzZ87kxz/+MWeffTY2m41Vq1bx3HPPMXXq1LCyhw4doqamJmxfRkbGES1S0aRQ00G2JAtJFgNfwKTJ6yOLtv8hiIiIROKJJ57g1ltv5cILLyQ3N5epU6dSX18f8/Meay6Z3r17069fPx588EG2b9+OYRih3++9996wsrfccssRn589e3bYXDjRZpgnOsi+k6uvrycrK4u6ujoyMzOjeuxBs/5Jg8vHyp+P5PQe6cf/gIiItJvL5WLbtm0UFxfHfN4TiY9j3dNIvr/1rCQKUtVZWEREJOHaFWrmzZtHv379cDgclJaWHnf8+5IlSxgwYAAOh4NBgwbx2muvhd7zer1MnTqVQYMGkZaWRmFhIRMmTGDPnvAZevv163fEGhJtrVORCK297jWsW0REJHEiDjWLFy+msrKSmTNnsm7dOoYMGUJFRcVRx8C///77jBs3jkmTJrF+/XrGjBnDmDFj2LhxIwBNTU2sW7eOBx54gHXr1vHyyy+zefNmfvCDHxxxrIceeojq6urQNmXKlEirHxMOTcAnIiKScBGHmieeeILbbruNW265hbPPPpv58+eTmprKc88912b53/72t4wePZpf/vKXnHXWWTz88MOcd955PP300wBkZWWxYsUKfvSjH9G/f39GjBjB008/zdq1a4+YYCgjIyNsDYlY9qCOhJZKEBERSbyIQo3H42Ht2rVhMwRaLBbKy8upqqpq8zNVVVVHzChYUVFx1PIAdXV1GIZxRA/sxx57jO7du3Puuefy+OOP4/MdPUS43W7q6+vDtlhpDTVqqREREUmciIZ079+/H7/fT15eXtj+vLw8Nm3a1OZnampq2iz/3bHrrVwuF1OnTmXcuHFhvZx/9rOfcd5555GTk8P777/P9OnTqa6u5oknnmjzOLNnz+bBBx+M5PLaTes/iYiIJN5JNU+N1+vlRz/6EaZp8oc//CHsvcrKytDrwYMHY7PZ+OlPf8rs2bOx2+1HHGv69Olhn6mvr6eoqCgm9W5tqXGpo7CIiEjCRBRqcnNzsVqt1NbWhu2vra0lPz+/zc/k5+efUPnWQLNjxw7efPPN445FLy0txefzsX37dvr373/E+3a7vc2wEwspLaOf1FIjIiKSOBH1qbHZbAwbNoyVK1eG9gUCAVauXElZWVmbnykrKwsrD7BixYqw8q2BZsuWLbzxxht07979uHXZsGEDFouFnj17RnIJMaHHTyIiIokX8einyspK/vjHP/LnP/+ZL774gjvuuAOn0xmaDnnChAlMnz49VP7uu+9m+fLlzJ07l02bNjFr1izWrFnDXXfdBQQDzQ033MCaNWtYsGABfr+fmpoaampqQiuRVlVV8eSTT/Lxxx/z1VdfsWDBAu69915uvvlmunXrFo2/Q4do9JOIiBzLd+dZ++42a9asDh176dKlJ1yHDz74IGy/2+2me/fuGIbB22+/Hdq/atUqLrvsMnJyckhNTaWkpISJEyeGvpvffvvto17P0frNxlrEfWrGjh3Lvn37mDFjBjU1NQwdOpTly5eHOgPv3LkTi+VwVrrwwgtZuHAh999/P/fddx8lJSUsXbqUgQMHAvD111/z6quvAjB06NCwc7311ltceuml2O12Fi1axKxZs3C73RQXF3PvvfeG9ZlJpBSNfhIRkWOorq4OvV68eDEzZsxg8+bNoX3p6fFZYqeoqIjnn3+eESNGhPa98sorpKenc/DgwdC+zz//nNGjRzNlyhSeeuopUlJS2LJlC3/961/x+8O/6zZv3nxEl5GEPUUxTxF1dXUmYNbV1UX92M+9+5XZd+oy8z8XrI36sUVEJFxzc7P5+eefm83NzYmuSrs8//zzZlZWVti+P/7xj+aAAQNMu91u9u/f35w3b17oPbfbbd55551mfn6+abfbzT59+piPPvqoaZqm2bdvXxMIbX379j3qeQHz/vvvNzMzM82mpqbQ/ssvv9x84IEHTMB86623TNM0zd/85jdmv379jnkdb731lgmY33zzTUTX35Zj3dNIvr9PqtFPnVVo9JNaakRE4s80wduUmHMnp4JhdOgQCxYsYMaMGTz99NOce+65rF+/nttuu420tDQmTpzIU089xauvvspLL71Enz592LVrF7t27QLgo48+omfPnjz//POMHj0aq9V6zHMNGzaMfv368de//pWbb76ZnTt38s477zBv3jwefvjhULn8/Hyqq6t55513uOSSSzp0ffGkUBMFGv0kIpJA3iZ4tDAx575vD9g6Nrv9zJkzmTt3Lj/84Q8BKC4u5vPPP+eZZ55h4sSJ7Ny5k5KSEi6++GIMw6Bv376hz/bo0QOA7Ozso45C/q5bb72V5557jptvvpkXXniBK6+8MnScVv/+7//OP//5T0aOHEl+fj4jRoxg1KhRTJgw4YhHTb179w77vW/fvnz2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9eo2z+t2u6mvrw/bREREpOuKKNTs378fv99PXl5e2P68vDxqamra/ExNTc0xy7f+PF6Znj17hr2flJRETk7OUc87e/ZssrKyQltRUdEJXqWIiIh0Rl129NP06dOpq6sLbbt27Up0lURERCSGIgo1ubm5WK1Wamtrw/bX1taSn5/f5mfy8/OPWb715/HKfLcjss/n4+DBg0c9r91uJzMzM2wTERGRriuiUGOz2Rg2bBgrV64M7QsEAqxcuZKysrI2P1NWVhZWHmDFihWh8sXFxeTn54eVqa+vZ/Xq1aEyZWVlHDp0iLVr14bKvPnmmwQCAUpLSyO5BBEREemiIl4mobKykokTJzJ8+HAuuOACnnzySZxOJ7fccgsAEyZMoFevXsyePRuAu+++m5EjRzJ37lyuuuoqFi1axJo1a3j22WeB4BTQ99xzD4888gglJSUUFxfzwAMPUFhYyJgxYwA466yzGD16NLfddhvz58/H6/Vy1113ceONN57QyCcRERHp+iIONWPHjmXfvn3MmDGDmpoahg4dyvLly0MdfXfu3InFcrgB6MILL2ThwoXcf//93HfffZSUlLB06VIGDhwYKvOrX/0Kp9PJ5MmTOXToEBdffDHLly/H4XCEyixYsIC77rqLUaNGYbFYuP7663nqqac6cu0iIiLShUQ8T01npXlqREREOp9Ivr9PmVW6W7Ob5qsRERHpPFq/t0+kDeaUCTUNDQ0Amq9GRESkE2poaCArK+uYZU6Zx0+BQIA9e/aQkZGBYRhRPXZ9fT1FRUXs2rWrSz/aOhWu81S4RtB1djW6zq7jVLhGiOw6TdOkoaGBwsLCsD67bTllWmosFgu9e/eO6TlOlflwToXrPBWuEXSdXY2us+s4Fa4RTvw6j9dC06rLzigsIiIipxaFGhEREekSFGqiwG63M3PmTOx2e6KrElOnwnWeCtcIus6uRtfZdZwK1wixu85TpqOwiIiIdG1qqREREZEuQaFGREREugSFGhEREekSFGpERESkS1Co6aB58+bRr18/HA4HpaWlfPjhh4muUlTNmjULwzDCtgEDBiS6Wh32zjvvcM0111BYWIhhGCxdujTsfdM0mTFjBgUFBaSkpFBeXs6WLVsSU9kOON51/uQnPzni/o4ePToxlW2n2bNnc/7555ORkUHPnj0ZM2YMmzdvDivjcrm488476d69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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(experiment.train_loss_mse[:], label=\"Train MSE\")\n",
    "plt.plot(experiment.test_loss_mse[:], label=\"Test MSE\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Kernel PCA\n",
    "Kernel PCA, which will later be used as a baseline."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'PCA'"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Model init\n",
    "from models import PCA\n",
    "\n",
    "hidden_dim = round(input_dim * dim_reduction)\n",
    "model = PCA(hidden_dim=hidden_dim)\n",
    "model_name = model.__class__.__name__\n",
    "model_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Trainer definition\n",
    "from models import KernelPCATrainer\n",
    "from benchmarking.utils import Experiment\n",
    "\n",
    "experiment = Experiment({}, f\"{model_name} Example\", '1.0', model, dataset_name)\n",
    "trainer = KernelPCATrainer(model=model)\n",
    "trainer.train(train_loader=train_loader, test_loader=test_loader, experiment=experiment)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train loss:  0.0010937084443867207\n",
      "Test loss:  0.0010981984669342637\n"
     ]
    }
   ],
   "source": [
    "print(\"Train loss: \", experiment.train_loss_mse[-1])\n",
    "print(\"Test loss: \", experiment.test_loss_mse[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "custoverse-env",
   "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.9.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
