{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "56f9d1fd",
   "metadata": {},
   "source": [
    "Import the libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bcc9171d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import os\n",
    "# import networkx as nx\n",
    "from matplotlib import pyplot as plt\n",
    "import torch\n",
    "# import pickle\n",
    "# import time\n",
    "# import pandas as pd\n",
    "os.chdir(\"../\")\n",
    "from datagen.generateDataset_soft_interventions import Dataset\n",
    "from models.resblock_trainer_scout import resflow_train_test_wrapper as scout_trainer\n",
    "from utils import *\n",
    "from pathlib import Path\n",
    "from baselines.llc import LLCClassWrapper\n",
    "from rpy2 import robjects\n",
    "from rpy2.robjects import numpy2ri\n",
    "import rpy2.robjects as robjects"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ea36a4c6",
   "metadata": {},
   "source": [
    "Pick a noise type and intervention type"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a747ed04",
   "metadata": {},
   "outputs": [],
   "source": [
    "noise_type = 'gumbel' #Choices: 'gaussian', 'gumbel', 'exponential'\n",
    "intervention_type = 'shift' #Choices: 'shift', 'scale', 'noise'  \n",
    "sem_type = 'nnl' #Choices: 'lin', 'nnl'\n",
    "n_nodes = 10\n",
    "if intervention_type == 'shift':\n",
    "    shift_scale=2\n",
    "    intervention_scale=0.5\n",
    "    noisy = False\n",
    "elif intervention_type == 'scale':\n",
    "    shift_scale=0\n",
    "    intervention_scale=2\n",
    "    noisy = False\n",
    "elif intervention_type == 'noise':\n",
    "    shift_scale=0\n",
    "    intervention_scale=0.5\n",
    "    noisy = True\n",
    "unknown_target = True #If True, intervention targets are unknown during training"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "24ed34ca",
   "metadata": {},
   "source": [
    "Generating the dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "8e48df62",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_gen = Dataset(\n",
    "    n_nodes=n_nodes,\n",
    "    expected_density=2, \n",
    "    n_samples=1000,\n",
    "    n_experiments=n_nodes,\n",
    "    act_fun='tanh',\n",
    "    contractive=True,\n",
    "    target_predef=True,\n",
    "    targets= [np.array([node]) for node in range(n_nodes)],\n",
    "    mode = 'sat-pair-condition',\n",
    "    sem_type=sem_type, \n",
    "    shift_scale=shift_scale,\n",
    "    enforce_dag=False, \n",
    "    intervention_scale=intervention_scale,\n",
    "    noisy=noisy,\n",
    "    noise_type=noise_type,\n",
    "    noisy_weight=-1\n",
    "    )\n",
    "datasets = dataset_gen.generate(interventions=True)\n",
    "training_data = datasets\n",
    "intervention_sets =dataset_gen.targets\n",
    "n_experiments = len(intervention_sets)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "501c0ec5",
   "metadata": {},
   "source": [
    "Creating graph proxy for nonlinear SEM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "72913960",
   "metadata": {},
   "outputs": [],
   "source": [
    "    \n",
    "def jacobian_sq_empirical(fn, x, max_samples=256, device=None):\n",
    "    if device is None:\n",
    "        device = x.device if isinstance(x, torch.Tensor) else 'cpu'\n",
    "    if not isinstance(x, torch.Tensor):\n",
    "        x = torch.tensor(x, dtype=torch.float, device=device)\n",
    "    else:\n",
    "        x = x.to(device).float()\n",
    "    if x.ndim == 1:\n",
    "        x = x.unsqueeze(0)\n",
    "    N = x.shape[0]\n",
    "    S = min(N, max_samples)\n",
    "    def _call(inp):\n",
    "        out = fn(inp)\n",
    "        if isinstance(out, tuple):\n",
    "            out = out[0]\n",
    "        if out.ndim == 1:\n",
    "            out = out.unsqueeze(0)\n",
    "        return out\n",
    "    y0 = _call(x[0:1])\n",
    "    out_dim = y0.shape[1]\n",
    "    in_dim = x.shape[1]\n",
    "    acc = np.zeros((out_dim, in_dim), dtype=float)\n",
    "    for k in range(S):\n",
    "        xs = x[k:k+1].detach().clone().requires_grad_(True)\n",
    "        ys = _call(xs)        # (1, out_dim)\n",
    "        yv = ys[0]\n",
    "        for i in range(yv.shape[0]):\n",
    "            grad_i = torch.autograd.grad(yv[i], xs, retain_graph=True, create_graph=False)[0]  # (1, in_dim)\n",
    "            acc[i] += (grad_i.squeeze(0).detach().cpu().numpy() ** 2)\n",
    "    acc /= float(S)\n",
    "    return acc\n",
    "\n",
    "def minmax_normalize(M, eps=1e-12):\n",
    "    M = np.array(M, dtype=float)\n",
    "    mn = M.min()\n",
    "    mx = M.max()\n",
    "    return (M - mn) / (mx - mn + eps)\n",
    "\n",
    "if sem_type == \"nnl\":\n",
    "    device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "    f = dataset_gen.gen_model.f  \n",
    "    d = n_nodes   \n",
    "    G = 100 \n",
    "    vals = torch.linspace(-10.0, 10.0, G, device=device)\n",
    "    x_grid = torch.zeros(d * G, d, device=device)\n",
    "    for j in range(d):\n",
    "        x_grid[j*G:(j+1)*G, j] = vals\n",
    "    J2_grid = jacobian_sq_empirical(f, x_grid, max_samples=x_grid.shape[0], device=device)\n",
    "    gt_graph = J2_grid.T\n",
    "elif sem_type == \"lin\":\n",
    "    gt_graph = abs(dataset_gen.gen_model.weights)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a25def6a",
   "metadata": {},
   "source": [
    "Define SCOUT model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "fe472e0d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initializing the model\n",
      "Number of Parameters : 1392\n"
     ]
    }
   ],
   "source": [
    "if sem_type == \"lin\":\n",
    "    act_fun = 'none'\n",
    "elif sem_type == \"nnl\":\n",
    "    act_fun = 'tanh'\n",
    "model = scout_trainer(\n",
    "    n_nodes=n_nodes,\n",
    "    batch_size=512,\n",
    "    l1_reg=True, \n",
    "    lambda_c=1e-3, # sparsity penalization coef for graph learning\n",
    "    lambda_r=1e-2, # sparsity penalization coef for intervention learning\n",
    "    fun_type='gst-mlp', # Gumble-softmax masking function\n",
    "    act_fun=act_fun,\n",
    "    lr=1e-2,\n",
    "    epochs=200, # change to a higher number for better accuracy,\n",
    "    v=True, \n",
    "    inline=True, \n",
    "    n_hidden=0,\n",
    "    optim='adam',\n",
    "    dag_input=False,\n",
    "    unknown_intervention=unknown_target,\n",
    "    n_experiments=n_experiments,\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6c9fe2e7",
   "metadata": {},
   "source": [
    "Train SCOUT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "cd1bbd45",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting Training\n",
      "Epoch 1/200 Batch 0, Loss 16.8421\n",
      "Epoch 1/200 Batch 1, Loss 16.2027\n",
      "Epoch 1/200 Batch 2, Loss 16.2449\n",
      "Epoch 1/200 Batch 3, Loss 16.0202\n",
      "Epoch 1/200 Batch 4, Loss 16.0118\n",
      "Epoch 1/200 Batch 5, Loss 15.6813\n",
      "Epoch 1/200 Batch 6, Loss 15.5242\n",
      "Epoch 1/200 Batch 7, Loss 15.4126\n",
      "Epoch 1/200 Batch 8, Loss 15.3680\n",
      "Epoch 1/200 Batch 9, Loss 15.0088\n",
      "Epoch 1/200 Batch 10, Loss 15.0869\n",
      "Epoch 1/200 Batch 11, Loss 14.9794\n",
      "Epoch 1/200 Batch 12, Loss 14.9197\n",
      "Epoch 1/200 Batch 13, Loss 14.7977\n",
      "Epoch 1/200 Batch 14, Loss 14.7472\n",
      "Epoch 1/200 Batch 15, Loss 14.6419\n",
      "Epoch 1/200 Batch 16, Loss 14.3925\n",
      "Epoch 1/200 Batch 17, Loss 14.3346\n",
      "Epoch 1/200 Batch 18, Loss 13.8967\n",
      "Epoch 1/200 Batch 19, Loss 14.2098\n",
      "Epoch 2/200 Batch 0, Loss 14.0119\n",
      "Epoch 2/200 Batch 1, Loss 14.0640\n",
      "Epoch 2/200 Batch 2, Loss 14.0214\n",
      "Epoch 2/200 Batch 3, Loss 14.0207\n",
      "Epoch 2/200 Batch 4, Loss 13.7281\n",
      "Epoch 2/200 Batch 5, Loss 13.6886\n",
      "Epoch 2/200 Batch 6, Loss 13.7404\n",
      "Epoch 2/200 Batch 7, Loss 13.6744\n",
      "Epoch 2/200 Batch 8, Loss 13.5522\n",
      "Epoch 2/200 Batch 9, Loss 13.5443\n",
      "Epoch 2/200 Batch 10, Loss 13.1985\n",
      "Epoch 2/200 Batch 11, Loss 13.3326\n",
      "Epoch 2/200 Batch 12, Loss 13.2674\n",
      "Epoch 2/200 Batch 13, Loss 13.2006\n",
      "Epoch 2/200 Batch 14, Loss 13.3007\n",
      "Epoch 2/200 Batch 15, Loss 13.1989\n",
      "Epoch 2/200 Batch 16, Loss 13.2276\n",
      "Epoch 2/200 Batch 17, Loss 13.0441\n",
      "Epoch 2/200 Batch 18, Loss 13.1713\n",
      "Epoch 2/200 Batch 19, Loss 13.1620\n",
      "Epoch 3/200 Batch 0, Loss 12.9378\n",
      "Epoch 3/200 Batch 1, Loss 12.9726\n",
      "Epoch 3/200 Batch 2, Loss 12.8831\n",
      "Epoch 3/200 Batch 3, Loss 12.8899\n",
      "Epoch 3/200 Batch 4, Loss 12.8206\n",
      "Epoch 3/200 Batch 5, Loss 12.7877\n",
      "Epoch 3/200 Batch 6, Loss 12.9086\n",
      "Epoch 3/200 Batch 7, Loss 12.7467\n",
      "Epoch 3/200 Batch 8, Loss 12.6547\n",
      "Epoch 3/200 Batch 9, Loss 12.6862\n",
      "Epoch 3/200 Batch 10, Loss 12.7477\n",
      "Epoch 3/200 Batch 11, Loss 12.6411\n",
      "Epoch 3/200 Batch 12, Loss 12.6001\n",
      "Epoch 3/200 Batch 13, Loss 12.6291\n",
      "Epoch 3/200 Batch 14, Loss 12.5755\n",
      "Epoch 3/200 Batch 15, Loss 12.6217\n",
      "Epoch 3/200 Batch 16, Loss 12.4515\n",
      "Epoch 3/200 Batch 17, Loss 12.2427\n",
      "Epoch 3/200 Batch 18, Loss 12.5374\n",
      "Epoch 3/200 Batch 19, Loss 12.3148\n",
      "Epoch 4/200 Batch 0, Loss 12.4934\n",
      "Epoch 4/200 Batch 1, Loss 12.4970\n",
      "Epoch 4/200 Batch 2, Loss 12.3671\n",
      "Epoch 4/200 Batch 3, Loss 12.3390\n",
      "Epoch 4/200 Batch 4, Loss 12.5036\n",
      "Epoch 4/200 Batch 5, Loss 12.3031\n",
      "Epoch 4/200 Batch 6, Loss 12.3289\n",
      "Epoch 4/200 Batch 7, Loss 12.4211\n",
      "Epoch 4/200 Batch 8, Loss 12.3438\n",
      "Epoch 4/200 Batch 9, Loss 12.2355\n",
      "Epoch 4/200 Batch 10, Loss 12.1268\n",
      "Epoch 4/200 Batch 11, Loss 12.2999\n",
      "Epoch 4/200 Batch 12, Loss 12.3611\n",
      "Epoch 4/200 Batch 13, Loss 12.2872\n",
      "Epoch 4/200 Batch 14, Loss 12.3307\n",
      "Epoch 4/200 Batch 15, Loss 12.2496\n",
      "Epoch 4/200 Batch 16, Loss 12.0946\n",
      "Epoch 4/200 Batch 17, Loss 12.1302\n",
      "Epoch 4/200 Batch 18, Loss 12.3931\n",
      "Epoch 4/200 Batch 19, Loss 12.3201\n",
      "Epoch 5/200 Batch 0, Loss 12.2960\n",
      "Epoch 5/200 Batch 1, Loss 12.0643\n",
      "Epoch 5/200 Batch 2, Loss 11.9735\n",
      "Epoch 5/200 Batch 3, Loss 12.1249\n",
      "Epoch 5/200 Batch 4, Loss 12.1961\n",
      "Epoch 5/200 Batch 5, Loss 12.2344\n",
      "Epoch 5/200 Batch 6, Loss 12.0964\n",
      "Epoch 5/200 Batch 7, Loss 12.1758\n",
      "Epoch 5/200 Batch 8, Loss 12.1794\n",
      "Epoch 5/200 Batch 9, Loss 11.9476\n",
      "Epoch 5/200 Batch 10, Loss 12.0609\n",
      "Epoch 5/200 Batch 11, Loss 12.1335\n",
      "Epoch 5/200 Batch 12, Loss 12.1305\n",
      "Epoch 5/200 Batch 13, Loss 12.2185\n",
      "Epoch 5/200 Batch 14, Loss 12.1977\n",
      "Epoch 5/200 Batch 15, Loss 12.1161\n",
      "Epoch 5/200 Batch 16, Loss 12.0750\n",
      "Epoch 5/200 Batch 17, Loss 12.1713\n",
      "Epoch 5/200 Batch 18, Loss 12.2867\n",
      "Epoch 5/200 Batch 19, Loss 12.1117\n",
      "Epoch 6/200 Batch 0, Loss 11.9481\n",
      "Epoch 6/200 Batch 1, Loss 12.1900\n",
      "Epoch 6/200 Batch 2, Loss 12.1019\n",
      "Epoch 6/200 Batch 3, Loss 12.0201\n",
      "Epoch 6/200 Batch 4, Loss 12.1813\n",
      "Epoch 6/200 Batch 5, Loss 11.9340\n",
      "Epoch 6/200 Batch 6, Loss 11.9311\n",
      "Epoch 6/200 Batch 7, Loss 12.0503\n",
      "Epoch 6/200 Batch 8, Loss 12.0769\n",
      "Epoch 6/200 Batch 9, Loss 11.9370\n",
      "Epoch 6/200 Batch 10, Loss 12.0612\n",
      "Epoch 6/200 Batch 11, Loss 11.8270\n",
      "Epoch 6/200 Batch 12, Loss 11.9930\n",
      "Epoch 6/200 Batch 13, Loss 12.0347\n",
      "Epoch 6/200 Batch 14, Loss 11.9545\n",
      "Epoch 6/200 Batch 15, Loss 12.0626\n",
      "Epoch 6/200 Batch 16, Loss 12.0649\n",
      "Epoch 6/200 Batch 17, Loss 11.8281\n",
      "Epoch 6/200 Batch 18, Loss 12.0676\n",
      "Epoch 6/200 Batch 19, Loss 11.9906\n",
      "Epoch 7/200 Batch 0, Loss 11.9307\n",
      "Epoch 7/200 Batch 1, Loss 12.0086\n",
      "Epoch 7/200 Batch 2, Loss 12.0170\n",
      "Epoch 7/200 Batch 3, Loss 11.9078\n",
      "Epoch 7/200 Batch 4, Loss 12.0024\n",
      "Epoch 7/200 Batch 5, Loss 11.7446\n",
      "Epoch 7/200 Batch 6, Loss 12.0864\n",
      "Epoch 7/200 Batch 7, Loss 11.9905\n",
      "Epoch 7/200 Batch 8, Loss 12.0137\n",
      "Epoch 7/200 Batch 9, Loss 11.9280\n",
      "Epoch 7/200 Batch 10, Loss 11.9935\n",
      "Epoch 7/200 Batch 11, Loss 11.9038\n",
      "Epoch 7/200 Batch 12, Loss 11.8755\n",
      "Epoch 7/200 Batch 13, Loss 11.7970\n",
      "Epoch 7/200 Batch 14, Loss 11.7860\n",
      "Epoch 7/200 Batch 15, Loss 11.9856\n",
      "Epoch 7/200 Batch 16, Loss 11.9672\n",
      "Epoch 7/200 Batch 17, Loss 12.0023\n",
      "Epoch 7/200 Batch 18, Loss 11.8178\n",
      "Epoch 7/200 Batch 19, Loss 11.8037\n",
      "Epoch 8/200 Batch 0, Loss 11.9166\n",
      "Epoch 8/200 Batch 1, Loss 11.7197\n",
      "Epoch 8/200 Batch 2, Loss 11.7974\n",
      "Epoch 8/200 Batch 3, Loss 11.8187\n",
      "Epoch 8/200 Batch 4, Loss 11.8754\n",
      "Epoch 8/200 Batch 5, Loss 11.7219\n",
      "Epoch 8/200 Batch 6, Loss 11.8627\n",
      "Epoch 8/200 Batch 7, Loss 11.8178\n",
      "Epoch 8/200 Batch 8, Loss 11.9056\n",
      "Epoch 8/200 Batch 9, Loss 11.8273\n",
      "Epoch 8/200 Batch 10, Loss 12.0159\n",
      "Epoch 8/200 Batch 11, Loss 11.8508\n",
      "Epoch 8/200 Batch 12, Loss 11.8092\n",
      "Epoch 8/200 Batch 13, Loss 11.8549\n",
      "Epoch 8/200 Batch 14, Loss 11.8867\n",
      "Epoch 8/200 Batch 15, Loss 11.7971\n",
      "Epoch 8/200 Batch 16, Loss 11.8991\n",
      "Epoch 8/200 Batch 17, Loss 11.9700\n",
      "Epoch 8/200 Batch 18, Loss 11.8001\n",
      "Epoch 8/200 Batch 19, Loss 11.8970\n",
      "Epoch 9/200 Batch 0, Loss 11.9726\n",
      "Epoch 9/200 Batch 1, Loss 11.8948\n",
      "Epoch 9/200 Batch 2, Loss 11.9296\n",
      "Epoch 9/200 Batch 3, Loss 11.8288\n",
      "Epoch 9/200 Batch 4, Loss 11.8317\n",
      "Epoch 9/200 Batch 5, Loss 11.9313\n",
      "Epoch 9/200 Batch 6, Loss 11.8222\n",
      "Epoch 9/200 Batch 7, Loss 11.6461\n",
      "Epoch 9/200 Batch 8, Loss 11.7172\n",
      "Epoch 9/200 Batch 9, Loss 11.9829\n",
      "Epoch 9/200 Batch 10, Loss 11.7424\n",
      "Epoch 9/200 Batch 11, Loss 11.7224\n",
      "Epoch 9/200 Batch 12, Loss 11.7852\n",
      "Epoch 9/200 Batch 13, Loss 11.7690\n",
      "Epoch 9/200 Batch 14, Loss 11.7635\n",
      "Epoch 9/200 Batch 15, Loss 11.6298\n",
      "Epoch 9/200 Batch 16, Loss 11.8109\n",
      "Epoch 9/200 Batch 17, Loss 11.6770\n",
      "Epoch 9/200 Batch 18, Loss 11.8690\n",
      "Epoch 9/200 Batch 19, Loss 12.0027\n",
      "Epoch 10/200 Batch 0, Loss 11.6577\n",
      "Epoch 10/200 Batch 1, Loss 11.8062\n",
      "Epoch 10/200 Batch 2, Loss 11.8566\n",
      "Epoch 10/200 Batch 3, Loss 11.4977\n",
      "Epoch 10/200 Batch 4, Loss 11.9636\n",
      "Epoch 10/200 Batch 5, Loss 11.6506\n",
      "Epoch 10/200 Batch 6, Loss 11.7478\n",
      "Epoch 10/200 Batch 7, Loss 11.8059\n",
      "Epoch 10/200 Batch 8, Loss 11.7094\n",
      "Epoch 10/200 Batch 9, Loss 11.7608\n",
      "Epoch 10/200 Batch 10, Loss 11.7132\n",
      "Epoch 10/200 Batch 11, Loss 11.7919\n",
      "Epoch 10/200 Batch 12, Loss 11.8419\n",
      "Epoch 10/200 Batch 13, Loss 11.7253\n",
      "Epoch 10/200 Batch 14, Loss 11.9334\n",
      "Epoch 10/200 Batch 15, Loss 11.7668\n",
      "Epoch 10/200 Batch 16, Loss 11.7882\n",
      "Epoch 10/200 Batch 17, Loss 11.7975\n",
      "Epoch 10/200 Batch 18, Loss 11.6935\n",
      "Epoch 10/200 Batch 19, Loss 11.7210\n",
      "Epoch 11/200 Batch 0, Loss 11.7352\n",
      "Epoch 11/200 Batch 1, Loss 11.8036\n",
      "Epoch 11/200 Batch 2, Loss 11.8075\n",
      "Epoch 11/200 Batch 3, Loss 11.6677\n",
      "Epoch 11/200 Batch 4, Loss 11.6529\n",
      "Epoch 11/200 Batch 5, Loss 11.6421\n",
      "Epoch 11/200 Batch 6, Loss 11.6702\n",
      "Epoch 11/200 Batch 7, Loss 11.9329\n",
      "Epoch 11/200 Batch 8, Loss 11.7374\n",
      "Epoch 11/200 Batch 9, Loss 11.7192\n",
      "Epoch 11/200 Batch 10, Loss 11.5408\n",
      "Epoch 11/200 Batch 11, Loss 11.7320\n",
      "Epoch 11/200 Batch 12, Loss 11.7656\n",
      "Epoch 11/200 Batch 13, Loss 11.8273\n",
      "Epoch 11/200 Batch 14, Loss 11.7686\n",
      "Epoch 11/200 Batch 15, Loss 11.6860\n",
      "Epoch 11/200 Batch 16, Loss 11.6573\n",
      "Epoch 11/200 Batch 17, Loss 11.7421\n",
      "Epoch 11/200 Batch 18, Loss 11.7009\n",
      "Epoch 11/200 Batch 19, Loss 11.5167\n",
      "Epoch 12/200 Batch 0, Loss 11.5687\n",
      "Epoch 12/200 Batch 1, Loss 11.8720\n",
      "Epoch 12/200 Batch 2, Loss 11.6993\n",
      "Epoch 12/200 Batch 3, Loss 11.6722\n",
      "Epoch 12/200 Batch 4, Loss 11.8068\n",
      "Epoch 12/200 Batch 5, Loss 11.6805\n",
      "Epoch 12/200 Batch 6, Loss 11.6450\n",
      "Epoch 12/200 Batch 7, Loss 11.9990\n",
      "Epoch 12/200 Batch 8, Loss 11.8011\n",
      "Epoch 12/200 Batch 9, Loss 11.7387\n",
      "Epoch 12/200 Batch 10, Loss 11.7026\n",
      "Epoch 12/200 Batch 11, Loss 11.6549\n",
      "Epoch 12/200 Batch 12, Loss 11.5477\n",
      "Epoch 12/200 Batch 13, Loss 11.8144\n",
      "Epoch 12/200 Batch 14, Loss 11.5426\n",
      "Epoch 12/200 Batch 15, Loss 11.5444\n",
      "Epoch 12/200 Batch 16, Loss 11.6201\n",
      "Epoch 12/200 Batch 17, Loss 11.5021\n",
      "Epoch 12/200 Batch 18, Loss 11.7001\n",
      "Epoch 12/200 Batch 19, Loss 11.4759\n",
      "Epoch 13/200 Batch 0, Loss 11.6129\n",
      "Epoch 13/200 Batch 1, Loss 11.5192\n",
      "Epoch 13/200 Batch 2, Loss 11.5504\n",
      "Epoch 13/200 Batch 3, Loss 11.6261\n",
      "Epoch 13/200 Batch 4, Loss 11.6514\n",
      "Epoch 13/200 Batch 5, Loss 11.7058\n",
      "Epoch 13/200 Batch 6, Loss 12.0136\n",
      "Epoch 13/200 Batch 7, Loss 11.7211\n",
      "Epoch 13/200 Batch 8, Loss 11.6004\n",
      "Epoch 13/200 Batch 9, Loss 11.6492\n",
      "Epoch 13/200 Batch 10, Loss 11.6555\n",
      "Epoch 13/200 Batch 11, Loss 11.7044\n",
      "Epoch 13/200 Batch 12, Loss 11.5989\n",
      "Epoch 13/200 Batch 13, Loss 11.6937\n",
      "Epoch 13/200 Batch 14, Loss 11.6442\n",
      "Epoch 13/200 Batch 15, Loss 11.6144\n",
      "Epoch 13/200 Batch 16, Loss 11.7555\n",
      "Epoch 13/200 Batch 17, Loss 11.6024\n",
      "Epoch 13/200 Batch 18, Loss 11.7142\n",
      "Epoch 13/200 Batch 19, Loss 11.6210\n",
      "Epoch 14/200 Batch 0, Loss 11.7093\n",
      "Epoch 14/200 Batch 1, Loss 11.7114\n",
      "Epoch 14/200 Batch 2, Loss 11.7267\n",
      "Epoch 14/200 Batch 3, Loss 11.6555\n",
      "Epoch 14/200 Batch 4, Loss 11.6990\n",
      "Epoch 14/200 Batch 5, Loss 11.5153\n",
      "Epoch 14/200 Batch 6, Loss 11.7407\n",
      "Epoch 14/200 Batch 7, Loss 11.6681\n",
      "Epoch 14/200 Batch 8, Loss 11.4808\n",
      "Epoch 14/200 Batch 9, Loss 11.6014\n",
      "Epoch 14/200 Batch 10, Loss 11.6229\n",
      "Epoch 14/200 Batch 11, Loss 11.6393\n",
      "Epoch 14/200 Batch 12, Loss 11.6491\n",
      "Epoch 14/200 Batch 13, Loss 11.7777\n",
      "Epoch 14/200 Batch 14, Loss 11.6389\n",
      "Epoch 14/200 Batch 15, Loss 11.8172\n",
      "Epoch 14/200 Batch 16, Loss 11.6157\n",
      "Epoch 14/200 Batch 17, Loss 11.5801\n",
      "Epoch 14/200 Batch 18, Loss 11.5845\n",
      "Epoch 14/200 Batch 19, Loss 11.6994\n",
      "Epoch 15/200 Batch 0, Loss 11.5635\n",
      "Epoch 15/200 Batch 1, Loss 11.7099\n",
      "Epoch 15/200 Batch 2, Loss 11.6688\n",
      "Epoch 15/200 Batch 3, Loss 11.5491\n",
      "Epoch 15/200 Batch 4, Loss 11.6066\n",
      "Epoch 15/200 Batch 5, Loss 11.4442\n",
      "Epoch 15/200 Batch 6, Loss 11.5014\n",
      "Epoch 15/200 Batch 7, Loss 11.6757\n",
      "Epoch 15/200 Batch 8, Loss 11.5183\n",
      "Epoch 15/200 Batch 9, Loss 11.5468\n",
      "Epoch 15/200 Batch 10, Loss 11.6620\n",
      "Epoch 15/200 Batch 11, Loss 11.8063\n",
      "Epoch 15/200 Batch 12, Loss 11.5108\n",
      "Epoch 15/200 Batch 13, Loss 11.5804\n",
      "Epoch 15/200 Batch 14, Loss 11.7107\n",
      "Epoch 15/200 Batch 15, Loss 11.6623\n",
      "Epoch 15/200 Batch 16, Loss 11.6546\n",
      "Epoch 15/200 Batch 17, Loss 11.5606\n",
      "Epoch 15/200 Batch 18, Loss 11.6327\n",
      "Epoch 15/200 Batch 19, Loss 11.6323\n",
      "Epoch 16/200 Batch 0, Loss 11.5387\n",
      "Epoch 16/200 Batch 1, Loss 11.6222\n",
      "Epoch 16/200 Batch 2, Loss 11.5509\n",
      "Epoch 16/200 Batch 3, Loss 11.5406\n",
      "Epoch 16/200 Batch 4, Loss 11.6525\n",
      "Epoch 16/200 Batch 5, Loss 11.6151\n",
      "Epoch 16/200 Batch 6, Loss 11.4509\n",
      "Epoch 16/200 Batch 7, Loss 11.6295\n",
      "Epoch 16/200 Batch 8, Loss 11.7659\n",
      "Epoch 16/200 Batch 9, Loss 11.4991\n",
      "Epoch 16/200 Batch 10, Loss 11.5503\n",
      "Epoch 16/200 Batch 11, Loss 11.5710\n",
      "Epoch 16/200 Batch 12, Loss 11.5223\n",
      "Epoch 16/200 Batch 13, Loss 11.8051\n",
      "Epoch 16/200 Batch 14, Loss 11.6926\n",
      "Epoch 16/200 Batch 15, Loss 11.6269\n",
      "Epoch 16/200 Batch 16, Loss 11.5754\n",
      "Epoch 16/200 Batch 17, Loss 11.6662\n",
      "Epoch 16/200 Batch 18, Loss 11.8628\n",
      "Epoch 16/200 Batch 19, Loss 11.6811\n",
      "Epoch 17/200 Batch 0, Loss 11.5505\n",
      "Epoch 17/200 Batch 1, Loss 11.5959\n",
      "Epoch 17/200 Batch 2, Loss 11.4903\n",
      "Epoch 17/200 Batch 3, Loss 11.5735\n",
      "Epoch 17/200 Batch 4, Loss 11.6773\n",
      "Epoch 17/200 Batch 5, Loss 11.6488\n",
      "Epoch 17/200 Batch 6, Loss 11.6693\n",
      "Epoch 17/200 Batch 7, Loss 11.6325\n",
      "Epoch 17/200 Batch 8, Loss 11.6995\n",
      "Epoch 17/200 Batch 9, Loss 11.5793\n",
      "Epoch 17/200 Batch 10, Loss 11.4860\n",
      "Epoch 17/200 Batch 11, Loss 11.3607\n",
      "Epoch 17/200 Batch 12, Loss 11.6154\n",
      "Epoch 17/200 Batch 13, Loss 11.3457\n",
      "Epoch 17/200 Batch 14, Loss 11.5930\n",
      "Epoch 17/200 Batch 15, Loss 11.6549\n",
      "Epoch 17/200 Batch 16, Loss 11.4890\n",
      "Epoch 17/200 Batch 17, Loss 11.7775\n",
      "Epoch 17/200 Batch 18, Loss 11.5063\n",
      "Epoch 17/200 Batch 19, Loss 11.5554\n",
      "Epoch 18/200 Batch 0, Loss 11.5012\n",
      "Epoch 18/200 Batch 1, Loss 11.6211\n",
      "Epoch 18/200 Batch 2, Loss 11.6149\n",
      "Epoch 18/200 Batch 3, Loss 11.6257\n",
      "Epoch 18/200 Batch 4, Loss 11.6395\n",
      "Epoch 18/200 Batch 5, Loss 11.5336\n",
      "Epoch 18/200 Batch 6, Loss 11.5229\n",
      "Epoch 18/200 Batch 7, Loss 11.4211\n",
      "Epoch 18/200 Batch 8, Loss 11.4445\n",
      "Epoch 18/200 Batch 9, Loss 11.7862\n",
      "Epoch 18/200 Batch 10, Loss 11.6420\n",
      "Epoch 18/200 Batch 11, Loss 11.5061\n",
      "Epoch 18/200 Batch 12, Loss 11.4756\n",
      "Epoch 18/200 Batch 13, Loss 11.6871\n",
      "Epoch 18/200 Batch 14, Loss 11.5548\n",
      "Epoch 18/200 Batch 15, Loss 11.4443\n",
      "Epoch 18/200 Batch 16, Loss 11.5517\n",
      "Epoch 18/200 Batch 17, Loss 11.5532\n",
      "Epoch 18/200 Batch 18, Loss 11.5673\n",
      "Epoch 18/200 Batch 19, Loss 11.5210\n",
      "Epoch 19/200 Batch 0, Loss 11.3636\n",
      "Epoch 19/200 Batch 1, Loss 11.6222\n",
      "Epoch 19/200 Batch 2, Loss 11.4979\n",
      "Epoch 19/200 Batch 3, Loss 11.6771\n",
      "Epoch 19/200 Batch 4, Loss 11.5400\n",
      "Epoch 19/200 Batch 5, Loss 11.6357\n",
      "Epoch 19/200 Batch 6, Loss 11.6548\n",
      "Epoch 19/200 Batch 7, Loss 11.4731\n",
      "Epoch 19/200 Batch 8, Loss 11.5469\n",
      "Epoch 19/200 Batch 9, Loss 11.7669\n",
      "Epoch 19/200 Batch 10, Loss 11.5348\n",
      "Epoch 19/200 Batch 11, Loss 11.4601\n",
      "Epoch 19/200 Batch 12, Loss 11.6776\n",
      "Epoch 19/200 Batch 13, Loss 11.5778\n",
      "Epoch 19/200 Batch 14, Loss 11.5982\n",
      "Epoch 19/200 Batch 15, Loss 11.5001\n",
      "Epoch 19/200 Batch 16, Loss 11.5555\n",
      "Epoch 19/200 Batch 17, Loss 11.5711\n",
      "Epoch 19/200 Batch 18, Loss 11.5099\n",
      "Epoch 19/200 Batch 19, Loss 11.2209\n",
      "Epoch 20/200 Batch 0, Loss 11.5655\n",
      "Epoch 20/200 Batch 1, Loss 11.4743\n",
      "Epoch 20/200 Batch 2, Loss 11.3933\n",
      "Epoch 20/200 Batch 3, Loss 11.6306\n",
      "Epoch 20/200 Batch 4, Loss 11.4809\n",
      "Epoch 20/200 Batch 5, Loss 11.5315\n",
      "Epoch 20/200 Batch 6, Loss 11.3747\n",
      "Epoch 20/200 Batch 7, Loss 11.5461\n",
      "Epoch 20/200 Batch 8, Loss 11.3988\n",
      "Epoch 20/200 Batch 9, Loss 11.4785\n",
      "Epoch 20/200 Batch 10, Loss 11.5864\n",
      "Epoch 20/200 Batch 11, Loss 11.4910\n",
      "Epoch 20/200 Batch 12, Loss 11.5067\n",
      "Epoch 20/200 Batch 13, Loss 11.5930\n",
      "Epoch 20/200 Batch 14, Loss 11.4196\n",
      "Epoch 20/200 Batch 15, Loss 11.5418\n",
      "Epoch 20/200 Batch 16, Loss 11.6250\n",
      "Epoch 20/200 Batch 17, Loss 11.6077\n",
      "Epoch 20/200 Batch 18, Loss 11.7390\n",
      "Epoch 20/200 Batch 19, Loss 11.4523\n",
      "Epoch 21/200 Batch 0, Loss 11.5553\n",
      "Epoch 21/200 Batch 1, Loss 11.7550\n",
      "Epoch 21/200 Batch 2, Loss 11.4035\n",
      "Epoch 21/200 Batch 3, Loss 11.4910\n",
      "Epoch 21/200 Batch 4, Loss 11.5091\n",
      "Epoch 21/200 Batch 5, Loss 11.4457\n",
      "Epoch 21/200 Batch 6, Loss 11.4504\n",
      "Epoch 21/200 Batch 7, Loss 11.7683\n",
      "Epoch 21/200 Batch 8, Loss 11.4153\n",
      "Epoch 21/200 Batch 9, Loss 11.4527\n",
      "Epoch 21/200 Batch 10, Loss 11.5363\n",
      "Epoch 21/200 Batch 11, Loss 11.5545\n",
      "Epoch 21/200 Batch 12, Loss 11.4138\n",
      "Epoch 21/200 Batch 13, Loss 11.6164\n",
      "Epoch 21/200 Batch 14, Loss 11.6023\n",
      "Epoch 21/200 Batch 15, Loss 11.5634\n",
      "Epoch 21/200 Batch 16, Loss 11.6625\n",
      "Epoch 21/200 Batch 17, Loss 11.4861\n",
      "Epoch 21/200 Batch 18, Loss 11.4997\n",
      "Epoch 21/200 Batch 19, Loss 11.5212\n",
      "Epoch 22/200 Batch 0, Loss 11.3627\n",
      "Epoch 22/200 Batch 1, Loss 11.5579\n",
      "Epoch 22/200 Batch 2, Loss 11.3654\n",
      "Epoch 22/200 Batch 3, Loss 11.4452\n",
      "Epoch 22/200 Batch 4, Loss 11.3812\n",
      "Epoch 22/200 Batch 5, Loss 11.5159\n",
      "Epoch 22/200 Batch 6, Loss 11.5994\n",
      "Epoch 22/200 Batch 7, Loss 11.7129\n",
      "Epoch 22/200 Batch 8, Loss 11.6469\n",
      "Epoch 22/200 Batch 9, Loss 11.5772\n",
      "Epoch 22/200 Batch 10, Loss 11.4143\n",
      "Epoch 22/200 Batch 11, Loss 11.4848\n",
      "Epoch 22/200 Batch 12, Loss 11.4166\n",
      "Epoch 22/200 Batch 13, Loss 11.5867\n",
      "Epoch 22/200 Batch 14, Loss 11.5220\n",
      "Epoch 22/200 Batch 15, Loss 11.7779\n",
      "Epoch 22/200 Batch 16, Loss 11.4603\n",
      "Epoch 22/200 Batch 17, Loss 11.5160\n",
      "Epoch 22/200 Batch 18, Loss 11.7065\n",
      "Epoch 22/200 Batch 19, Loss 11.5260\n",
      "Epoch 23/200 Batch 0, Loss 11.5295\n",
      "Epoch 23/200 Batch 1, Loss 11.4137\n",
      "Epoch 23/200 Batch 2, Loss 11.5041\n",
      "Epoch 23/200 Batch 3, Loss 11.4051\n",
      "Epoch 23/200 Batch 4, Loss 11.4551\n",
      "Epoch 23/200 Batch 5, Loss 11.4229\n",
      "Epoch 23/200 Batch 6, Loss 11.4914\n",
      "Epoch 23/200 Batch 7, Loss 11.5225\n",
      "Epoch 23/200 Batch 8, Loss 11.5662\n",
      "Epoch 23/200 Batch 9, Loss 11.5674\n",
      "Epoch 23/200 Batch 10, Loss 11.5215\n",
      "Epoch 23/200 Batch 11, Loss 11.4366\n",
      "Epoch 23/200 Batch 12, Loss 11.4810\n",
      "Epoch 23/200 Batch 13, Loss 11.4157\n",
      "Epoch 23/200 Batch 14, Loss 11.4937\n",
      "Epoch 23/200 Batch 15, Loss 11.5860\n",
      "Epoch 23/200 Batch 16, Loss 11.5459\n",
      "Epoch 23/200 Batch 17, Loss 11.7201\n",
      "Epoch 23/200 Batch 18, Loss 11.4317\n",
      "Epoch 23/200 Batch 19, Loss 11.5200\n",
      "Epoch 24/200 Batch 0, Loss 11.5091\n",
      "Epoch 24/200 Batch 1, Loss 11.5466\n",
      "Epoch 24/200 Batch 2, Loss 11.5888\n",
      "Epoch 24/200 Batch 3, Loss 11.5113\n",
      "Epoch 24/200 Batch 4, Loss 11.4857\n",
      "Epoch 24/200 Batch 5, Loss 11.3278\n",
      "Epoch 24/200 Batch 6, Loss 11.5516\n",
      "Epoch 24/200 Batch 7, Loss 11.4424\n",
      "Epoch 24/200 Batch 8, Loss 11.5194\n",
      "Epoch 24/200 Batch 9, Loss 11.4931\n",
      "Epoch 24/200 Batch 10, Loss 11.5165\n",
      "Epoch 24/200 Batch 11, Loss 11.5906\n",
      "Epoch 24/200 Batch 12, Loss 11.3932\n",
      "Epoch 24/200 Batch 13, Loss 11.3384\n",
      "Epoch 24/200 Batch 14, Loss 11.5277\n",
      "Epoch 24/200 Batch 15, Loss 11.4068\n",
      "Epoch 24/200 Batch 16, Loss 11.5176\n",
      "Epoch 24/200 Batch 17, Loss 11.3979\n",
      "Epoch 24/200 Batch 18, Loss 11.4983\n",
      "Epoch 24/200 Batch 19, Loss 11.5011\n",
      "Epoch 25/200 Batch 0, Loss 11.4478\n",
      "Epoch 25/200 Batch 1, Loss 11.5687\n",
      "Epoch 25/200 Batch 2, Loss 11.6083\n",
      "Epoch 25/200 Batch 3, Loss 11.4085\n",
      "Epoch 25/200 Batch 4, Loss 11.5291\n",
      "Epoch 25/200 Batch 5, Loss 11.5397\n",
      "Epoch 25/200 Batch 6, Loss 11.4801\n",
      "Epoch 25/200 Batch 7, Loss 11.3002\n",
      "Epoch 25/200 Batch 8, Loss 11.5865\n",
      "Epoch 25/200 Batch 9, Loss 11.4895\n",
      "Epoch 25/200 Batch 10, Loss 11.4650\n",
      "Epoch 25/200 Batch 11, Loss 11.5660\n",
      "Epoch 25/200 Batch 12, Loss 11.5840\n",
      "Epoch 25/200 Batch 13, Loss 11.4363\n",
      "Epoch 25/200 Batch 14, Loss 11.4394\n",
      "Epoch 25/200 Batch 15, Loss 11.3661\n",
      "Epoch 25/200 Batch 16, Loss 11.4216\n",
      "Epoch 25/200 Batch 17, Loss 11.5837\n",
      "Epoch 25/200 Batch 18, Loss 11.5619\n",
      "Epoch 25/200 Batch 19, Loss 11.2689\n",
      "Epoch 26/200 Batch 0, Loss 11.4069\n",
      "Epoch 26/200 Batch 1, Loss 11.3713\n",
      "Epoch 26/200 Batch 2, Loss 11.5494\n",
      "Epoch 26/200 Batch 3, Loss 11.6563\n",
      "Epoch 26/200 Batch 4, Loss 11.2577\n",
      "Epoch 26/200 Batch 5, Loss 11.2967\n",
      "Epoch 26/200 Batch 6, Loss 11.4360\n",
      "Epoch 26/200 Batch 7, Loss 11.4546\n",
      "Epoch 26/200 Batch 8, Loss 11.3927\n",
      "Epoch 26/200 Batch 9, Loss 11.5378\n",
      "Epoch 26/200 Batch 10, Loss 11.5026\n",
      "Epoch 26/200 Batch 11, Loss 11.3924\n",
      "Epoch 26/200 Batch 12, Loss 11.4471\n",
      "Epoch 26/200 Batch 13, Loss 11.7584\n",
      "Epoch 26/200 Batch 14, Loss 11.5036\n",
      "Epoch 26/200 Batch 15, Loss 11.5868\n",
      "Epoch 26/200 Batch 16, Loss 11.5664\n",
      "Epoch 26/200 Batch 17, Loss 11.6700\n",
      "Epoch 26/200 Batch 18, Loss 11.5153\n",
      "Epoch 26/200 Batch 19, Loss 11.5199\n",
      "Epoch 27/200 Batch 0, Loss 11.5490\n",
      "Epoch 27/200 Batch 1, Loss 11.5084\n",
      "Epoch 27/200 Batch 2, Loss 11.5493\n",
      "Epoch 27/200 Batch 3, Loss 11.3881\n",
      "Epoch 27/200 Batch 4, Loss 11.5418\n",
      "Epoch 27/200 Batch 5, Loss 11.4938\n",
      "Epoch 27/200 Batch 6, Loss 11.3388\n",
      "Epoch 27/200 Batch 7, Loss 11.3276\n",
      "Epoch 27/200 Batch 8, Loss 11.6243\n",
      "Epoch 27/200 Batch 9, Loss 11.4409\n",
      "Epoch 27/200 Batch 10, Loss 11.5432\n",
      "Epoch 27/200 Batch 11, Loss 11.4402\n",
      "Epoch 27/200 Batch 12, Loss 11.5002\n",
      "Epoch 27/200 Batch 13, Loss 11.4316\n",
      "Epoch 27/200 Batch 14, Loss 11.4263\n",
      "Epoch 27/200 Batch 15, Loss 11.5826\n",
      "Epoch 27/200 Batch 16, Loss 11.3477\n",
      "Epoch 27/200 Batch 17, Loss 11.5445\n",
      "Epoch 27/200 Batch 18, Loss 11.3717\n",
      "Epoch 27/200 Batch 19, Loss 11.3751\n",
      "Epoch 28/200 Batch 0, Loss 11.5737\n",
      "Epoch 28/200 Batch 1, Loss 11.4879\n",
      "Epoch 28/200 Batch 2, Loss 11.4003\n",
      "Epoch 28/200 Batch 3, Loss 11.5263\n",
      "Epoch 28/200 Batch 4, Loss 11.3699\n",
      "Epoch 28/200 Batch 5, Loss 11.6432\n",
      "Epoch 28/200 Batch 6, Loss 11.5044\n",
      "Epoch 28/200 Batch 7, Loss 11.4510\n",
      "Epoch 28/200 Batch 8, Loss 11.5681\n",
      "Epoch 28/200 Batch 9, Loss 11.3162\n",
      "Epoch 28/200 Batch 10, Loss 11.5715\n",
      "Epoch 28/200 Batch 11, Loss 11.5573\n",
      "Epoch 28/200 Batch 12, Loss 11.6003\n",
      "Epoch 28/200 Batch 13, Loss 11.3937\n",
      "Epoch 28/200 Batch 14, Loss 11.2476\n",
      "Epoch 28/200 Batch 15, Loss 11.5167\n",
      "Epoch 28/200 Batch 16, Loss 11.5242\n",
      "Epoch 28/200 Batch 17, Loss 11.3156\n",
      "Epoch 28/200 Batch 18, Loss 11.3959\n",
      "Epoch 28/200 Batch 19, Loss 11.4875\n",
      "Epoch 29/200 Batch 0, Loss 11.6546\n",
      "Epoch 29/200 Batch 1, Loss 11.5668\n",
      "Epoch 29/200 Batch 2, Loss 11.6622\n",
      "Epoch 29/200 Batch 3, Loss 11.5149\n",
      "Epoch 29/200 Batch 4, Loss 11.4402\n",
      "Epoch 29/200 Batch 5, Loss 11.4784\n",
      "Epoch 29/200 Batch 6, Loss 11.4546\n",
      "Epoch 29/200 Batch 7, Loss 11.4687\n",
      "Epoch 29/200 Batch 8, Loss 11.5390\n",
      "Epoch 29/200 Batch 9, Loss 11.3882\n",
      "Epoch 29/200 Batch 10, Loss 11.1290\n",
      "Epoch 29/200 Batch 11, Loss 11.4716\n",
      "Epoch 29/200 Batch 12, Loss 11.8255\n",
      "Epoch 29/200 Batch 13, Loss 11.4174\n",
      "Epoch 29/200 Batch 14, Loss 11.4741\n",
      "Epoch 29/200 Batch 15, Loss 11.4514\n",
      "Epoch 29/200 Batch 16, Loss 11.3904\n",
      "Epoch 29/200 Batch 17, Loss 11.3626\n",
      "Epoch 29/200 Batch 18, Loss 11.3616\n",
      "Epoch 29/200 Batch 19, Loss 11.5238\n",
      "Epoch 30/200 Batch 0, Loss 11.3657\n",
      "Epoch 30/200 Batch 1, Loss 11.4125\n",
      "Epoch 30/200 Batch 2, Loss 11.3609\n",
      "Epoch 30/200 Batch 3, Loss 11.3413\n",
      "Epoch 30/200 Batch 4, Loss 11.5646\n",
      "Epoch 30/200 Batch 5, Loss 11.3447\n",
      "Epoch 30/200 Batch 6, Loss 11.4534\n",
      "Epoch 30/200 Batch 7, Loss 11.4127\n",
      "Epoch 30/200 Batch 8, Loss 11.5791\n",
      "Epoch 30/200 Batch 9, Loss 11.6502\n",
      "Epoch 30/200 Batch 10, Loss 11.2758\n",
      "Epoch 30/200 Batch 11, Loss 11.5590\n",
      "Epoch 30/200 Batch 12, Loss 11.4966\n",
      "Epoch 30/200 Batch 13, Loss 11.5194\n",
      "Epoch 30/200 Batch 14, Loss 11.5290\n",
      "Epoch 30/200 Batch 15, Loss 11.4841\n",
      "Epoch 30/200 Batch 16, Loss 11.7437\n",
      "Epoch 30/200 Batch 17, Loss 11.3864\n",
      "Epoch 30/200 Batch 18, Loss 11.4369\n",
      "Epoch 30/200 Batch 19, Loss 11.5698\n",
      "Epoch 31/200 Batch 0, Loss 11.4224\n",
      "Epoch 31/200 Batch 1, Loss 11.6763\n",
      "Epoch 31/200 Batch 2, Loss 11.5128\n",
      "Epoch 31/200 Batch 3, Loss 11.3609\n",
      "Epoch 31/200 Batch 4, Loss 11.3538\n",
      "Epoch 31/200 Batch 5, Loss 11.5419\n",
      "Epoch 31/200 Batch 6, Loss 11.4712\n",
      "Epoch 31/200 Batch 7, Loss 11.4622\n",
      "Epoch 31/200 Batch 8, Loss 11.3262\n",
      "Epoch 31/200 Batch 9, Loss 11.4801\n",
      "Epoch 31/200 Batch 10, Loss 11.4029\n",
      "Epoch 31/200 Batch 11, Loss 11.7309\n",
      "Epoch 31/200 Batch 12, Loss 11.4660\n",
      "Epoch 31/200 Batch 13, Loss 11.4510\n",
      "Epoch 31/200 Batch 14, Loss 11.4672\n",
      "Epoch 31/200 Batch 15, Loss 11.4078\n",
      "Epoch 31/200 Batch 16, Loss 11.4109\n",
      "Epoch 31/200 Batch 17, Loss 11.5587\n",
      "Epoch 31/200 Batch 18, Loss 11.4629\n",
      "Epoch 31/200 Batch 19, Loss 11.3973\n",
      "Epoch 32/200 Batch 0, Loss 11.3824\n",
      "Epoch 32/200 Batch 1, Loss 11.2958\n",
      "Epoch 32/200 Batch 2, Loss 11.3736\n",
      "Epoch 32/200 Batch 3, Loss 11.5328\n",
      "Epoch 32/200 Batch 4, Loss 11.3693\n",
      "Epoch 32/200 Batch 5, Loss 11.4124\n",
      "Epoch 32/200 Batch 6, Loss 11.4184\n",
      "Epoch 32/200 Batch 7, Loss 11.5947\n",
      "Epoch 32/200 Batch 8, Loss 11.5903\n",
      "Epoch 32/200 Batch 9, Loss 11.4237\n",
      "Epoch 32/200 Batch 10, Loss 11.6153\n",
      "Epoch 32/200 Batch 11, Loss 11.3817\n",
      "Epoch 32/200 Batch 12, Loss 11.3957\n",
      "Epoch 32/200 Batch 13, Loss 11.3901\n",
      "Epoch 32/200 Batch 14, Loss 11.5082\n",
      "Epoch 32/200 Batch 15, Loss 11.3498\n",
      "Epoch 32/200 Batch 16, Loss 11.4394\n",
      "Epoch 32/200 Batch 17, Loss 11.5803\n",
      "Epoch 32/200 Batch 18, Loss 11.4920\n",
      "Epoch 32/200 Batch 19, Loss 11.6102\n",
      "Epoch 33/200 Batch 0, Loss 11.5285\n",
      "Epoch 33/200 Batch 1, Loss 11.4230\n",
      "Epoch 33/200 Batch 2, Loss 11.3240\n",
      "Epoch 33/200 Batch 3, Loss 11.4716\n",
      "Epoch 33/200 Batch 4, Loss 11.4224\n",
      "Epoch 33/200 Batch 5, Loss 11.4184\n",
      "Epoch 33/200 Batch 6, Loss 11.4654\n",
      "Epoch 33/200 Batch 7, Loss 11.5555\n",
      "Epoch 33/200 Batch 8, Loss 11.3239\n",
      "Epoch 33/200 Batch 9, Loss 11.3308\n",
      "Epoch 33/200 Batch 10, Loss 11.5194\n",
      "Epoch 33/200 Batch 11, Loss 11.3209\n",
      "Epoch 33/200 Batch 12, Loss 11.4443\n",
      "Epoch 33/200 Batch 13, Loss 11.4099\n",
      "Epoch 33/200 Batch 14, Loss 11.4926\n",
      "Epoch 33/200 Batch 15, Loss 11.4170\n",
      "Epoch 33/200 Batch 16, Loss 11.3127\n",
      "Epoch 33/200 Batch 17, Loss 11.5421\n",
      "Epoch 33/200 Batch 18, Loss 11.6048\n",
      "Epoch 33/200 Batch 19, Loss 11.4841\n",
      "Epoch 34/200 Batch 0, Loss 11.4767\n",
      "Epoch 34/200 Batch 1, Loss 11.3449\n",
      "Epoch 34/200 Batch 2, Loss 11.4729\n",
      "Epoch 34/200 Batch 3, Loss 11.5279\n",
      "Epoch 34/200 Batch 4, Loss 11.6748\n",
      "Epoch 34/200 Batch 5, Loss 11.2722\n",
      "Epoch 34/200 Batch 6, Loss 11.5031\n",
      "Epoch 34/200 Batch 7, Loss 11.4506\n",
      "Epoch 34/200 Batch 8, Loss 11.5894\n",
      "Epoch 34/200 Batch 9, Loss 11.3981\n",
      "Epoch 34/200 Batch 10, Loss 11.5022\n",
      "Epoch 34/200 Batch 11, Loss 11.3727\n",
      "Epoch 34/200 Batch 12, Loss 11.4495\n",
      "Epoch 34/200 Batch 13, Loss 11.3701\n",
      "Epoch 34/200 Batch 14, Loss 11.2517\n",
      "Epoch 34/200 Batch 15, Loss 11.3109\n",
      "Epoch 34/200 Batch 16, Loss 11.4116\n",
      "Epoch 34/200 Batch 17, Loss 11.2188\n",
      "Epoch 34/200 Batch 18, Loss 11.6660\n",
      "Epoch 34/200 Batch 19, Loss 11.4148\n",
      "Epoch 35/200 Batch 0, Loss 11.3707\n",
      "Epoch 35/200 Batch 1, Loss 11.4081\n",
      "Epoch 35/200 Batch 2, Loss 11.2549\n",
      "Epoch 35/200 Batch 3, Loss 11.3732\n",
      "Epoch 35/200 Batch 4, Loss 11.4039\n",
      "Epoch 35/200 Batch 5, Loss 11.5077\n",
      "Epoch 35/200 Batch 6, Loss 11.5359\n",
      "Epoch 35/200 Batch 7, Loss 11.5637\n",
      "Epoch 35/200 Batch 8, Loss 11.4551\n",
      "Epoch 35/200 Batch 9, Loss 11.5091\n",
      "Epoch 35/200 Batch 10, Loss 11.5021\n",
      "Epoch 35/200 Batch 11, Loss 11.5537\n",
      "Epoch 35/200 Batch 12, Loss 11.4929\n",
      "Epoch 35/200 Batch 13, Loss 11.4567\n",
      "Epoch 35/200 Batch 14, Loss 11.5236\n",
      "Epoch 35/200 Batch 15, Loss 11.2317\n",
      "Epoch 35/200 Batch 16, Loss 11.3567\n",
      "Epoch 35/200 Batch 17, Loss 11.5161\n",
      "Epoch 35/200 Batch 18, Loss 11.3568\n",
      "Epoch 35/200 Batch 19, Loss 11.4932\n",
      "Epoch 36/200 Batch 0, Loss 11.2622\n",
      "Epoch 36/200 Batch 1, Loss 11.4548\n",
      "Epoch 36/200 Batch 2, Loss 11.3122\n",
      "Epoch 36/200 Batch 3, Loss 11.5420\n",
      "Epoch 36/200 Batch 4, Loss 11.5064\n",
      "Epoch 36/200 Batch 5, Loss 11.3740\n",
      "Epoch 36/200 Batch 6, Loss 11.5477\n",
      "Epoch 36/200 Batch 7, Loss 11.5412\n",
      "Epoch 36/200 Batch 8, Loss 11.2818\n",
      "Epoch 36/200 Batch 9, Loss 11.3962\n",
      "Epoch 36/200 Batch 10, Loss 11.5282\n",
      "Epoch 36/200 Batch 11, Loss 11.6259\n",
      "Epoch 36/200 Batch 12, Loss 11.3314\n",
      "Epoch 36/200 Batch 13, Loss 11.2340\n",
      "Epoch 36/200 Batch 14, Loss 11.4522\n",
      "Epoch 36/200 Batch 15, Loss 11.3823\n",
      "Epoch 36/200 Batch 16, Loss 11.4962\n",
      "Epoch 36/200 Batch 17, Loss 11.4758\n",
      "Epoch 36/200 Batch 18, Loss 11.3903\n",
      "Epoch 36/200 Batch 19, Loss 11.5013\n",
      "Epoch 37/200 Batch 0, Loss 11.5691\n",
      "Epoch 37/200 Batch 1, Loss 11.3274\n",
      "Epoch 37/200 Batch 2, Loss 11.5052\n",
      "Epoch 37/200 Batch 3, Loss 11.5015\n",
      "Epoch 37/200 Batch 4, Loss 11.3200\n",
      "Epoch 37/200 Batch 5, Loss 11.2605\n",
      "Epoch 37/200 Batch 6, Loss 11.5841\n",
      "Epoch 37/200 Batch 7, Loss 11.2520\n",
      "Epoch 37/200 Batch 8, Loss 11.3864\n",
      "Epoch 37/200 Batch 9, Loss 11.3734\n",
      "Epoch 37/200 Batch 10, Loss 11.4561\n",
      "Epoch 37/200 Batch 11, Loss 11.3875\n",
      "Epoch 37/200 Batch 12, Loss 11.3816\n",
      "Epoch 37/200 Batch 13, Loss 11.5439\n",
      "Epoch 37/200 Batch 14, Loss 11.4049\n",
      "Epoch 37/200 Batch 15, Loss 11.5784\n",
      "Epoch 37/200 Batch 16, Loss 11.4371\n",
      "Epoch 37/200 Batch 17, Loss 11.4739\n",
      "Epoch 37/200 Batch 18, Loss 11.3876\n",
      "Epoch 37/200 Batch 19, Loss 11.3665\n",
      "Epoch 38/200 Batch 0, Loss 11.3320\n",
      "Epoch 38/200 Batch 1, Loss 11.5157\n",
      "Epoch 38/200 Batch 2, Loss 11.5631\n",
      "Epoch 38/200 Batch 3, Loss 11.5535\n",
      "Epoch 38/200 Batch 4, Loss 11.4105\n",
      "Epoch 38/200 Batch 5, Loss 11.2452\n",
      "Epoch 38/200 Batch 6, Loss 11.3939\n",
      "Epoch 38/200 Batch 7, Loss 11.3606\n",
      "Epoch 38/200 Batch 8, Loss 11.4822\n",
      "Epoch 38/200 Batch 9, Loss 11.4521\n",
      "Epoch 38/200 Batch 10, Loss 11.4960\n",
      "Epoch 38/200 Batch 11, Loss 11.3928\n",
      "Epoch 38/200 Batch 12, Loss 11.3049\n",
      "Epoch 38/200 Batch 13, Loss 11.4674\n",
      "Epoch 38/200 Batch 14, Loss 11.4597\n",
      "Epoch 38/200 Batch 15, Loss 11.5843\n",
      "Epoch 38/200 Batch 16, Loss 11.2936\n",
      "Epoch 38/200 Batch 17, Loss 11.4001\n",
      "Epoch 38/200 Batch 18, Loss 11.3923\n",
      "Epoch 38/200 Batch 19, Loss 11.5702\n",
      "Epoch 39/200 Batch 0, Loss 11.3679\n",
      "Epoch 39/200 Batch 1, Loss 11.3372\n",
      "Epoch 39/200 Batch 2, Loss 11.5034\n",
      "Epoch 39/200 Batch 3, Loss 11.5419\n",
      "Epoch 39/200 Batch 4, Loss 11.3164\n",
      "Epoch 39/200 Batch 5, Loss 11.3800\n",
      "Epoch 39/200 Batch 6, Loss 11.4497\n",
      "Epoch 39/200 Batch 7, Loss 11.7076\n",
      "Epoch 39/200 Batch 8, Loss 11.4461\n",
      "Epoch 39/200 Batch 9, Loss 11.3743\n",
      "Epoch 39/200 Batch 10, Loss 11.3882\n",
      "Epoch 39/200 Batch 11, Loss 11.3197\n",
      "Epoch 39/200 Batch 12, Loss 11.4214\n",
      "Epoch 39/200 Batch 13, Loss 11.3937\n",
      "Epoch 39/200 Batch 14, Loss 11.2430\n",
      "Epoch 39/200 Batch 15, Loss 11.4181\n",
      "Epoch 39/200 Batch 16, Loss 11.3745\n",
      "Epoch 39/200 Batch 17, Loss 11.3753\n",
      "Epoch 39/200 Batch 18, Loss 11.3251\n",
      "Epoch 39/200 Batch 19, Loss 11.6360\n",
      "Epoch 40/200 Batch 0, Loss 11.3979\n",
      "Epoch 40/200 Batch 1, Loss 11.4166\n",
      "Epoch 40/200 Batch 2, Loss 11.4638\n",
      "Epoch 40/200 Batch 3, Loss 11.3915\n",
      "Epoch 40/200 Batch 4, Loss 11.4748\n",
      "Epoch 40/200 Batch 5, Loss 11.2856\n",
      "Epoch 40/200 Batch 6, Loss 11.2236\n",
      "Epoch 40/200 Batch 7, Loss 11.4878\n",
      "Epoch 40/200 Batch 8, Loss 11.1771\n",
      "Epoch 40/200 Batch 9, Loss 11.3564\n",
      "Epoch 40/200 Batch 10, Loss 11.5229\n",
      "Epoch 40/200 Batch 11, Loss 11.3807\n",
      "Epoch 40/200 Batch 12, Loss 11.5315\n",
      "Epoch 40/200 Batch 13, Loss 11.3940\n",
      "Epoch 40/200 Batch 14, Loss 11.5237\n",
      "Epoch 40/200 Batch 15, Loss 11.6553\n",
      "Epoch 40/200 Batch 16, Loss 11.2004\n",
      "Epoch 40/200 Batch 17, Loss 11.3516\n",
      "Epoch 40/200 Batch 18, Loss 11.4740\n",
      "Epoch 40/200 Batch 19, Loss 11.0405\n",
      "Epoch 41/200 Batch 0, Loss 11.2889\n",
      "Epoch 41/200 Batch 1, Loss 11.3862\n",
      "Epoch 41/200 Batch 2, Loss 11.3244\n",
      "Epoch 41/200 Batch 3, Loss 11.3691\n",
      "Epoch 41/200 Batch 4, Loss 11.4852\n",
      "Epoch 41/200 Batch 5, Loss 11.3952\n",
      "Epoch 41/200 Batch 6, Loss 11.3736\n",
      "Epoch 41/200 Batch 7, Loss 11.3698\n",
      "Epoch 41/200 Batch 8, Loss 11.4194\n",
      "Epoch 41/200 Batch 9, Loss 11.5859\n",
      "Epoch 41/200 Batch 10, Loss 11.2859\n",
      "Epoch 41/200 Batch 11, Loss 11.4654\n",
      "Epoch 41/200 Batch 12, Loss 11.4104\n",
      "Epoch 41/200 Batch 13, Loss 11.4690\n",
      "Epoch 41/200 Batch 14, Loss 11.5655\n",
      "Epoch 41/200 Batch 15, Loss 11.4988\n",
      "Epoch 41/200 Batch 16, Loss 11.3199\n",
      "Epoch 41/200 Batch 17, Loss 11.5890\n",
      "Epoch 41/200 Batch 18, Loss 11.4676\n",
      "Epoch 41/200 Batch 19, Loss 11.4018\n",
      "Epoch 42/200 Batch 0, Loss 11.4836\n",
      "Epoch 42/200 Batch 1, Loss 11.3931\n",
      "Epoch 42/200 Batch 2, Loss 11.3410\n",
      "Epoch 42/200 Batch 3, Loss 11.4903\n",
      "Epoch 42/200 Batch 4, Loss 11.3032\n",
      "Epoch 42/200 Batch 5, Loss 11.4615\n",
      "Epoch 42/200 Batch 6, Loss 11.5454\n",
      "Epoch 42/200 Batch 7, Loss 11.3402\n",
      "Epoch 42/200 Batch 8, Loss 11.5931\n",
      "Epoch 42/200 Batch 9, Loss 11.3138\n",
      "Epoch 42/200 Batch 10, Loss 11.5144\n",
      "Epoch 42/200 Batch 11, Loss 11.1739\n",
      "Epoch 42/200 Batch 12, Loss 11.5821\n",
      "Epoch 42/200 Batch 13, Loss 11.1034\n",
      "Epoch 42/200 Batch 14, Loss 11.3204\n",
      "Epoch 42/200 Batch 15, Loss 11.4997\n",
      "Epoch 42/200 Batch 16, Loss 11.4778\n",
      "Epoch 42/200 Batch 17, Loss 11.3740\n",
      "Epoch 42/200 Batch 18, Loss 11.5592\n",
      "Epoch 42/200 Batch 19, Loss 11.4781\n",
      "Epoch 43/200 Batch 0, Loss 11.2938\n",
      "Epoch 43/200 Batch 1, Loss 11.2653\n",
      "Epoch 43/200 Batch 2, Loss 11.4012\n",
      "Epoch 43/200 Batch 3, Loss 11.3790\n",
      "Epoch 43/200 Batch 4, Loss 11.4945\n",
      "Epoch 43/200 Batch 5, Loss 11.3698\n",
      "Epoch 43/200 Batch 6, Loss 11.5444\n",
      "Epoch 43/200 Batch 7, Loss 11.3927\n",
      "Epoch 43/200 Batch 8, Loss 11.4519\n",
      "Epoch 43/200 Batch 9, Loss 11.3936\n",
      "Epoch 43/200 Batch 10, Loss 11.3931\n",
      "Epoch 43/200 Batch 11, Loss 11.2340\n",
      "Epoch 43/200 Batch 12, Loss 11.3396\n",
      "Epoch 43/200 Batch 13, Loss 11.5576\n",
      "Epoch 43/200 Batch 14, Loss 11.4931\n",
      "Epoch 43/200 Batch 15, Loss 11.4851\n",
      "Epoch 43/200 Batch 16, Loss 11.4594\n",
      "Epoch 43/200 Batch 17, Loss 11.4726\n",
      "Epoch 43/200 Batch 18, Loss 11.4875\n",
      "Epoch 43/200 Batch 19, Loss 11.6727\n",
      "Epoch 44/200 Batch 0, Loss 11.4447\n",
      "Epoch 44/200 Batch 1, Loss 11.4367\n",
      "Epoch 44/200 Batch 2, Loss 11.3565\n",
      "Epoch 44/200 Batch 3, Loss 11.5469\n",
      "Epoch 44/200 Batch 4, Loss 11.2857\n",
      "Epoch 44/200 Batch 5, Loss 11.2644\n",
      "Epoch 44/200 Batch 6, Loss 11.3563\n",
      "Epoch 44/200 Batch 7, Loss 11.4324\n",
      "Epoch 44/200 Batch 8, Loss 11.3339\n",
      "Epoch 44/200 Batch 9, Loss 11.4964\n",
      "Epoch 44/200 Batch 10, Loss 11.4436\n",
      "Epoch 44/200 Batch 11, Loss 11.2650\n",
      "Epoch 44/200 Batch 12, Loss 11.4451\n",
      "Epoch 44/200 Batch 13, Loss 11.4142\n",
      "Epoch 44/200 Batch 14, Loss 11.3675\n",
      "Epoch 44/200 Batch 15, Loss 11.3428\n",
      "Epoch 44/200 Batch 16, Loss 11.4109\n",
      "Epoch 44/200 Batch 17, Loss 11.5131\n",
      "Epoch 44/200 Batch 18, Loss 11.5117\n",
      "Epoch 44/200 Batch 19, Loss 11.4378\n",
      "Epoch 45/200 Batch 0, Loss 11.3082\n",
      "Epoch 45/200 Batch 1, Loss 11.4468\n",
      "Epoch 45/200 Batch 2, Loss 11.3049\n",
      "Epoch 45/200 Batch 3, Loss 11.5520\n",
      "Epoch 45/200 Batch 4, Loss 11.3171\n",
      "Epoch 45/200 Batch 5, Loss 11.4776\n",
      "Epoch 45/200 Batch 6, Loss 11.3763\n",
      "Epoch 45/200 Batch 7, Loss 11.4647\n",
      "Epoch 45/200 Batch 8, Loss 11.3078\n",
      "Epoch 45/200 Batch 9, Loss 11.4235\n",
      "Epoch 45/200 Batch 10, Loss 11.4842\n",
      "Epoch 45/200 Batch 11, Loss 11.3904\n",
      "Epoch 45/200 Batch 12, Loss 11.4055\n",
      "Epoch 45/200 Batch 13, Loss 11.3526\n",
      "Epoch 45/200 Batch 14, Loss 11.3345\n",
      "Epoch 45/200 Batch 15, Loss 11.4899\n",
      "Epoch 45/200 Batch 16, Loss 11.4784\n",
      "Epoch 45/200 Batch 17, Loss 11.3733\n",
      "Epoch 45/200 Batch 18, Loss 11.4242\n",
      "Epoch 45/200 Batch 19, Loss 11.3091\n",
      "Epoch 46/200 Batch 0, Loss 11.4652\n",
      "Epoch 46/200 Batch 1, Loss 11.5610\n",
      "Epoch 46/200 Batch 2, Loss 11.2069\n",
      "Epoch 46/200 Batch 3, Loss 11.4167\n",
      "Epoch 46/200 Batch 4, Loss 11.2292\n",
      "Epoch 46/200 Batch 5, Loss 11.4044\n",
      "Epoch 46/200 Batch 6, Loss 11.3548\n",
      "Epoch 46/200 Batch 7, Loss 11.4167\n",
      "Epoch 46/200 Batch 8, Loss 11.3067\n",
      "Epoch 46/200 Batch 9, Loss 11.4626\n",
      "Epoch 46/200 Batch 10, Loss 11.5141\n",
      "Epoch 46/200 Batch 11, Loss 11.3975\n",
      "Epoch 46/200 Batch 12, Loss 11.2770\n",
      "Epoch 46/200 Batch 13, Loss 11.4358\n",
      "Epoch 46/200 Batch 14, Loss 11.3869\n",
      "Epoch 46/200 Batch 15, Loss 11.3614\n",
      "Epoch 46/200 Batch 16, Loss 11.3794\n",
      "Epoch 46/200 Batch 17, Loss 11.4202\n",
      "Epoch 46/200 Batch 18, Loss 11.4329\n",
      "Epoch 46/200 Batch 19, Loss 11.4158\n",
      "Epoch 47/200 Batch 0, Loss 11.4489\n",
      "Epoch 47/200 Batch 1, Loss 11.3830\n",
      "Epoch 47/200 Batch 2, Loss 11.5291\n",
      "Epoch 47/200 Batch 3, Loss 11.5502\n",
      "Epoch 47/200 Batch 4, Loss 11.4085\n",
      "Epoch 47/200 Batch 5, Loss 11.3498\n",
      "Epoch 47/200 Batch 6, Loss 11.1674\n",
      "Epoch 47/200 Batch 7, Loss 11.2965\n",
      "Epoch 47/200 Batch 8, Loss 11.5209\n",
      "Epoch 47/200 Batch 9, Loss 11.3250\n",
      "Epoch 47/200 Batch 10, Loss 11.5380\n",
      "Epoch 47/200 Batch 11, Loss 11.3134\n",
      "Epoch 47/200 Batch 12, Loss 11.3034\n",
      "Epoch 47/200 Batch 13, Loss 11.4340\n",
      "Epoch 47/200 Batch 14, Loss 11.5617\n",
      "Epoch 47/200 Batch 15, Loss 11.4831\n",
      "Epoch 47/200 Batch 16, Loss 11.2608\n",
      "Epoch 47/200 Batch 17, Loss 11.1801\n",
      "Epoch 47/200 Batch 18, Loss 11.4388\n",
      "Epoch 47/200 Batch 19, Loss 11.6343\n",
      "Epoch 48/200 Batch 0, Loss 11.3699\n",
      "Epoch 48/200 Batch 1, Loss 11.2194\n",
      "Epoch 48/200 Batch 2, Loss 11.4327\n",
      "Epoch 48/200 Batch 3, Loss 11.2881\n",
      "Epoch 48/200 Batch 4, Loss 11.3992\n",
      "Epoch 48/200 Batch 5, Loss 11.2855\n",
      "Epoch 48/200 Batch 6, Loss 11.3128\n",
      "Epoch 48/200 Batch 7, Loss 11.4474\n",
      "Epoch 48/200 Batch 8, Loss 11.4595\n",
      "Epoch 48/200 Batch 9, Loss 11.2400\n",
      "Epoch 48/200 Batch 10, Loss 11.5584\n",
      "Epoch 48/200 Batch 11, Loss 11.3066\n",
      "Epoch 48/200 Batch 12, Loss 11.4338\n",
      "Epoch 48/200 Batch 13, Loss 11.3462\n",
      "Epoch 48/200 Batch 14, Loss 11.1851\n",
      "Epoch 48/200 Batch 15, Loss 11.4494\n",
      "Epoch 48/200 Batch 16, Loss 11.4306\n",
      "Epoch 48/200 Batch 17, Loss 11.5036\n",
      "Epoch 48/200 Batch 18, Loss 11.4341\n",
      "Epoch 48/200 Batch 19, Loss 11.4562\n",
      "Epoch 49/200 Batch 0, Loss 11.1980\n",
      "Epoch 49/200 Batch 1, Loss 11.3843\n",
      "Epoch 49/200 Batch 2, Loss 11.4852\n",
      "Epoch 49/200 Batch 3, Loss 11.3917\n",
      "Epoch 49/200 Batch 4, Loss 11.3677\n",
      "Epoch 49/200 Batch 5, Loss 11.4658\n",
      "Epoch 49/200 Batch 6, Loss 11.5367\n",
      "Epoch 49/200 Batch 7, Loss 11.4597\n",
      "Epoch 49/200 Batch 8, Loss 11.3280\n",
      "Epoch 49/200 Batch 9, Loss 11.3602\n",
      "Epoch 49/200 Batch 10, Loss 11.4417\n",
      "Epoch 49/200 Batch 11, Loss 11.4436\n",
      "Epoch 49/200 Batch 12, Loss 11.3082\n",
      "Epoch 49/200 Batch 13, Loss 11.4064\n",
      "Epoch 49/200 Batch 14, Loss 11.3535\n",
      "Epoch 49/200 Batch 15, Loss 11.2321\n",
      "Epoch 49/200 Batch 16, Loss 11.3064\n",
      "Epoch 49/200 Batch 17, Loss 11.3980\n",
      "Epoch 49/200 Batch 18, Loss 11.6189\n",
      "Epoch 49/200 Batch 19, Loss 11.5359\n",
      "Epoch 50/200 Batch 0, Loss 11.2991\n",
      "Epoch 50/200 Batch 1, Loss 11.2810\n",
      "Epoch 50/200 Batch 2, Loss 11.5145\n",
      "Epoch 50/200 Batch 3, Loss 11.3783\n",
      "Epoch 50/200 Batch 4, Loss 11.5581\n",
      "Epoch 50/200 Batch 5, Loss 11.2509\n",
      "Epoch 50/200 Batch 6, Loss 11.2927\n",
      "Epoch 50/200 Batch 7, Loss 11.5149\n",
      "Epoch 50/200 Batch 8, Loss 11.4697\n",
      "Epoch 50/200 Batch 9, Loss 11.1677\n",
      "Epoch 50/200 Batch 10, Loss 11.4254\n",
      "Epoch 50/200 Batch 11, Loss 11.3035\n",
      "Epoch 50/200 Batch 12, Loss 11.4427\n",
      "Epoch 50/200 Batch 13, Loss 11.4286\n",
      "Epoch 50/200 Batch 14, Loss 11.5415\n",
      "Epoch 50/200 Batch 15, Loss 11.3487\n",
      "Epoch 50/200 Batch 16, Loss 11.3609\n",
      "Epoch 50/200 Batch 17, Loss 11.3922\n",
      "Epoch 50/200 Batch 18, Loss 11.3071\n",
      "Epoch 50/200 Batch 19, Loss 11.3798\n",
      "Epoch 51/200 Batch 0, Loss 11.4081\n",
      "Epoch 51/200 Batch 1, Loss 11.2518\n",
      "Epoch 51/200 Batch 2, Loss 11.4927\n",
      "Epoch 51/200 Batch 3, Loss 11.2792\n",
      "Epoch 51/200 Batch 4, Loss 11.4023\n",
      "Epoch 51/200 Batch 5, Loss 11.3331\n",
      "Epoch 51/200 Batch 6, Loss 11.5340\n",
      "Epoch 51/200 Batch 7, Loss 11.3137\n",
      "Epoch 51/200 Batch 8, Loss 11.4659\n",
      "Epoch 51/200 Batch 9, Loss 11.3795\n",
      "Epoch 51/200 Batch 10, Loss 11.4342\n",
      "Epoch 51/200 Batch 11, Loss 11.3780\n",
      "Epoch 51/200 Batch 12, Loss 11.4236\n",
      "Epoch 51/200 Batch 13, Loss 11.4982\n",
      "Epoch 51/200 Batch 14, Loss 11.3553\n",
      "Epoch 51/200 Batch 15, Loss 11.3064\n",
      "Epoch 51/200 Batch 16, Loss 11.2793\n",
      "Epoch 51/200 Batch 17, Loss 11.5794\n",
      "Epoch 51/200 Batch 18, Loss 11.1677\n",
      "Epoch 51/200 Batch 19, Loss 11.3932\n",
      "Epoch 52/200 Batch 0, Loss 11.1314\n",
      "Epoch 52/200 Batch 1, Loss 11.4361\n",
      "Epoch 52/200 Batch 2, Loss 11.3467\n",
      "Epoch 52/200 Batch 3, Loss 11.3920\n",
      "Epoch 52/200 Batch 4, Loss 11.4717\n",
      "Epoch 52/200 Batch 5, Loss 11.4531\n",
      "Epoch 52/200 Batch 6, Loss 11.2992\n",
      "Epoch 52/200 Batch 7, Loss 11.3603\n",
      "Epoch 52/200 Batch 8, Loss 11.3521\n",
      "Epoch 52/200 Batch 9, Loss 11.3980\n",
      "Epoch 52/200 Batch 10, Loss 11.4281\n",
      "Epoch 52/200 Batch 11, Loss 11.4723\n",
      "Epoch 52/200 Batch 12, Loss 11.2150\n",
      "Epoch 52/200 Batch 13, Loss 11.5196\n",
      "Epoch 52/200 Batch 14, Loss 11.4197\n",
      "Epoch 52/200 Batch 15, Loss 11.5454\n",
      "Epoch 52/200 Batch 16, Loss 11.3668\n",
      "Epoch 52/200 Batch 17, Loss 11.5745\n",
      "Epoch 52/200 Batch 18, Loss 11.3357\n",
      "Epoch 52/200 Batch 19, Loss 11.7258\n",
      "Epoch 53/200 Batch 0, Loss 11.3988\n",
      "Epoch 53/200 Batch 1, Loss 11.4642\n",
      "Epoch 53/200 Batch 2, Loss 11.4308\n",
      "Epoch 53/200 Batch 3, Loss 11.3378\n",
      "Epoch 53/200 Batch 4, Loss 11.3800\n",
      "Epoch 53/200 Batch 5, Loss 11.2957\n",
      "Epoch 53/200 Batch 6, Loss 11.6226\n",
      "Epoch 53/200 Batch 7, Loss 11.1326\n",
      "Epoch 53/200 Batch 8, Loss 11.4052\n",
      "Epoch 53/200 Batch 9, Loss 11.4379\n",
      "Epoch 53/200 Batch 10, Loss 11.4490\n",
      "Epoch 53/200 Batch 11, Loss 11.3549\n",
      "Epoch 53/200 Batch 12, Loss 11.3991\n",
      "Epoch 53/200 Batch 13, Loss 11.1779\n",
      "Epoch 53/200 Batch 14, Loss 11.4519\n",
      "Epoch 53/200 Batch 15, Loss 11.2904\n",
      "Epoch 53/200 Batch 16, Loss 11.2906\n",
      "Epoch 53/200 Batch 17, Loss 11.4141\n",
      "Epoch 53/200 Batch 18, Loss 11.5638\n",
      "Epoch 53/200 Batch 19, Loss 11.3774\n",
      "Epoch 54/200 Batch 0, Loss 11.3639\n",
      "Epoch 54/200 Batch 1, Loss 11.3601\n",
      "Epoch 54/200 Batch 2, Loss 11.3452\n",
      "Epoch 54/200 Batch 3, Loss 11.3790\n",
      "Epoch 54/200 Batch 4, Loss 11.5581\n",
      "Epoch 54/200 Batch 5, Loss 11.6014\n",
      "Epoch 54/200 Batch 6, Loss 11.4868\n",
      "Epoch 54/200 Batch 7, Loss 11.2419\n",
      "Epoch 54/200 Batch 8, Loss 11.2760\n",
      "Epoch 54/200 Batch 9, Loss 11.3465\n",
      "Epoch 54/200 Batch 10, Loss 11.3939\n",
      "Epoch 54/200 Batch 11, Loss 11.7187\n",
      "Epoch 54/200 Batch 12, Loss 11.2818\n",
      "Epoch 54/200 Batch 13, Loss 11.5178\n",
      "Epoch 54/200 Batch 14, Loss 11.2587\n",
      "Epoch 54/200 Batch 15, Loss 11.3761\n",
      "Epoch 54/200 Batch 16, Loss 11.0608\n",
      "Epoch 54/200 Batch 17, Loss 11.2928\n",
      "Epoch 54/200 Batch 18, Loss 11.3094\n",
      "Epoch 54/200 Batch 19, Loss 11.1787\n",
      "Epoch 55/200 Batch 0, Loss 11.5366\n",
      "Epoch 55/200 Batch 1, Loss 11.4249\n",
      "Epoch 55/200 Batch 2, Loss 11.4091\n",
      "Epoch 55/200 Batch 3, Loss 11.2738\n",
      "Epoch 55/200 Batch 4, Loss 11.3947\n",
      "Epoch 55/200 Batch 5, Loss 11.2424\n",
      "Epoch 55/200 Batch 6, Loss 11.4634\n",
      "Epoch 55/200 Batch 7, Loss 11.2430\n",
      "Epoch 55/200 Batch 8, Loss 11.4991\n",
      "Epoch 55/200 Batch 9, Loss 11.3558\n",
      "Epoch 55/200 Batch 10, Loss 11.4348\n",
      "Epoch 55/200 Batch 11, Loss 11.2127\n",
      "Epoch 55/200 Batch 12, Loss 11.4680\n",
      "Epoch 55/200 Batch 13, Loss 11.3233\n",
      "Epoch 55/200 Batch 14, Loss 11.2441\n",
      "Epoch 55/200 Batch 15, Loss 11.4219\n",
      "Epoch 55/200 Batch 16, Loss 11.2723\n",
      "Epoch 55/200 Batch 17, Loss 11.3630\n",
      "Epoch 55/200 Batch 18, Loss 11.4233\n",
      "Epoch 55/200 Batch 19, Loss 11.2883\n",
      "Epoch 56/200 Batch 0, Loss 11.3869\n",
      "Epoch 56/200 Batch 1, Loss 11.3473\n",
      "Epoch 56/200 Batch 2, Loss 11.3136\n",
      "Epoch 56/200 Batch 3, Loss 11.3629\n",
      "Epoch 56/200 Batch 4, Loss 11.3422\n",
      "Epoch 56/200 Batch 5, Loss 11.4955\n",
      "Epoch 56/200 Batch 6, Loss 11.3499\n",
      "Epoch 56/200 Batch 7, Loss 11.4160\n",
      "Epoch 56/200 Batch 8, Loss 11.4962\n",
      "Epoch 56/200 Batch 9, Loss 11.3409\n",
      "Epoch 56/200 Batch 10, Loss 11.3307\n",
      "Epoch 56/200 Batch 11, Loss 11.4697\n",
      "Epoch 56/200 Batch 12, Loss 11.3314\n",
      "Epoch 56/200 Batch 13, Loss 11.5050\n",
      "Epoch 56/200 Batch 14, Loss 11.2897\n",
      "Epoch 56/200 Batch 15, Loss 11.1868\n",
      "Epoch 56/200 Batch 16, Loss 11.2916\n",
      "Epoch 56/200 Batch 17, Loss 11.5289\n",
      "Epoch 56/200 Batch 18, Loss 11.3476\n",
      "Epoch 56/200 Batch 19, Loss 11.4020\n",
      "Epoch 57/200 Batch 0, Loss 11.5038\n",
      "Epoch 57/200 Batch 1, Loss 11.3251\n",
      "Epoch 57/200 Batch 2, Loss 11.3869\n",
      "Epoch 57/200 Batch 3, Loss 11.4403\n",
      "Epoch 57/200 Batch 4, Loss 11.3451\n",
      "Epoch 57/200 Batch 5, Loss 11.3426\n",
      "Epoch 57/200 Batch 6, Loss 11.3024\n",
      "Epoch 57/200 Batch 7, Loss 11.3509\n",
      "Epoch 57/200 Batch 8, Loss 11.3286\n",
      "Epoch 57/200 Batch 9, Loss 11.4697\n",
      "Epoch 57/200 Batch 10, Loss 11.2718\n",
      "Epoch 57/200 Batch 11, Loss 11.3301\n",
      "Epoch 57/200 Batch 12, Loss 11.6056\n",
      "Epoch 57/200 Batch 13, Loss 11.3670\n",
      "Epoch 57/200 Batch 14, Loss 11.3286\n",
      "Epoch 57/200 Batch 15, Loss 11.3405\n",
      "Epoch 57/200 Batch 16, Loss 11.2921\n",
      "Epoch 57/200 Batch 17, Loss 11.2515\n",
      "Epoch 57/200 Batch 18, Loss 11.3574\n",
      "Epoch 57/200 Batch 19, Loss 11.5935\n",
      "Epoch 58/200 Batch 0, Loss 11.3712\n",
      "Epoch 58/200 Batch 1, Loss 11.1857\n",
      "Epoch 58/200 Batch 2, Loss 11.4158\n",
      "Epoch 58/200 Batch 3, Loss 11.6658\n",
      "Epoch 58/200 Batch 4, Loss 11.1947\n",
      "Epoch 58/200 Batch 5, Loss 11.3790\n",
      "Epoch 58/200 Batch 6, Loss 11.3289\n",
      "Epoch 58/200 Batch 7, Loss 11.3671\n",
      "Epoch 58/200 Batch 8, Loss 11.4054\n",
      "Epoch 58/200 Batch 9, Loss 11.4255\n",
      "Epoch 58/200 Batch 10, Loss 11.1322\n",
      "Epoch 58/200 Batch 11, Loss 11.4571\n",
      "Epoch 58/200 Batch 12, Loss 11.3965\n",
      "Epoch 58/200 Batch 13, Loss 11.3478\n",
      "Epoch 58/200 Batch 14, Loss 11.4967\n",
      "Epoch 58/200 Batch 15, Loss 11.5015\n",
      "Epoch 58/200 Batch 16, Loss 11.3248\n",
      "Epoch 58/200 Batch 17, Loss 11.3764\n",
      "Epoch 58/200 Batch 18, Loss 11.4251\n",
      "Epoch 58/200 Batch 19, Loss 11.2586\n",
      "Epoch 59/200 Batch 0, Loss 11.4780\n",
      "Epoch 59/200 Batch 1, Loss 11.4341\n",
      "Epoch 59/200 Batch 2, Loss 11.5545\n",
      "Epoch 59/200 Batch 3, Loss 11.3263\n",
      "Epoch 59/200 Batch 4, Loss 11.3685\n",
      "Epoch 59/200 Batch 5, Loss 11.5319\n",
      "Epoch 59/200 Batch 6, Loss 11.3909\n",
      "Epoch 59/200 Batch 7, Loss 11.3645\n",
      "Epoch 59/200 Batch 8, Loss 11.2860\n",
      "Epoch 59/200 Batch 9, Loss 11.2827\n",
      "Epoch 59/200 Batch 10, Loss 11.3352\n",
      "Epoch 59/200 Batch 11, Loss 11.3272\n",
      "Epoch 59/200 Batch 12, Loss 11.3119\n",
      "Epoch 59/200 Batch 13, Loss 11.2468\n",
      "Epoch 59/200 Batch 14, Loss 11.2319\n",
      "Epoch 59/200 Batch 15, Loss 11.4282\n",
      "Epoch 59/200 Batch 16, Loss 11.5383\n",
      "Epoch 59/200 Batch 17, Loss 11.3208\n",
      "Epoch 59/200 Batch 18, Loss 11.2813\n",
      "Epoch 59/200 Batch 19, Loss 11.3378\n",
      "Epoch 60/200 Batch 0, Loss 11.3364\n",
      "Epoch 60/200 Batch 1, Loss 11.4698\n",
      "Epoch 60/200 Batch 2, Loss 11.4288\n",
      "Epoch 60/200 Batch 3, Loss 11.3838\n",
      "Epoch 60/200 Batch 4, Loss 11.3280\n",
      "Epoch 60/200 Batch 5, Loss 11.2798\n",
      "Epoch 60/200 Batch 6, Loss 11.2679\n",
      "Epoch 60/200 Batch 7, Loss 11.3911\n",
      "Epoch 60/200 Batch 8, Loss 11.4586\n",
      "Epoch 60/200 Batch 9, Loss 11.2743\n",
      "Epoch 60/200 Batch 10, Loss 11.4294\n",
      "Epoch 60/200 Batch 11, Loss 11.4762\n",
      "Epoch 60/200 Batch 12, Loss 11.2458\n",
      "Epoch 60/200 Batch 13, Loss 11.2929\n",
      "Epoch 60/200 Batch 14, Loss 11.4920\n",
      "Epoch 60/200 Batch 15, Loss 11.3192\n",
      "Epoch 60/200 Batch 16, Loss 11.2130\n",
      "Epoch 60/200 Batch 17, Loss 11.2589\n",
      "Epoch 60/200 Batch 18, Loss 11.3967\n",
      "Epoch 60/200 Batch 19, Loss 11.5472\n",
      "Epoch 61/200 Batch 0, Loss 11.3190\n",
      "Epoch 61/200 Batch 1, Loss 11.3101\n",
      "Epoch 61/200 Batch 2, Loss 11.5652\n",
      "Epoch 61/200 Batch 3, Loss 11.4849\n",
      "Epoch 61/200 Batch 4, Loss 11.1974\n",
      "Epoch 61/200 Batch 5, Loss 11.3190\n",
      "Epoch 61/200 Batch 6, Loss 11.2693\n",
      "Epoch 61/200 Batch 7, Loss 11.2537\n",
      "Epoch 61/200 Batch 8, Loss 11.2556\n",
      "Epoch 61/200 Batch 9, Loss 11.5608\n",
      "Epoch 61/200 Batch 10, Loss 11.4506\n",
      "Epoch 61/200 Batch 11, Loss 11.4005\n",
      "Epoch 61/200 Batch 12, Loss 11.3890\n",
      "Epoch 61/200 Batch 13, Loss 11.3279\n",
      "Epoch 61/200 Batch 14, Loss 11.2093\n",
      "Epoch 61/200 Batch 15, Loss 11.2798\n",
      "Epoch 61/200 Batch 16, Loss 11.2520\n",
      "Epoch 61/200 Batch 17, Loss 11.4917\n",
      "Epoch 61/200 Batch 18, Loss 11.2333\n",
      "Epoch 61/200 Batch 19, Loss 11.6139\n",
      "Epoch 62/200 Batch 0, Loss 11.4132\n",
      "Epoch 62/200 Batch 1, Loss 11.3619\n",
      "Epoch 62/200 Batch 2, Loss 11.2503\n",
      "Epoch 62/200 Batch 3, Loss 11.3875\n",
      "Epoch 62/200 Batch 4, Loss 11.4263\n",
      "Epoch 62/200 Batch 5, Loss 11.2818\n",
      "Epoch 62/200 Batch 6, Loss 11.2712\n",
      "Epoch 62/200 Batch 7, Loss 11.4694\n",
      "Epoch 62/200 Batch 8, Loss 11.3978\n",
      "Epoch 62/200 Batch 9, Loss 11.2337\n",
      "Epoch 62/200 Batch 10, Loss 11.4026\n",
      "Epoch 62/200 Batch 11, Loss 11.2812\n",
      "Epoch 62/200 Batch 12, Loss 11.5174\n",
      "Epoch 62/200 Batch 13, Loss 11.3401\n",
      "Epoch 62/200 Batch 14, Loss 11.3726\n",
      "Epoch 62/200 Batch 15, Loss 11.4696\n",
      "Epoch 62/200 Batch 16, Loss 11.3239\n",
      "Epoch 62/200 Batch 17, Loss 11.4473\n",
      "Epoch 62/200 Batch 18, Loss 11.3315\n",
      "Epoch 62/200 Batch 19, Loss 11.4519\n",
      "Epoch 63/200 Batch 0, Loss 11.3797\n",
      "Epoch 63/200 Batch 1, Loss 11.4502\n",
      "Epoch 63/200 Batch 2, Loss 11.3405\n",
      "Epoch 63/200 Batch 3, Loss 11.4360\n",
      "Epoch 63/200 Batch 4, Loss 11.3486\n",
      "Epoch 63/200 Batch 5, Loss 11.2433\n",
      "Epoch 63/200 Batch 6, Loss 11.5472\n",
      "Epoch 63/200 Batch 7, Loss 11.4081\n",
      "Epoch 63/200 Batch 8, Loss 11.4058\n",
      "Epoch 63/200 Batch 9, Loss 11.2303\n",
      "Epoch 63/200 Batch 10, Loss 11.3206\n",
      "Epoch 63/200 Batch 11, Loss 11.2163\n",
      "Epoch 63/200 Batch 12, Loss 11.4392\n",
      "Epoch 63/200 Batch 13, Loss 11.2678\n",
      "Epoch 63/200 Batch 14, Loss 11.3644\n",
      "Epoch 63/200 Batch 15, Loss 11.4773\n",
      "Epoch 63/200 Batch 16, Loss 11.3947\n",
      "Epoch 63/200 Batch 17, Loss 11.2168\n",
      "Epoch 63/200 Batch 18, Loss 11.4185\n",
      "Epoch 63/200 Batch 19, Loss 11.3274\n",
      "Epoch 64/200 Batch 0, Loss 11.3079\n",
      "Epoch 64/200 Batch 1, Loss 11.4683\n",
      "Epoch 64/200 Batch 2, Loss 11.4356\n",
      "Epoch 64/200 Batch 3, Loss 11.4399\n",
      "Epoch 64/200 Batch 4, Loss 11.4580\n",
      "Epoch 64/200 Batch 5, Loss 11.5026\n",
      "Epoch 64/200 Batch 6, Loss 11.5774\n",
      "Epoch 64/200 Batch 7, Loss 11.3446\n",
      "Epoch 64/200 Batch 8, Loss 11.4819\n",
      "Epoch 64/200 Batch 9, Loss 11.3080\n",
      "Epoch 64/200 Batch 10, Loss 11.3965\n",
      "Epoch 64/200 Batch 11, Loss 11.5349\n",
      "Epoch 64/200 Batch 12, Loss 11.4553\n",
      "Epoch 64/200 Batch 13, Loss 11.1652\n",
      "Epoch 64/200 Batch 14, Loss 11.2683\n",
      "Epoch 64/200 Batch 15, Loss 11.2748\n",
      "Epoch 64/200 Batch 16, Loss 11.3877\n",
      "Epoch 64/200 Batch 17, Loss 11.3814\n",
      "Epoch 64/200 Batch 18, Loss 11.3032\n",
      "Epoch 64/200 Batch 19, Loss 11.3001\n",
      "Epoch 65/200 Batch 0, Loss 11.2581\n",
      "Epoch 65/200 Batch 1, Loss 11.4376\n",
      "Epoch 65/200 Batch 2, Loss 11.4983\n",
      "Epoch 65/200 Batch 3, Loss 11.4930\n",
      "Epoch 65/200 Batch 4, Loss 11.3989\n",
      "Epoch 65/200 Batch 5, Loss 11.5134\n",
      "Epoch 65/200 Batch 6, Loss 11.4456\n",
      "Epoch 65/200 Batch 7, Loss 11.4154\n",
      "Epoch 65/200 Batch 8, Loss 11.3624\n",
      "Epoch 65/200 Batch 9, Loss 11.2893\n",
      "Epoch 65/200 Batch 10, Loss 11.4346\n",
      "Epoch 65/200 Batch 11, Loss 11.1794\n",
      "Epoch 65/200 Batch 12, Loss 11.3143\n",
      "Epoch 65/200 Batch 13, Loss 11.2895\n",
      "Epoch 65/200 Batch 14, Loss 11.4048\n",
      "Epoch 65/200 Batch 15, Loss 11.2872\n",
      "Epoch 65/200 Batch 16, Loss 11.3364\n",
      "Epoch 65/200 Batch 17, Loss 11.4004\n",
      "Epoch 65/200 Batch 18, Loss 11.3952\n",
      "Epoch 65/200 Batch 19, Loss 11.2882\n",
      "Epoch 66/200 Batch 0, Loss 11.2638\n",
      "Epoch 66/200 Batch 1, Loss 11.3849\n",
      "Epoch 66/200 Batch 2, Loss 11.4068\n",
      "Epoch 66/200 Batch 3, Loss 11.1892\n",
      "Epoch 66/200 Batch 4, Loss 11.4325\n",
      "Epoch 66/200 Batch 5, Loss 11.3237\n",
      "Epoch 66/200 Batch 6, Loss 11.4580\n",
      "Epoch 66/200 Batch 7, Loss 11.2737\n",
      "Epoch 66/200 Batch 8, Loss 11.3470\n",
      "Epoch 66/200 Batch 9, Loss 11.3388\n",
      "Epoch 66/200 Batch 10, Loss 11.4412\n",
      "Epoch 66/200 Batch 11, Loss 11.2684\n",
      "Epoch 66/200 Batch 12, Loss 11.1983\n",
      "Epoch 66/200 Batch 13, Loss 11.3450\n",
      "Epoch 66/200 Batch 14, Loss 11.3613\n",
      "Epoch 66/200 Batch 15, Loss 11.5743\n",
      "Epoch 66/200 Batch 16, Loss 11.4456\n",
      "Epoch 66/200 Batch 17, Loss 11.3502\n",
      "Epoch 66/200 Batch 18, Loss 11.3956\n",
      "Epoch 66/200 Batch 19, Loss 11.2595\n",
      "Epoch 67/200 Batch 0, Loss 11.3373\n",
      "Epoch 67/200 Batch 1, Loss 11.3251\n",
      "Epoch 67/200 Batch 2, Loss 11.4757\n",
      "Epoch 67/200 Batch 3, Loss 11.2489\n",
      "Epoch 67/200 Batch 4, Loss 11.3236\n",
      "Epoch 67/200 Batch 5, Loss 11.3172\n",
      "Epoch 67/200 Batch 6, Loss 11.1516\n",
      "Epoch 67/200 Batch 7, Loss 11.4592\n",
      "Epoch 67/200 Batch 8, Loss 11.2903\n",
      "Epoch 67/200 Batch 9, Loss 11.3498\n",
      "Epoch 67/200 Batch 10, Loss 11.2422\n",
      "Epoch 67/200 Batch 11, Loss 11.5529\n",
      "Epoch 67/200 Batch 12, Loss 11.4380\n",
      "Epoch 67/200 Batch 13, Loss 11.3914\n",
      "Epoch 67/200 Batch 14, Loss 11.3039\n",
      "Epoch 67/200 Batch 15, Loss 11.4893\n",
      "Epoch 67/200 Batch 16, Loss 11.2948\n",
      "Epoch 67/200 Batch 17, Loss 11.3127\n",
      "Epoch 67/200 Batch 18, Loss 11.3951\n",
      "Epoch 67/200 Batch 19, Loss 11.4455\n",
      "Epoch 68/200 Batch 0, Loss 11.4125\n",
      "Epoch 68/200 Batch 1, Loss 11.4458\n",
      "Epoch 68/200 Batch 2, Loss 11.2257\n",
      "Epoch 68/200 Batch 3, Loss 11.3277\n",
      "Epoch 68/200 Batch 4, Loss 11.2875\n",
      "Epoch 68/200 Batch 5, Loss 11.3564\n",
      "Epoch 68/200 Batch 6, Loss 11.2866\n",
      "Epoch 68/200 Batch 7, Loss 11.3297\n",
      "Epoch 68/200 Batch 8, Loss 11.4290\n",
      "Epoch 68/200 Batch 9, Loss 11.2432\n",
      "Epoch 68/200 Batch 10, Loss 11.4839\n",
      "Epoch 68/200 Batch 11, Loss 11.2132\n",
      "Epoch 68/200 Batch 12, Loss 11.3000\n",
      "Epoch 68/200 Batch 13, Loss 11.3880\n",
      "Epoch 68/200 Batch 14, Loss 11.4229\n",
      "Epoch 68/200 Batch 15, Loss 11.4002\n",
      "Epoch 68/200 Batch 16, Loss 11.4147\n",
      "Epoch 68/200 Batch 17, Loss 11.4458\n",
      "Epoch 68/200 Batch 18, Loss 11.4129\n",
      "Epoch 68/200 Batch 19, Loss 11.3983\n",
      "Epoch 69/200 Batch 0, Loss 11.2704\n",
      "Epoch 69/200 Batch 1, Loss 11.6246\n",
      "Epoch 69/200 Batch 2, Loss 11.3178\n",
      "Epoch 69/200 Batch 3, Loss 11.4424\n",
      "Epoch 69/200 Batch 4, Loss 11.5317\n",
      "Epoch 69/200 Batch 5, Loss 11.3548\n",
      "Epoch 69/200 Batch 6, Loss 11.2189\n",
      "Epoch 69/200 Batch 7, Loss 11.3553\n",
      "Epoch 69/200 Batch 8, Loss 11.3993\n",
      "Epoch 69/200 Batch 9, Loss 11.2650\n",
      "Epoch 69/200 Batch 10, Loss 11.3033\n",
      "Epoch 69/200 Batch 11, Loss 11.5659\n",
      "Epoch 69/200 Batch 12, Loss 11.2617\n",
      "Epoch 69/200 Batch 13, Loss 11.3104\n",
      "Epoch 69/200 Batch 14, Loss 11.3038\n",
      "Epoch 69/200 Batch 15, Loss 11.5534\n",
      "Epoch 69/200 Batch 16, Loss 11.2831\n",
      "Epoch 69/200 Batch 17, Loss 11.3205\n",
      "Epoch 69/200 Batch 18, Loss 11.3334\n",
      "Epoch 69/200 Batch 19, Loss 11.3232\n",
      "Epoch 70/200 Batch 0, Loss 11.3090\n",
      "Epoch 70/200 Batch 1, Loss 11.3956\n",
      "Epoch 70/200 Batch 2, Loss 11.4024\n",
      "Epoch 70/200 Batch 3, Loss 11.4133\n",
      "Epoch 70/200 Batch 4, Loss 11.2686\n",
      "Epoch 70/200 Batch 5, Loss 11.1572\n",
      "Epoch 70/200 Batch 6, Loss 11.5913\n",
      "Epoch 70/200 Batch 7, Loss 11.5373\n",
      "Epoch 70/200 Batch 8, Loss 11.1778\n",
      "Epoch 70/200 Batch 9, Loss 11.4017\n",
      "Epoch 70/200 Batch 10, Loss 11.3366\n",
      "Epoch 70/200 Batch 11, Loss 11.5325\n",
      "Epoch 70/200 Batch 12, Loss 11.3090\n",
      "Epoch 70/200 Batch 13, Loss 11.3046\n",
      "Epoch 70/200 Batch 14, Loss 11.3036\n",
      "Epoch 70/200 Batch 15, Loss 11.5126\n",
      "Epoch 70/200 Batch 16, Loss 11.2737\n",
      "Epoch 70/200 Batch 17, Loss 11.4036\n",
      "Epoch 70/200 Batch 18, Loss 11.2849\n",
      "Epoch 70/200 Batch 19, Loss 11.3729\n",
      "Epoch 71/200 Batch 0, Loss 11.3588\n",
      "Epoch 71/200 Batch 1, Loss 11.4855\n",
      "Epoch 71/200 Batch 2, Loss 11.3130\n",
      "Epoch 71/200 Batch 3, Loss 11.4231\n",
      "Epoch 71/200 Batch 4, Loss 11.2939\n",
      "Epoch 71/200 Batch 5, Loss 11.2767\n",
      "Epoch 71/200 Batch 6, Loss 11.2610\n",
      "Epoch 71/200 Batch 7, Loss 11.3384\n",
      "Epoch 71/200 Batch 8, Loss 11.2406\n",
      "Epoch 71/200 Batch 9, Loss 11.5117\n",
      "Epoch 71/200 Batch 10, Loss 11.4066\n",
      "Epoch 71/200 Batch 11, Loss 11.2616\n",
      "Epoch 71/200 Batch 12, Loss 11.5100\n",
      "Epoch 71/200 Batch 13, Loss 11.4726\n",
      "Epoch 71/200 Batch 14, Loss 11.2548\n",
      "Epoch 71/200 Batch 15, Loss 11.3073\n",
      "Epoch 71/200 Batch 16, Loss 11.2904\n",
      "Epoch 71/200 Batch 17, Loss 11.4246\n",
      "Epoch 71/200 Batch 18, Loss 11.2985\n",
      "Epoch 71/200 Batch 19, Loss 11.0565\n",
      "Epoch 72/200 Batch 0, Loss 11.3598\n",
      "Epoch 72/200 Batch 1, Loss 11.5435\n",
      "Epoch 72/200 Batch 2, Loss 11.4425\n",
      "Epoch 72/200 Batch 3, Loss 11.4132\n",
      "Epoch 72/200 Batch 4, Loss 11.0351\n",
      "Epoch 72/200 Batch 5, Loss 11.4753\n",
      "Epoch 72/200 Batch 6, Loss 11.2801\n",
      "Epoch 72/200 Batch 7, Loss 11.3345\n",
      "Epoch 72/200 Batch 8, Loss 11.3168\n",
      "Epoch 72/200 Batch 9, Loss 11.4609\n",
      "Epoch 72/200 Batch 10, Loss 11.3819\n",
      "Epoch 72/200 Batch 11, Loss 11.1860\n",
      "Epoch 72/200 Batch 12, Loss 11.2526\n",
      "Epoch 72/200 Batch 13, Loss 11.3324\n",
      "Epoch 72/200 Batch 14, Loss 11.3958\n",
      "Epoch 72/200 Batch 15, Loss 11.3190\n",
      "Epoch 72/200 Batch 16, Loss 11.4711\n",
      "Epoch 72/200 Batch 17, Loss 11.4314\n",
      "Epoch 72/200 Batch 18, Loss 11.3775\n",
      "Epoch 72/200 Batch 19, Loss 11.4485\n",
      "Epoch 73/200 Batch 0, Loss 11.4987\n",
      "Epoch 73/200 Batch 1, Loss 11.4419\n",
      "Epoch 73/200 Batch 2, Loss 11.4065\n",
      "Epoch 73/200 Batch 3, Loss 11.3155\n",
      "Epoch 73/200 Batch 4, Loss 11.4945\n",
      "Epoch 73/200 Batch 5, Loss 11.3372\n",
      "Epoch 73/200 Batch 6, Loss 11.2711\n",
      "Epoch 73/200 Batch 7, Loss 11.2799\n",
      "Epoch 73/200 Batch 8, Loss 11.2774\n",
      "Epoch 73/200 Batch 9, Loss 11.4555\n",
      "Epoch 73/200 Batch 10, Loss 11.3353\n",
      "Epoch 73/200 Batch 11, Loss 11.5346\n",
      "Epoch 73/200 Batch 12, Loss 11.5368\n",
      "Epoch 73/200 Batch 13, Loss 11.2228\n",
      "Epoch 73/200 Batch 14, Loss 11.3571\n",
      "Epoch 73/200 Batch 15, Loss 11.3755\n",
      "Epoch 73/200 Batch 16, Loss 11.3375\n",
      "Epoch 73/200 Batch 17, Loss 11.3389\n",
      "Epoch 73/200 Batch 18, Loss 11.2754\n",
      "Epoch 73/200 Batch 19, Loss 11.4783\n",
      "Epoch 74/200 Batch 0, Loss 11.3324\n",
      "Epoch 74/200 Batch 1, Loss 11.3220\n",
      "Epoch 74/200 Batch 2, Loss 11.2291\n",
      "Epoch 74/200 Batch 3, Loss 11.4901\n",
      "Epoch 74/200 Batch 4, Loss 11.4774\n",
      "Epoch 74/200 Batch 5, Loss 11.5661\n",
      "Epoch 74/200 Batch 6, Loss 11.1533\n",
      "Epoch 74/200 Batch 7, Loss 11.5084\n",
      "Epoch 74/200 Batch 8, Loss 11.3348\n",
      "Epoch 74/200 Batch 9, Loss 11.2934\n",
      "Epoch 74/200 Batch 10, Loss 11.5094\n",
      "Epoch 74/200 Batch 11, Loss 11.2724\n",
      "Epoch 74/200 Batch 12, Loss 11.2803\n",
      "Epoch 74/200 Batch 13, Loss 11.5093\n",
      "Epoch 74/200 Batch 14, Loss 11.3108\n",
      "Epoch 74/200 Batch 15, Loss 11.2308\n",
      "Epoch 74/200 Batch 16, Loss 11.2893\n",
      "Epoch 74/200 Batch 17, Loss 11.2984\n",
      "Epoch 74/200 Batch 18, Loss 11.3289\n",
      "Epoch 74/200 Batch 19, Loss 11.4190\n",
      "Epoch 75/200 Batch 0, Loss 11.3295\n",
      "Epoch 75/200 Batch 1, Loss 11.3122\n",
      "Epoch 75/200 Batch 2, Loss 11.4184\n",
      "Epoch 75/200 Batch 3, Loss 11.3260\n",
      "Epoch 75/200 Batch 4, Loss 11.3253\n",
      "Epoch 75/200 Batch 5, Loss 11.3995\n",
      "Epoch 75/200 Batch 6, Loss 11.3413\n",
      "Epoch 75/200 Batch 7, Loss 11.3753\n",
      "Epoch 75/200 Batch 8, Loss 11.4199\n",
      "Epoch 75/200 Batch 9, Loss 11.4445\n",
      "Epoch 75/200 Batch 10, Loss 11.3340\n",
      "Epoch 75/200 Batch 11, Loss 11.2878\n",
      "Epoch 75/200 Batch 12, Loss 11.3194\n",
      "Epoch 75/200 Batch 13, Loss 11.3108\n",
      "Epoch 75/200 Batch 14, Loss 11.4665\n",
      "Epoch 75/200 Batch 15, Loss 11.3874\n",
      "Epoch 75/200 Batch 16, Loss 11.3013\n",
      "Epoch 75/200 Batch 17, Loss 11.3594\n",
      "Epoch 75/200 Batch 18, Loss 11.3929\n",
      "Epoch 75/200 Batch 19, Loss 11.2823\n",
      "Epoch 76/200 Batch 0, Loss 11.3538\n",
      "Epoch 76/200 Batch 1, Loss 11.4629\n",
      "Epoch 76/200 Batch 2, Loss 11.3229\n",
      "Epoch 76/200 Batch 3, Loss 11.1889\n",
      "Epoch 76/200 Batch 4, Loss 11.4482\n",
      "Epoch 76/200 Batch 5, Loss 11.3795\n",
      "Epoch 76/200 Batch 6, Loss 11.4561\n",
      "Epoch 76/200 Batch 7, Loss 11.4100\n",
      "Epoch 76/200 Batch 8, Loss 11.3298\n",
      "Epoch 76/200 Batch 9, Loss 11.3940\n",
      "Epoch 76/200 Batch 10, Loss 11.4999\n",
      "Epoch 76/200 Batch 11, Loss 11.3574\n",
      "Epoch 76/200 Batch 12, Loss 11.2376\n",
      "Epoch 76/200 Batch 13, Loss 11.2662\n",
      "Epoch 76/200 Batch 14, Loss 11.4695\n",
      "Epoch 76/200 Batch 15, Loss 11.2286\n",
      "Epoch 76/200 Batch 16, Loss 11.3570\n",
      "Epoch 76/200 Batch 17, Loss 11.3813\n",
      "Epoch 76/200 Batch 18, Loss 11.2835\n",
      "Epoch 76/200 Batch 19, Loss 11.2388\n",
      "Epoch 77/200 Batch 0, Loss 11.3968\n",
      "Epoch 77/200 Batch 1, Loss 11.2750\n",
      "Epoch 77/200 Batch 2, Loss 11.1384\n",
      "Epoch 77/200 Batch 3, Loss 11.2375\n",
      "Epoch 77/200 Batch 4, Loss 11.3800\n",
      "Epoch 77/200 Batch 5, Loss 11.3049\n",
      "Epoch 77/200 Batch 6, Loss 11.4438\n",
      "Epoch 77/200 Batch 7, Loss 11.2652\n",
      "Epoch 77/200 Batch 8, Loss 11.5253\n",
      "Epoch 77/200 Batch 9, Loss 11.4034\n",
      "Epoch 77/200 Batch 10, Loss 11.4324\n",
      "Epoch 77/200 Batch 11, Loss 11.3437\n",
      "Epoch 77/200 Batch 12, Loss 11.3052\n",
      "Epoch 77/200 Batch 13, Loss 11.3705\n",
      "Epoch 77/200 Batch 14, Loss 11.3637\n",
      "Epoch 77/200 Batch 15, Loss 11.5953\n",
      "Epoch 77/200 Batch 16, Loss 11.4846\n",
      "Epoch 77/200 Batch 17, Loss 11.4618\n",
      "Epoch 77/200 Batch 18, Loss 11.3239\n",
      "Epoch 77/200 Batch 19, Loss 11.5075\n",
      "Epoch 78/200 Batch 0, Loss 11.3770\n",
      "Epoch 78/200 Batch 1, Loss 11.3449\n",
      "Epoch 78/200 Batch 2, Loss 11.3113\n",
      "Epoch 78/200 Batch 3, Loss 11.3039\n",
      "Epoch 78/200 Batch 4, Loss 11.3225\n",
      "Epoch 78/200 Batch 5, Loss 11.3070\n",
      "Epoch 78/200 Batch 6, Loss 11.4157\n",
      "Epoch 78/200 Batch 7, Loss 11.4688\n",
      "Epoch 78/200 Batch 8, Loss 11.3232\n",
      "Epoch 78/200 Batch 9, Loss 11.3636\n",
      "Epoch 78/200 Batch 10, Loss 11.3403\n",
      "Epoch 78/200 Batch 11, Loss 11.4679\n",
      "Epoch 78/200 Batch 12, Loss 11.4787\n",
      "Epoch 78/200 Batch 13, Loss 11.3164\n",
      "Epoch 78/200 Batch 14, Loss 11.3311\n",
      "Epoch 78/200 Batch 15, Loss 11.3719\n",
      "Epoch 78/200 Batch 16, Loss 11.3312\n",
      "Epoch 78/200 Batch 17, Loss 11.3321\n",
      "Epoch 78/200 Batch 18, Loss 11.0682\n",
      "Epoch 78/200 Batch 19, Loss 11.4091\n",
      "Epoch 79/200 Batch 0, Loss 11.4230\n",
      "Epoch 79/200 Batch 1, Loss 11.3653\n",
      "Epoch 79/200 Batch 2, Loss 11.2607\n",
      "Epoch 79/200 Batch 3, Loss 11.1816\n",
      "Epoch 79/200 Batch 4, Loss 11.3167\n",
      "Epoch 79/200 Batch 5, Loss 11.4228\n",
      "Epoch 79/200 Batch 6, Loss 11.3888\n",
      "Epoch 79/200 Batch 7, Loss 11.5627\n",
      "Epoch 79/200 Batch 8, Loss 11.4778\n",
      "Epoch 79/200 Batch 9, Loss 11.3209\n",
      "Epoch 79/200 Batch 10, Loss 11.4112\n",
      "Epoch 79/200 Batch 11, Loss 11.2698\n",
      "Epoch 79/200 Batch 12, Loss 11.2980\n",
      "Epoch 79/200 Batch 13, Loss 11.3197\n",
      "Epoch 79/200 Batch 14, Loss 11.3864\n",
      "Epoch 79/200 Batch 15, Loss 11.3522\n",
      "Epoch 79/200 Batch 16, Loss 11.3469\n",
      "Epoch 79/200 Batch 17, Loss 11.3268\n",
      "Epoch 79/200 Batch 18, Loss 11.1889\n",
      "Epoch 79/200 Batch 19, Loss 11.4182\n",
      "Epoch 80/200 Batch 0, Loss 11.3572\n",
      "Epoch 80/200 Batch 1, Loss 11.3451\n",
      "Epoch 80/200 Batch 2, Loss 11.4196\n",
      "Epoch 80/200 Batch 3, Loss 11.3527\n",
      "Epoch 80/200 Batch 4, Loss 11.5173\n",
      "Epoch 80/200 Batch 5, Loss 11.4511\n",
      "Epoch 80/200 Batch 6, Loss 11.4738\n",
      "Epoch 80/200 Batch 7, Loss 11.3806\n",
      "Epoch 80/200 Batch 8, Loss 11.2413\n",
      "Epoch 80/200 Batch 9, Loss 11.4786\n",
      "Epoch 80/200 Batch 10, Loss 11.3076\n",
      "Epoch 80/200 Batch 11, Loss 11.1890\n",
      "Epoch 80/200 Batch 12, Loss 11.3426\n",
      "Epoch 80/200 Batch 13, Loss 11.2940\n",
      "Epoch 80/200 Batch 14, Loss 11.3477\n",
      "Epoch 80/200 Batch 15, Loss 11.2806\n",
      "Epoch 80/200 Batch 16, Loss 11.3053\n",
      "Epoch 80/200 Batch 17, Loss 11.4236\n",
      "Epoch 80/200 Batch 18, Loss 11.4046\n",
      "Epoch 80/200 Batch 19, Loss 11.2878\n",
      "Epoch 81/200 Batch 0, Loss 11.1686\n",
      "Epoch 81/200 Batch 1, Loss 11.5026\n",
      "Epoch 81/200 Batch 2, Loss 11.2999\n",
      "Epoch 81/200 Batch 3, Loss 11.4446\n",
      "Epoch 81/200 Batch 4, Loss 11.4679\n",
      "Epoch 81/200 Batch 5, Loss 11.5049\n",
      "Epoch 81/200 Batch 6, Loss 11.3233\n",
      "Epoch 81/200 Batch 7, Loss 11.1847\n",
      "Epoch 81/200 Batch 8, Loss 11.4438\n",
      "Epoch 81/200 Batch 9, Loss 11.0811\n",
      "Epoch 81/200 Batch 10, Loss 11.3433\n",
      "Epoch 81/200 Batch 11, Loss 11.2537\n",
      "Epoch 81/200 Batch 12, Loss 11.3038\n",
      "Epoch 81/200 Batch 13, Loss 11.4127\n",
      "Epoch 81/200 Batch 14, Loss 11.3698\n",
      "Epoch 81/200 Batch 15, Loss 11.2597\n",
      "Epoch 81/200 Batch 16, Loss 11.3715\n",
      "Epoch 81/200 Batch 17, Loss 11.4965\n",
      "Epoch 81/200 Batch 18, Loss 11.1129\n",
      "Epoch 81/200 Batch 19, Loss 11.3658\n",
      "Epoch 82/200 Batch 0, Loss 11.2747\n",
      "Epoch 82/200 Batch 1, Loss 11.1895\n",
      "Epoch 82/200 Batch 2, Loss 11.1643\n",
      "Epoch 82/200 Batch 3, Loss 11.2014\n",
      "Epoch 82/200 Batch 4, Loss 11.2556\n",
      "Epoch 82/200 Batch 5, Loss 11.3511\n",
      "Epoch 82/200 Batch 6, Loss 11.3229\n",
      "Epoch 82/200 Batch 7, Loss 11.5052\n",
      "Epoch 82/200 Batch 8, Loss 11.3412\n",
      "Epoch 82/200 Batch 9, Loss 11.4647\n",
      "Epoch 82/200 Batch 10, Loss 11.4326\n",
      "Epoch 82/200 Batch 11, Loss 11.3999\n",
      "Epoch 82/200 Batch 12, Loss 11.4629\n",
      "Epoch 82/200 Batch 13, Loss 11.5034\n",
      "Epoch 82/200 Batch 14, Loss 11.4050\n",
      "Epoch 82/200 Batch 15, Loss 11.2918\n",
      "Epoch 82/200 Batch 16, Loss 11.4772\n",
      "Epoch 82/200 Batch 17, Loss 11.1147\n",
      "Epoch 82/200 Batch 18, Loss 11.2309\n",
      "Epoch 82/200 Batch 19, Loss 11.4027\n",
      "Epoch 83/200 Batch 0, Loss 11.2786\n",
      "Epoch 83/200 Batch 1, Loss 11.3949\n",
      "Epoch 83/200 Batch 2, Loss 11.3402\n",
      "Epoch 83/200 Batch 3, Loss 11.4108\n",
      "Epoch 83/200 Batch 4, Loss 11.3419\n",
      "Epoch 83/200 Batch 5, Loss 11.2854\n",
      "Epoch 83/200 Batch 6, Loss 11.3733\n",
      "Epoch 83/200 Batch 7, Loss 11.4981\n",
      "Epoch 83/200 Batch 8, Loss 11.2141\n",
      "Epoch 83/200 Batch 9, Loss 11.3650\n",
      "Epoch 83/200 Batch 10, Loss 11.4244\n",
      "Epoch 83/200 Batch 11, Loss 11.3098\n",
      "Epoch 83/200 Batch 12, Loss 11.3435\n",
      "Epoch 83/200 Batch 13, Loss 11.2591\n",
      "Epoch 83/200 Batch 14, Loss 11.4241\n",
      "Epoch 83/200 Batch 15, Loss 11.3336\n",
      "Epoch 83/200 Batch 16, Loss 11.5431\n",
      "Epoch 83/200 Batch 17, Loss 11.2320\n",
      "Epoch 83/200 Batch 18, Loss 11.4256\n",
      "Epoch 83/200 Batch 19, Loss 11.5916\n",
      "Epoch 84/200 Batch 0, Loss 11.3412\n",
      "Epoch 84/200 Batch 1, Loss 11.4067\n",
      "Epoch 84/200 Batch 2, Loss 11.1339\n",
      "Epoch 84/200 Batch 3, Loss 11.4171\n",
      "Epoch 84/200 Batch 4, Loss 11.2632\n",
      "Epoch 84/200 Batch 5, Loss 11.3389\n",
      "Epoch 84/200 Batch 6, Loss 11.2323\n",
      "Epoch 84/200 Batch 7, Loss 11.2705\n",
      "Epoch 84/200 Batch 8, Loss 11.3509\n",
      "Epoch 84/200 Batch 9, Loss 11.2534\n",
      "Epoch 84/200 Batch 10, Loss 11.3433\n",
      "Epoch 84/200 Batch 11, Loss 11.2409\n",
      "Epoch 84/200 Batch 12, Loss 11.3930\n",
      "Epoch 84/200 Batch 13, Loss 11.3468\n",
      "Epoch 84/200 Batch 14, Loss 11.4265\n",
      "Epoch 84/200 Batch 15, Loss 11.5705\n",
      "Epoch 84/200 Batch 16, Loss 11.2613\n",
      "Epoch 84/200 Batch 17, Loss 11.4179\n",
      "Epoch 84/200 Batch 18, Loss 11.4863\n",
      "Epoch 84/200 Batch 19, Loss 11.4146\n",
      "Epoch 85/200 Batch 0, Loss 11.1883\n",
      "Epoch 85/200 Batch 1, Loss 11.4737\n",
      "Epoch 85/200 Batch 2, Loss 11.3650\n",
      "Epoch 85/200 Batch 3, Loss 11.3387\n",
      "Epoch 85/200 Batch 4, Loss 11.2480\n",
      "Epoch 85/200 Batch 5, Loss 11.2887\n",
      "Epoch 85/200 Batch 6, Loss 11.1660\n",
      "Epoch 85/200 Batch 7, Loss 11.2409\n",
      "Epoch 85/200 Batch 8, Loss 11.3230\n",
      "Epoch 85/200 Batch 9, Loss 11.5052\n",
      "Epoch 85/200 Batch 10, Loss 11.3790\n",
      "Epoch 85/200 Batch 11, Loss 11.3200\n",
      "Epoch 85/200 Batch 12, Loss 11.3168\n",
      "Epoch 85/200 Batch 13, Loss 11.4538\n",
      "Epoch 85/200 Batch 14, Loss 11.3920\n",
      "Epoch 85/200 Batch 15, Loss 11.3668\n",
      "Epoch 85/200 Batch 16, Loss 11.3503\n",
      "Epoch 85/200 Batch 17, Loss 11.4259\n",
      "Epoch 85/200 Batch 18, Loss 11.3224\n",
      "Epoch 85/200 Batch 19, Loss 11.3575\n",
      "Epoch 86/200 Batch 0, Loss 11.3341\n",
      "Epoch 86/200 Batch 1, Loss 11.3578\n",
      "Epoch 86/200 Batch 2, Loss 11.5492\n",
      "Epoch 86/200 Batch 3, Loss 11.3795\n",
      "Epoch 86/200 Batch 4, Loss 11.2732\n",
      "Epoch 86/200 Batch 5, Loss 11.2408\n",
      "Epoch 86/200 Batch 6, Loss 11.4910\n",
      "Epoch 86/200 Batch 7, Loss 11.4129\n",
      "Epoch 86/200 Batch 8, Loss 11.2473\n",
      "Epoch 86/200 Batch 9, Loss 11.2913\n",
      "Epoch 86/200 Batch 10, Loss 11.3477\n",
      "Epoch 86/200 Batch 11, Loss 11.3002\n",
      "Epoch 86/200 Batch 12, Loss 11.2593\n",
      "Epoch 86/200 Batch 13, Loss 11.3963\n",
      "Epoch 86/200 Batch 14, Loss 11.5043\n",
      "Epoch 86/200 Batch 15, Loss 11.3330\n",
      "Epoch 86/200 Batch 16, Loss 11.3126\n",
      "Epoch 86/200 Batch 17, Loss 11.2882\n",
      "Epoch 86/200 Batch 18, Loss 11.3224\n",
      "Epoch 86/200 Batch 19, Loss 11.3544\n",
      "Epoch 87/200 Batch 0, Loss 11.1948\n",
      "Epoch 87/200 Batch 1, Loss 11.2635\n",
      "Epoch 87/200 Batch 2, Loss 11.2951\n",
      "Epoch 87/200 Batch 3, Loss 11.4340\n",
      "Epoch 87/200 Batch 4, Loss 11.4868\n",
      "Epoch 87/200 Batch 5, Loss 11.0867\n",
      "Epoch 87/200 Batch 6, Loss 11.3050\n",
      "Epoch 87/200 Batch 7, Loss 11.4331\n",
      "Epoch 87/200 Batch 8, Loss 11.3668\n",
      "Epoch 87/200 Batch 9, Loss 11.3724\n",
      "Epoch 87/200 Batch 10, Loss 11.3833\n",
      "Epoch 87/200 Batch 11, Loss 11.4047\n",
      "Epoch 87/200 Batch 12, Loss 11.4535\n",
      "Epoch 87/200 Batch 13, Loss 11.4196\n",
      "Epoch 87/200 Batch 14, Loss 11.2363\n",
      "Epoch 87/200 Batch 15, Loss 11.4139\n",
      "Epoch 87/200 Batch 16, Loss 11.4300\n",
      "Epoch 87/200 Batch 17, Loss 11.3837\n",
      "Epoch 87/200 Batch 18, Loss 11.1757\n",
      "Epoch 87/200 Batch 19, Loss 11.2802\n",
      "Epoch 88/200 Batch 0, Loss 11.5208\n",
      "Epoch 88/200 Batch 1, Loss 11.2352\n",
      "Epoch 88/200 Batch 2, Loss 11.4260\n",
      "Epoch 88/200 Batch 3, Loss 11.3076\n",
      "Epoch 88/200 Batch 4, Loss 11.2865\n",
      "Epoch 88/200 Batch 5, Loss 11.4054\n",
      "Epoch 88/200 Batch 6, Loss 11.2814\n",
      "Epoch 88/200 Batch 7, Loss 11.4174\n",
      "Epoch 88/200 Batch 8, Loss 11.3641\n",
      "Epoch 88/200 Batch 9, Loss 11.3110\n",
      "Epoch 88/200 Batch 10, Loss 11.3675\n",
      "Epoch 88/200 Batch 11, Loss 11.1644\n",
      "Epoch 88/200 Batch 12, Loss 11.3014\n",
      "Epoch 88/200 Batch 13, Loss 11.3402\n",
      "Epoch 88/200 Batch 14, Loss 11.3512\n",
      "Epoch 88/200 Batch 15, Loss 11.2013\n",
      "Epoch 88/200 Batch 16, Loss 11.3435\n",
      "Epoch 88/200 Batch 17, Loss 11.3642\n",
      "Epoch 88/200 Batch 18, Loss 11.4612\n",
      "Epoch 88/200 Batch 19, Loss 11.5043\n",
      "Epoch 89/200 Batch 0, Loss 11.3917\n",
      "Epoch 89/200 Batch 1, Loss 11.2962\n",
      "Epoch 89/200 Batch 2, Loss 11.2714\n",
      "Epoch 89/200 Batch 3, Loss 11.3454\n",
      "Epoch 89/200 Batch 4, Loss 11.3194\n",
      "Epoch 89/200 Batch 5, Loss 11.2278\n",
      "Epoch 89/200 Batch 6, Loss 11.3667\n",
      "Epoch 89/200 Batch 7, Loss 11.2867\n",
      "Epoch 89/200 Batch 8, Loss 11.6103\n",
      "Epoch 89/200 Batch 9, Loss 11.4033\n",
      "Epoch 89/200 Batch 10, Loss 11.3635\n",
      "Epoch 89/200 Batch 11, Loss 11.2437\n",
      "Epoch 89/200 Batch 12, Loss 11.3255\n",
      "Epoch 89/200 Batch 13, Loss 11.4052\n",
      "Epoch 89/200 Batch 14, Loss 11.2935\n",
      "Epoch 89/200 Batch 15, Loss 11.4024\n",
      "Epoch 89/200 Batch 16, Loss 11.3321\n",
      "Epoch 89/200 Batch 17, Loss 11.4582\n",
      "Epoch 89/200 Batch 18, Loss 11.4146\n",
      "Epoch 89/200 Batch 19, Loss 11.4329\n",
      "Epoch 90/200 Batch 0, Loss 11.4770\n",
      "Epoch 90/200 Batch 1, Loss 11.1382\n",
      "Epoch 90/200 Batch 2, Loss 11.3295\n",
      "Epoch 90/200 Batch 3, Loss 11.3006\n",
      "Epoch 90/200 Batch 4, Loss 11.3898\n",
      "Epoch 90/200 Batch 5, Loss 11.3512\n",
      "Epoch 90/200 Batch 6, Loss 11.3160\n",
      "Epoch 90/200 Batch 7, Loss 11.2996\n",
      "Epoch 90/200 Batch 8, Loss 11.2737\n",
      "Epoch 90/200 Batch 9, Loss 11.5302\n",
      "Epoch 90/200 Batch 10, Loss 11.3899\n",
      "Epoch 90/200 Batch 11, Loss 11.4612\n",
      "Epoch 90/200 Batch 12, Loss 11.2035\n",
      "Epoch 90/200 Batch 13, Loss 11.2284\n",
      "Epoch 90/200 Batch 14, Loss 11.3137\n",
      "Epoch 90/200 Batch 15, Loss 11.2174\n",
      "Epoch 90/200 Batch 16, Loss 11.3932\n",
      "Epoch 90/200 Batch 17, Loss 11.4937\n",
      "Epoch 90/200 Batch 18, Loss 11.3022\n",
      "Epoch 90/200 Batch 19, Loss 11.5703\n",
      "Epoch 91/200 Batch 0, Loss 11.2776\n",
      "Epoch 91/200 Batch 1, Loss 11.3480\n",
      "Epoch 91/200 Batch 2, Loss 11.1715\n",
      "Epoch 91/200 Batch 3, Loss 11.4975\n",
      "Epoch 91/200 Batch 4, Loss 11.2532\n",
      "Epoch 91/200 Batch 5, Loss 11.4053\n",
      "Epoch 91/200 Batch 6, Loss 11.3516\n",
      "Epoch 91/200 Batch 7, Loss 11.4584\n",
      "Epoch 91/200 Batch 8, Loss 11.2564\n",
      "Epoch 91/200 Batch 9, Loss 11.3531\n",
      "Epoch 91/200 Batch 10, Loss 11.2161\n",
      "Epoch 91/200 Batch 11, Loss 11.3490\n",
      "Epoch 91/200 Batch 12, Loss 11.2636\n",
      "Epoch 91/200 Batch 13, Loss 11.3603\n",
      "Epoch 91/200 Batch 14, Loss 11.4473\n",
      "Epoch 91/200 Batch 15, Loss 11.3589\n",
      "Epoch 91/200 Batch 16, Loss 11.3853\n",
      "Epoch 91/200 Batch 17, Loss 11.4528\n",
      "Epoch 91/200 Batch 18, Loss 11.3385\n",
      "Epoch 91/200 Batch 19, Loss 11.3470\n",
      "Epoch 92/200 Batch 0, Loss 11.2856\n",
      "Epoch 92/200 Batch 1, Loss 11.4277\n",
      "Epoch 92/200 Batch 2, Loss 11.2949\n",
      "Epoch 92/200 Batch 3, Loss 11.2345\n",
      "Epoch 92/200 Batch 4, Loss 11.3745\n",
      "Epoch 92/200 Batch 5, Loss 11.4028\n",
      "Epoch 92/200 Batch 6, Loss 11.1630\n",
      "Epoch 92/200 Batch 7, Loss 11.3705\n",
      "Epoch 92/200 Batch 8, Loss 11.2112\n",
      "Epoch 92/200 Batch 9, Loss 11.2745\n",
      "Epoch 92/200 Batch 10, Loss 11.3929\n",
      "Epoch 92/200 Batch 11, Loss 11.3287\n",
      "Epoch 92/200 Batch 12, Loss 11.3939\n",
      "Epoch 92/200 Batch 13, Loss 11.5181\n",
      "Epoch 92/200 Batch 14, Loss 11.3463\n",
      "Epoch 92/200 Batch 15, Loss 11.2189\n",
      "Epoch 92/200 Batch 16, Loss 11.3853\n",
      "Epoch 92/200 Batch 17, Loss 11.3623\n",
      "Epoch 92/200 Batch 18, Loss 11.3725\n",
      "Epoch 92/200 Batch 19, Loss 11.3010\n",
      "Epoch 93/200 Batch 0, Loss 11.3161\n",
      "Epoch 93/200 Batch 1, Loss 11.2922\n",
      "Epoch 93/200 Batch 2, Loss 11.3150\n",
      "Epoch 93/200 Batch 3, Loss 11.2993\n",
      "Epoch 93/200 Batch 4, Loss 11.5296\n",
      "Epoch 93/200 Batch 5, Loss 11.2497\n",
      "Epoch 93/200 Batch 6, Loss 11.1856\n",
      "Epoch 93/200 Batch 7, Loss 11.3359\n",
      "Epoch 93/200 Batch 8, Loss 11.2731\n",
      "Epoch 93/200 Batch 9, Loss 11.5073\n",
      "Epoch 93/200 Batch 10, Loss 11.4943\n",
      "Epoch 93/200 Batch 11, Loss 11.3607\n",
      "Epoch 93/200 Batch 12, Loss 11.3439\n",
      "Epoch 93/200 Batch 13, Loss 11.3566\n",
      "Epoch 93/200 Batch 14, Loss 11.3282\n",
      "Epoch 93/200 Batch 15, Loss 11.0671\n",
      "Epoch 93/200 Batch 16, Loss 11.3756\n",
      "Epoch 93/200 Batch 17, Loss 11.4055\n",
      "Epoch 93/200 Batch 18, Loss 11.4054\n",
      "Epoch 93/200 Batch 19, Loss 11.3353\n",
      "Epoch 94/200 Batch 0, Loss 11.2967\n",
      "Epoch 94/200 Batch 1, Loss 11.2077\n",
      "Epoch 94/200 Batch 2, Loss 11.3214\n",
      "Epoch 94/200 Batch 3, Loss 11.2744\n",
      "Epoch 94/200 Batch 4, Loss 11.2677\n",
      "Epoch 94/200 Batch 5, Loss 11.2634\n",
      "Epoch 94/200 Batch 6, Loss 11.2159\n",
      "Epoch 94/200 Batch 7, Loss 11.5063\n",
      "Epoch 94/200 Batch 8, Loss 11.5385\n",
      "Epoch 94/200 Batch 9, Loss 11.1612\n",
      "Epoch 94/200 Batch 10, Loss 11.3906\n",
      "Epoch 94/200 Batch 11, Loss 11.2071\n",
      "Epoch 94/200 Batch 12, Loss 11.3734\n",
      "Epoch 94/200 Batch 13, Loss 11.3900\n",
      "Epoch 94/200 Batch 14, Loss 11.3707\n",
      "Epoch 94/200 Batch 15, Loss 11.2446\n",
      "Epoch 94/200 Batch 16, Loss 11.2312\n",
      "Epoch 94/200 Batch 17, Loss 11.4604\n",
      "Epoch 94/200 Batch 18, Loss 11.4879\n",
      "Epoch 94/200 Batch 19, Loss 11.4664\n",
      "Epoch 95/200 Batch 0, Loss 11.3925\n",
      "Epoch 95/200 Batch 1, Loss 11.2463\n",
      "Epoch 95/200 Batch 2, Loss 11.3993\n",
      "Epoch 95/200 Batch 3, Loss 11.2877\n",
      "Epoch 95/200 Batch 4, Loss 11.4765\n",
      "Epoch 95/200 Batch 5, Loss 11.2866\n",
      "Epoch 95/200 Batch 6, Loss 11.1227\n",
      "Epoch 95/200 Batch 7, Loss 11.3403\n",
      "Epoch 95/200 Batch 8, Loss 11.3310\n",
      "Epoch 95/200 Batch 9, Loss 11.4095\n",
      "Epoch 95/200 Batch 10, Loss 11.4832\n",
      "Epoch 95/200 Batch 11, Loss 11.4103\n",
      "Epoch 95/200 Batch 12, Loss 11.2968\n",
      "Epoch 95/200 Batch 13, Loss 11.3941\n",
      "Epoch 95/200 Batch 14, Loss 11.2218\n",
      "Epoch 95/200 Batch 15, Loss 11.3858\n",
      "Epoch 95/200 Batch 16, Loss 11.3474\n",
      "Epoch 95/200 Batch 17, Loss 11.3552\n",
      "Epoch 95/200 Batch 18, Loss 11.3080\n",
      "Epoch 95/200 Batch 19, Loss 11.2704\n",
      "Epoch 96/200 Batch 0, Loss 11.3284\n",
      "Epoch 96/200 Batch 1, Loss 11.2818\n",
      "Epoch 96/200 Batch 2, Loss 11.2084\n",
      "Epoch 96/200 Batch 3, Loss 11.3701\n",
      "Epoch 96/200 Batch 4, Loss 11.3865\n",
      "Epoch 96/200 Batch 5, Loss 11.3296\n",
      "Epoch 96/200 Batch 6, Loss 11.5479\n",
      "Epoch 96/200 Batch 7, Loss 11.3817\n",
      "Epoch 96/200 Batch 8, Loss 11.1937\n",
      "Epoch 96/200 Batch 9, Loss 11.1392\n",
      "Epoch 96/200 Batch 10, Loss 11.2130\n",
      "Epoch 96/200 Batch 11, Loss 11.2745\n",
      "Epoch 96/200 Batch 12, Loss 11.3721\n",
      "Epoch 96/200 Batch 13, Loss 11.3062\n",
      "Epoch 96/200 Batch 14, Loss 11.3546\n",
      "Epoch 96/200 Batch 15, Loss 11.5925\n",
      "Epoch 96/200 Batch 16, Loss 11.4469\n",
      "Epoch 96/200 Batch 17, Loss 11.4884\n",
      "Epoch 96/200 Batch 18, Loss 11.3762\n",
      "Epoch 96/200 Batch 19, Loss 11.4518\n",
      "Epoch 97/200 Batch 0, Loss 11.2059\n",
      "Epoch 97/200 Batch 1, Loss 11.2377\n",
      "Epoch 97/200 Batch 2, Loss 11.3308\n",
      "Epoch 97/200 Batch 3, Loss 11.3259\n",
      "Epoch 97/200 Batch 4, Loss 11.4658\n",
      "Epoch 97/200 Batch 5, Loss 11.2680\n",
      "Epoch 97/200 Batch 6, Loss 11.5637\n",
      "Epoch 97/200 Batch 7, Loss 11.2757\n",
      "Epoch 97/200 Batch 8, Loss 11.3888\n",
      "Epoch 97/200 Batch 9, Loss 11.1761\n",
      "Epoch 97/200 Batch 10, Loss 11.4413\n",
      "Epoch 97/200 Batch 11, Loss 11.3934\n",
      "Epoch 97/200 Batch 12, Loss 11.3148\n",
      "Epoch 97/200 Batch 13, Loss 11.4339\n",
      "Epoch 97/200 Batch 14, Loss 11.5000\n",
      "Epoch 97/200 Batch 15, Loss 11.2155\n",
      "Epoch 97/200 Batch 16, Loss 11.3434\n",
      "Epoch 97/200 Batch 17, Loss 11.1883\n",
      "Epoch 97/200 Batch 18, Loss 11.5398\n",
      "Epoch 97/200 Batch 19, Loss 11.3085\n",
      "Epoch 98/200 Batch 0, Loss 11.1992\n",
      "Epoch 98/200 Batch 1, Loss 11.2929\n",
      "Epoch 98/200 Batch 2, Loss 11.2786\n",
      "Epoch 98/200 Batch 3, Loss 11.2655\n",
      "Epoch 98/200 Batch 4, Loss 11.3670\n",
      "Epoch 98/200 Batch 5, Loss 11.3553\n",
      "Epoch 98/200 Batch 6, Loss 11.3967\n",
      "Epoch 98/200 Batch 7, Loss 11.2077\n",
      "Epoch 98/200 Batch 8, Loss 11.3924\n",
      "Epoch 98/200 Batch 9, Loss 11.2720\n",
      "Epoch 98/200 Batch 10, Loss 11.4491\n",
      "Epoch 98/200 Batch 11, Loss 11.2649\n",
      "Epoch 98/200 Batch 12, Loss 11.2603\n",
      "Epoch 98/200 Batch 13, Loss 11.3260\n",
      "Epoch 98/200 Batch 14, Loss 11.4504\n",
      "Epoch 98/200 Batch 15, Loss 11.4823\n",
      "Epoch 98/200 Batch 16, Loss 11.3995\n",
      "Epoch 98/200 Batch 17, Loss 11.3383\n",
      "Epoch 98/200 Batch 18, Loss 11.2415\n",
      "Epoch 98/200 Batch 19, Loss 11.4178\n",
      "Epoch 99/200 Batch 0, Loss 11.2388\n",
      "Epoch 99/200 Batch 1, Loss 11.4184\n",
      "Epoch 99/200 Batch 2, Loss 11.4710\n",
      "Epoch 99/200 Batch 3, Loss 11.2401\n",
      "Epoch 99/200 Batch 4, Loss 11.4563\n",
      "Epoch 99/200 Batch 5, Loss 11.4058\n",
      "Epoch 99/200 Batch 6, Loss 11.3223\n",
      "Epoch 99/200 Batch 7, Loss 11.3306\n",
      "Epoch 99/200 Batch 8, Loss 11.3378\n",
      "Epoch 99/200 Batch 9, Loss 11.3308\n",
      "Epoch 99/200 Batch 10, Loss 11.4230\n",
      "Epoch 99/200 Batch 11, Loss 11.2425\n",
      "Epoch 99/200 Batch 12, Loss 11.3925\n",
      "Epoch 99/200 Batch 13, Loss 11.3144\n",
      "Epoch 99/200 Batch 14, Loss 11.5351\n",
      "Epoch 99/200 Batch 15, Loss 11.2554\n",
      "Epoch 99/200 Batch 16, Loss 11.4749\n",
      "Epoch 99/200 Batch 17, Loss 11.3983\n",
      "Epoch 99/200 Batch 18, Loss 11.2849\n",
      "Epoch 99/200 Batch 19, Loss 11.5691\n",
      "Epoch 100/200 Batch 0, Loss 11.3205\n",
      "Epoch 100/200 Batch 1, Loss 11.2867\n",
      "Epoch 100/200 Batch 2, Loss 11.5002\n",
      "Epoch 100/200 Batch 3, Loss 11.3460\n",
      "Epoch 100/200 Batch 4, Loss 11.3262\n",
      "Epoch 100/200 Batch 5, Loss 11.4717\n",
      "Epoch 100/200 Batch 6, Loss 11.3578\n",
      "Epoch 100/200 Batch 7, Loss 11.2690\n",
      "Epoch 100/200 Batch 8, Loss 11.3855\n",
      "Epoch 100/200 Batch 9, Loss 11.2871\n",
      "Epoch 100/200 Batch 10, Loss 11.4087\n",
      "Epoch 100/200 Batch 11, Loss 11.4451\n",
      "Epoch 100/200 Batch 12, Loss 11.1421\n",
      "Epoch 100/200 Batch 13, Loss 11.3299\n",
      "Epoch 100/200 Batch 14, Loss 11.3430\n",
      "Epoch 100/200 Batch 15, Loss 11.4281\n",
      "Epoch 100/200 Batch 16, Loss 11.3547\n",
      "Epoch 100/200 Batch 17, Loss 11.1713\n",
      "Epoch 100/200 Batch 18, Loss 11.4348\n",
      "Epoch 100/200 Batch 19, Loss 11.2283\n",
      "Epoch 101/200 Batch 0, Loss 11.3585\n",
      "Epoch 101/200 Batch 1, Loss 11.4233\n",
      "Epoch 101/200 Batch 2, Loss 11.3528\n",
      "Epoch 101/200 Batch 3, Loss 11.4299\n",
      "Epoch 101/200 Batch 4, Loss 11.1614\n",
      "Epoch 101/200 Batch 5, Loss 11.3218\n",
      "Epoch 101/200 Batch 6, Loss 11.3393\n",
      "Epoch 101/200 Batch 7, Loss 11.3160\n",
      "Epoch 101/200 Batch 8, Loss 11.2568\n",
      "Epoch 101/200 Batch 9, Loss 11.3873\n",
      "Epoch 101/200 Batch 10, Loss 11.3230\n",
      "Epoch 101/200 Batch 11, Loss 11.5140\n",
      "Epoch 101/200 Batch 12, Loss 11.3804\n",
      "Epoch 101/200 Batch 13, Loss 11.3405\n",
      "Epoch 101/200 Batch 14, Loss 11.2410\n",
      "Epoch 101/200 Batch 15, Loss 11.2898\n",
      "Epoch 101/200 Batch 16, Loss 11.3329\n",
      "Epoch 101/200 Batch 17, Loss 11.3274\n",
      "Epoch 101/200 Batch 18, Loss 11.4037\n",
      "Epoch 101/200 Batch 19, Loss 11.1931\n",
      "Epoch 102/200 Batch 0, Loss 11.1945\n",
      "Epoch 102/200 Batch 1, Loss 11.2408\n",
      "Epoch 102/200 Batch 2, Loss 11.3312\n",
      "Epoch 102/200 Batch 3, Loss 11.3781\n",
      "Epoch 102/200 Batch 4, Loss 11.4225\n",
      "Epoch 102/200 Batch 5, Loss 11.2394\n",
      "Epoch 102/200 Batch 6, Loss 11.2925\n",
      "Epoch 102/200 Batch 7, Loss 11.4257\n",
      "Epoch 102/200 Batch 8, Loss 11.2139\n",
      "Epoch 102/200 Batch 9, Loss 11.2230\n",
      "Epoch 102/200 Batch 10, Loss 11.3108\n",
      "Epoch 102/200 Batch 11, Loss 11.2311\n",
      "Epoch 102/200 Batch 12, Loss 11.3104\n",
      "Epoch 102/200 Batch 13, Loss 11.2640\n",
      "Epoch 102/200 Batch 14, Loss 11.4667\n",
      "Epoch 102/200 Batch 15, Loss 11.2517\n",
      "Epoch 102/200 Batch 16, Loss 11.3284\n",
      "Epoch 102/200 Batch 17, Loss 11.3638\n",
      "Epoch 102/200 Batch 18, Loss 11.5630\n",
      "Epoch 102/200 Batch 19, Loss 11.4319\n",
      "Epoch 103/200 Batch 0, Loss 11.3595\n",
      "Epoch 103/200 Batch 1, Loss 11.2819\n",
      "Epoch 103/200 Batch 2, Loss 11.5383\n",
      "Epoch 103/200 Batch 3, Loss 11.4001\n",
      "Epoch 103/200 Batch 4, Loss 11.2640\n",
      "Epoch 103/200 Batch 5, Loss 11.3023\n",
      "Epoch 103/200 Batch 6, Loss 11.3021\n",
      "Epoch 103/200 Batch 7, Loss 11.2717\n",
      "Epoch 103/200 Batch 8, Loss 11.1911\n",
      "Epoch 103/200 Batch 9, Loss 11.3407\n",
      "Epoch 103/200 Batch 10, Loss 11.2936\n",
      "Epoch 103/200 Batch 11, Loss 11.3236\n",
      "Epoch 103/200 Batch 12, Loss 11.2095\n",
      "Epoch 103/200 Batch 13, Loss 11.3377\n",
      "Epoch 103/200 Batch 14, Loss 11.3625\n",
      "Epoch 103/200 Batch 15, Loss 11.3770\n",
      "Epoch 103/200 Batch 16, Loss 11.4305\n",
      "Epoch 103/200 Batch 17, Loss 11.3278\n",
      "Epoch 103/200 Batch 18, Loss 11.2806\n",
      "Epoch 103/200 Batch 19, Loss 11.2277\n",
      "Epoch 104/200 Batch 0, Loss 11.2909\n",
      "Epoch 104/200 Batch 1, Loss 11.3139\n",
      "Epoch 104/200 Batch 2, Loss 11.5545\n",
      "Epoch 104/200 Batch 3, Loss 11.0814\n",
      "Epoch 104/200 Batch 4, Loss 11.4278\n",
      "Epoch 104/200 Batch 5, Loss 11.4899\n",
      "Epoch 104/200 Batch 6, Loss 11.3081\n",
      "Epoch 104/200 Batch 7, Loss 11.3185\n",
      "Epoch 104/200 Batch 8, Loss 11.3315\n",
      "Epoch 104/200 Batch 9, Loss 11.2223\n",
      "Epoch 104/200 Batch 10, Loss 11.3016\n",
      "Epoch 104/200 Batch 11, Loss 11.3544\n",
      "Epoch 104/200 Batch 12, Loss 11.3955\n",
      "Epoch 104/200 Batch 13, Loss 11.3250\n",
      "Epoch 104/200 Batch 14, Loss 11.1312\n",
      "Epoch 104/200 Batch 15, Loss 11.3516\n",
      "Epoch 104/200 Batch 16, Loss 11.3467\n",
      "Epoch 104/200 Batch 17, Loss 11.3714\n",
      "Epoch 104/200 Batch 18, Loss 11.2358\n",
      "Epoch 104/200 Batch 19, Loss 11.3402\n",
      "Epoch 105/200 Batch 0, Loss 11.2796\n",
      "Epoch 105/200 Batch 1, Loss 11.0409\n",
      "Epoch 105/200 Batch 2, Loss 11.1027\n",
      "Epoch 105/200 Batch 3, Loss 11.2270\n",
      "Epoch 105/200 Batch 4, Loss 11.3353\n",
      "Epoch 105/200 Batch 5, Loss 11.3960\n",
      "Epoch 105/200 Batch 6, Loss 11.3496\n",
      "Epoch 105/200 Batch 7, Loss 11.3692\n",
      "Epoch 105/200 Batch 8, Loss 11.4756\n",
      "Epoch 105/200 Batch 9, Loss 11.4087\n",
      "Epoch 105/200 Batch 10, Loss 11.2485\n",
      "Epoch 105/200 Batch 11, Loss 11.5708\n",
      "Epoch 105/200 Batch 12, Loss 11.3899\n",
      "Epoch 105/200 Batch 13, Loss 11.2834\n",
      "Epoch 105/200 Batch 14, Loss 11.4112\n",
      "Epoch 105/200 Batch 15, Loss 11.2137\n",
      "Epoch 105/200 Batch 16, Loss 11.2967\n",
      "Epoch 105/200 Batch 17, Loss 11.4779\n",
      "Epoch 105/200 Batch 18, Loss 11.3907\n",
      "Epoch 105/200 Batch 19, Loss 11.4643\n",
      "Epoch 106/200 Batch 0, Loss 11.4215\n",
      "Epoch 106/200 Batch 1, Loss 11.2528\n",
      "Epoch 106/200 Batch 2, Loss 11.1635\n",
      "Epoch 106/200 Batch 3, Loss 11.2551\n",
      "Epoch 106/200 Batch 4, Loss 11.1943\n",
      "Epoch 106/200 Batch 5, Loss 11.2365\n",
      "Epoch 106/200 Batch 6, Loss 11.4511\n",
      "Epoch 106/200 Batch 7, Loss 11.3196\n",
      "Epoch 106/200 Batch 8, Loss 11.2609\n",
      "Epoch 106/200 Batch 9, Loss 11.4537\n",
      "Epoch 106/200 Batch 10, Loss 11.4245\n",
      "Epoch 106/200 Batch 11, Loss 11.2648\n",
      "Epoch 106/200 Batch 12, Loss 11.1527\n",
      "Epoch 106/200 Batch 13, Loss 11.4545\n",
      "Epoch 106/200 Batch 14, Loss 11.4846\n",
      "Epoch 106/200 Batch 15, Loss 11.3160\n",
      "Epoch 106/200 Batch 16, Loss 11.2685\n",
      "Epoch 106/200 Batch 17, Loss 11.2935\n",
      "Epoch 106/200 Batch 18, Loss 11.2865\n",
      "Epoch 106/200 Batch 19, Loss 11.6633\n",
      "Epoch 107/200 Batch 0, Loss 11.3670\n",
      "Epoch 107/200 Batch 1, Loss 11.3789\n",
      "Epoch 107/200 Batch 2, Loss 11.2801\n",
      "Epoch 107/200 Batch 3, Loss 11.2761\n",
      "Epoch 107/200 Batch 4, Loss 11.3881\n",
      "Epoch 107/200 Batch 5, Loss 11.1902\n",
      "Epoch 107/200 Batch 6, Loss 11.3134\n",
      "Epoch 107/200 Batch 7, Loss 11.3456\n",
      "Epoch 107/200 Batch 8, Loss 11.3430\n",
      "Epoch 107/200 Batch 9, Loss 11.3818\n",
      "Epoch 107/200 Batch 10, Loss 11.4150\n",
      "Epoch 107/200 Batch 11, Loss 11.4395\n",
      "Epoch 107/200 Batch 12, Loss 11.3521\n",
      "Epoch 107/200 Batch 13, Loss 11.3475\n",
      "Epoch 107/200 Batch 14, Loss 11.2348\n",
      "Epoch 107/200 Batch 15, Loss 11.3412\n",
      "Epoch 107/200 Batch 16, Loss 11.0774\n",
      "Epoch 107/200 Batch 17, Loss 11.3830\n",
      "Epoch 107/200 Batch 18, Loss 11.3685\n",
      "Epoch 107/200 Batch 19, Loss 11.5487\n",
      "Epoch 108/200 Batch 0, Loss 11.2706\n",
      "Epoch 108/200 Batch 1, Loss 11.1766\n",
      "Epoch 108/200 Batch 2, Loss 11.2639\n",
      "Epoch 108/200 Batch 3, Loss 11.3671\n",
      "Epoch 108/200 Batch 4, Loss 11.3101\n",
      "Epoch 108/200 Batch 5, Loss 11.4243\n",
      "Epoch 108/200 Batch 6, Loss 11.2979\n",
      "Epoch 108/200 Batch 7, Loss 11.2841\n",
      "Epoch 108/200 Batch 8, Loss 11.3411\n",
      "Epoch 108/200 Batch 9, Loss 11.5416\n",
      "Epoch 108/200 Batch 10, Loss 11.3428\n",
      "Epoch 108/200 Batch 11, Loss 11.4726\n",
      "Epoch 108/200 Batch 12, Loss 11.1110\n",
      "Epoch 108/200 Batch 13, Loss 11.4057\n",
      "Epoch 108/200 Batch 14, Loss 11.3548\n",
      "Epoch 108/200 Batch 15, Loss 11.3481\n",
      "Epoch 108/200 Batch 16, Loss 11.3171\n",
      "Epoch 108/200 Batch 17, Loss 11.3547\n",
      "Epoch 108/200 Batch 18, Loss 11.3266\n",
      "Epoch 108/200 Batch 19, Loss 11.4430\n",
      "Epoch 109/200 Batch 0, Loss 11.1119\n",
      "Epoch 109/200 Batch 1, Loss 11.2656\n",
      "Epoch 109/200 Batch 2, Loss 11.5637\n",
      "Epoch 109/200 Batch 3, Loss 11.3043\n",
      "Epoch 109/200 Batch 4, Loss 11.2617\n",
      "Epoch 109/200 Batch 5, Loss 11.3112\n",
      "Epoch 109/200 Batch 6, Loss 11.3750\n",
      "Epoch 109/200 Batch 7, Loss 11.4058\n",
      "Epoch 109/200 Batch 8, Loss 11.2486\n",
      "Epoch 109/200 Batch 9, Loss 11.2022\n",
      "Epoch 109/200 Batch 10, Loss 11.2564\n",
      "Epoch 109/200 Batch 11, Loss 11.4182\n",
      "Epoch 109/200 Batch 12, Loss 11.3264\n",
      "Epoch 109/200 Batch 13, Loss 11.4373\n",
      "Epoch 109/200 Batch 14, Loss 11.3837\n",
      "Epoch 109/200 Batch 15, Loss 11.3805\n",
      "Epoch 109/200 Batch 16, Loss 11.3207\n",
      "Epoch 109/200 Batch 17, Loss 11.3298\n",
      "Epoch 109/200 Batch 18, Loss 11.4754\n",
      "Epoch 109/200 Batch 19, Loss 11.2089\n",
      "Epoch 110/200 Batch 0, Loss 11.2909\n",
      "Epoch 110/200 Batch 1, Loss 11.5452\n",
      "Epoch 110/200 Batch 2, Loss 11.1800\n",
      "Epoch 110/200 Batch 3, Loss 11.3231\n",
      "Epoch 110/200 Batch 4, Loss 11.3646\n",
      "Epoch 110/200 Batch 5, Loss 11.3858\n",
      "Epoch 110/200 Batch 6, Loss 11.2993\n",
      "Epoch 110/200 Batch 7, Loss 11.4034\n",
      "Epoch 110/200 Batch 8, Loss 11.3109\n",
      "Epoch 110/200 Batch 9, Loss 11.2781\n",
      "Epoch 110/200 Batch 10, Loss 11.3642\n",
      "Epoch 110/200 Batch 11, Loss 11.4394\n",
      "Epoch 110/200 Batch 12, Loss 11.4141\n",
      "Epoch 110/200 Batch 13, Loss 11.4412\n",
      "Epoch 110/200 Batch 14, Loss 11.3447\n",
      "Epoch 110/200 Batch 15, Loss 11.2858\n",
      "Epoch 110/200 Batch 16, Loss 11.2419\n",
      "Epoch 110/200 Batch 17, Loss 11.1529\n",
      "Epoch 110/200 Batch 18, Loss 11.3355\n",
      "Epoch 110/200 Batch 19, Loss 11.3416\n",
      "Epoch 111/200 Batch 0, Loss 11.3987\n",
      "Epoch 111/200 Batch 1, Loss 11.2175\n",
      "Epoch 111/200 Batch 2, Loss 11.3229\n",
      "Epoch 111/200 Batch 3, Loss 11.3880\n",
      "Epoch 111/200 Batch 4, Loss 11.2444\n",
      "Epoch 111/200 Batch 5, Loss 11.3422\n",
      "Epoch 111/200 Batch 6, Loss 11.2337\n",
      "Epoch 111/200 Batch 7, Loss 11.3680\n",
      "Epoch 111/200 Batch 8, Loss 11.3018\n",
      "Epoch 111/200 Batch 9, Loss 11.4499\n",
      "Epoch 111/200 Batch 10, Loss 11.0987\n",
      "Epoch 111/200 Batch 11, Loss 11.2411\n",
      "Epoch 111/200 Batch 12, Loss 11.5390\n",
      "Epoch 111/200 Batch 13, Loss 11.3028\n",
      "Epoch 111/200 Batch 14, Loss 11.4767\n",
      "Epoch 111/200 Batch 15, Loss 11.3592\n",
      "Epoch 111/200 Batch 16, Loss 11.3910\n",
      "Epoch 111/200 Batch 17, Loss 11.4013\n",
      "Epoch 111/200 Batch 18, Loss 11.2598\n",
      "Epoch 111/200 Batch 19, Loss 11.3786\n",
      "Epoch 112/200 Batch 0, Loss 11.3173\n",
      "Epoch 112/200 Batch 1, Loss 11.3034\n",
      "Epoch 112/200 Batch 2, Loss 11.4914\n",
      "Epoch 112/200 Batch 3, Loss 11.3714\n",
      "Epoch 112/200 Batch 4, Loss 11.4722\n",
      "Epoch 112/200 Batch 5, Loss 11.2878\n",
      "Epoch 112/200 Batch 6, Loss 11.2809\n",
      "Epoch 112/200 Batch 7, Loss 11.3054\n",
      "Epoch 112/200 Batch 8, Loss 11.3003\n",
      "Epoch 112/200 Batch 9, Loss 11.3928\n",
      "Epoch 112/200 Batch 10, Loss 11.4691\n",
      "Epoch 112/200 Batch 11, Loss 11.3088\n",
      "Epoch 112/200 Batch 12, Loss 11.4046\n",
      "Epoch 112/200 Batch 13, Loss 11.2771\n",
      "Epoch 112/200 Batch 14, Loss 11.2811\n",
      "Epoch 112/200 Batch 15, Loss 11.2723\n",
      "Epoch 112/200 Batch 16, Loss 11.3064\n",
      "Epoch 112/200 Batch 17, Loss 11.3696\n",
      "Epoch 112/200 Batch 18, Loss 11.4607\n",
      "Epoch 112/200 Batch 19, Loss 11.2342\n",
      "Epoch 113/200 Batch 0, Loss 11.5368\n",
      "Epoch 113/200 Batch 1, Loss 11.4166\n",
      "Epoch 113/200 Batch 2, Loss 11.4323\n",
      "Epoch 113/200 Batch 3, Loss 11.3552\n",
      "Epoch 113/200 Batch 4, Loss 11.2917\n",
      "Epoch 113/200 Batch 5, Loss 11.2849\n",
      "Epoch 113/200 Batch 6, Loss 11.1851\n",
      "Epoch 113/200 Batch 7, Loss 11.4143\n",
      "Epoch 113/200 Batch 8, Loss 11.1804\n",
      "Epoch 113/200 Batch 9, Loss 11.2487\n",
      "Epoch 113/200 Batch 10, Loss 11.2622\n",
      "Epoch 113/200 Batch 11, Loss 11.4384\n",
      "Epoch 113/200 Batch 12, Loss 11.2425\n",
      "Epoch 113/200 Batch 13, Loss 11.2609\n",
      "Epoch 113/200 Batch 14, Loss 11.3926\n",
      "Epoch 113/200 Batch 15, Loss 11.4820\n",
      "Epoch 113/200 Batch 16, Loss 11.2236\n",
      "Epoch 113/200 Batch 17, Loss 11.3471\n",
      "Epoch 113/200 Batch 18, Loss 11.4046\n",
      "Epoch 113/200 Batch 19, Loss 11.3554\n",
      "Epoch 114/200 Batch 0, Loss 11.3093\n",
      "Epoch 114/200 Batch 1, Loss 11.2202\n",
      "Epoch 114/200 Batch 2, Loss 11.4083\n",
      "Epoch 114/200 Batch 3, Loss 11.5325\n",
      "Epoch 114/200 Batch 4, Loss 11.3918\n",
      "Epoch 114/200 Batch 5, Loss 11.4918\n",
      "Epoch 114/200 Batch 6, Loss 11.2848\n",
      "Epoch 114/200 Batch 7, Loss 11.1804\n",
      "Epoch 114/200 Batch 8, Loss 11.2940\n",
      "Epoch 114/200 Batch 9, Loss 11.1548\n",
      "Epoch 114/200 Batch 10, Loss 11.4965\n",
      "Epoch 114/200 Batch 11, Loss 11.2042\n",
      "Epoch 114/200 Batch 12, Loss 11.2141\n",
      "Epoch 114/200 Batch 13, Loss 11.3727\n",
      "Epoch 114/200 Batch 14, Loss 11.3320\n",
      "Epoch 114/200 Batch 15, Loss 11.2114\n",
      "Epoch 114/200 Batch 16, Loss 11.4710\n",
      "Epoch 114/200 Batch 17, Loss 11.2390\n",
      "Epoch 114/200 Batch 18, Loss 11.4524\n",
      "Epoch 114/200 Batch 19, Loss 11.3066\n",
      "Epoch 115/200 Batch 0, Loss 11.2244\n",
      "Epoch 115/200 Batch 1, Loss 11.2143\n",
      "Epoch 115/200 Batch 2, Loss 11.3967\n",
      "Epoch 115/200 Batch 3, Loss 11.2988\n",
      "Epoch 115/200 Batch 4, Loss 11.0883\n",
      "Epoch 115/200 Batch 5, Loss 11.3218\n",
      "Epoch 115/200 Batch 6, Loss 11.1999\n",
      "Epoch 115/200 Batch 7, Loss 11.3553\n",
      "Epoch 115/200 Batch 8, Loss 11.1877\n",
      "Epoch 115/200 Batch 9, Loss 11.3173\n",
      "Epoch 115/200 Batch 10, Loss 11.3765\n",
      "Epoch 115/200 Batch 11, Loss 11.2372\n",
      "Epoch 115/200 Batch 12, Loss 11.3163\n",
      "Epoch 115/200 Batch 13, Loss 11.3682\n",
      "Epoch 115/200 Batch 14, Loss 11.3953\n",
      "Epoch 115/200 Batch 15, Loss 11.2522\n",
      "Epoch 115/200 Batch 16, Loss 11.3102\n",
      "Epoch 115/200 Batch 17, Loss 11.5183\n",
      "Epoch 115/200 Batch 18, Loss 11.3588\n",
      "Epoch 115/200 Batch 19, Loss 11.3953\n",
      "Epoch 116/200 Batch 0, Loss 11.4542\n",
      "Epoch 116/200 Batch 1, Loss 11.4906\n",
      "Epoch 116/200 Batch 2, Loss 11.2056\n",
      "Epoch 116/200 Batch 3, Loss 11.2292\n",
      "Epoch 116/200 Batch 4, Loss 11.2448\n",
      "Epoch 116/200 Batch 5, Loss 11.2291\n",
      "Epoch 116/200 Batch 6, Loss 11.1177\n",
      "Epoch 116/200 Batch 7, Loss 11.3501\n",
      "Epoch 116/200 Batch 8, Loss 11.3703\n",
      "Epoch 116/200 Batch 9, Loss 11.3358\n",
      "Epoch 116/200 Batch 10, Loss 11.2462\n",
      "Epoch 116/200 Batch 11, Loss 11.3078\n",
      "Epoch 116/200 Batch 12, Loss 11.3726\n",
      "Epoch 116/200 Batch 13, Loss 11.3912\n",
      "Epoch 116/200 Batch 14, Loss 11.1910\n",
      "Epoch 116/200 Batch 15, Loss 11.5532\n",
      "Epoch 116/200 Batch 16, Loss 11.3135\n",
      "Epoch 116/200 Batch 17, Loss 11.1766\n",
      "Epoch 116/200 Batch 18, Loss 11.2528\n",
      "Epoch 116/200 Batch 19, Loss 11.3557\n",
      "Epoch 117/200 Batch 0, Loss 11.4402\n",
      "Epoch 117/200 Batch 1, Loss 11.2513\n",
      "Epoch 117/200 Batch 2, Loss 11.2029\n",
      "Epoch 117/200 Batch 3, Loss 11.4428\n",
      "Epoch 117/200 Batch 4, Loss 11.2867\n",
      "Epoch 117/200 Batch 5, Loss 11.3270\n",
      "Epoch 117/200 Batch 6, Loss 11.2229\n",
      "Epoch 117/200 Batch 7, Loss 11.2626\n",
      "Epoch 117/200 Batch 8, Loss 11.2428\n",
      "Epoch 117/200 Batch 9, Loss 11.4281\n",
      "Epoch 117/200 Batch 10, Loss 11.4876\n",
      "Epoch 117/200 Batch 11, Loss 11.2546\n",
      "Epoch 117/200 Batch 12, Loss 11.4595\n",
      "Epoch 117/200 Batch 13, Loss 11.3188\n",
      "Epoch 117/200 Batch 14, Loss 11.3738\n",
      "Epoch 117/200 Batch 15, Loss 11.1655\n",
      "Epoch 117/200 Batch 16, Loss 11.5588\n",
      "Epoch 117/200 Batch 17, Loss 11.3653\n",
      "Epoch 117/200 Batch 18, Loss 11.3370\n",
      "Epoch 117/200 Batch 19, Loss 11.3932\n",
      "Epoch 118/200 Batch 0, Loss 11.2323\n",
      "Epoch 118/200 Batch 1, Loss 11.1997\n",
      "Epoch 118/200 Batch 2, Loss 11.3307\n",
      "Epoch 118/200 Batch 3, Loss 11.1933\n",
      "Epoch 118/200 Batch 4, Loss 11.1839\n",
      "Epoch 118/200 Batch 5, Loss 11.4237\n",
      "Epoch 118/200 Batch 6, Loss 11.3522\n",
      "Epoch 118/200 Batch 7, Loss 11.1676\n",
      "Epoch 118/200 Batch 8, Loss 11.4141\n",
      "Epoch 118/200 Batch 9, Loss 11.3209\n",
      "Epoch 118/200 Batch 10, Loss 11.4688\n",
      "Epoch 118/200 Batch 11, Loss 11.2880\n",
      "Epoch 118/200 Batch 12, Loss 11.2794\n",
      "Epoch 118/200 Batch 13, Loss 11.3324\n",
      "Epoch 118/200 Batch 14, Loss 11.3809\n",
      "Epoch 118/200 Batch 15, Loss 11.2131\n",
      "Epoch 118/200 Batch 16, Loss 11.2777\n",
      "Epoch 118/200 Batch 17, Loss 11.3464\n",
      "Epoch 118/200 Batch 18, Loss 11.4867\n",
      "Epoch 118/200 Batch 19, Loss 11.6215\n",
      "Epoch 119/200 Batch 0, Loss 11.3771\n",
      "Epoch 119/200 Batch 1, Loss 11.3187\n",
      "Epoch 119/200 Batch 2, Loss 11.2365\n",
      "Epoch 119/200 Batch 3, Loss 11.3153\n",
      "Epoch 119/200 Batch 4, Loss 11.3519\n",
      "Epoch 119/200 Batch 5, Loss 11.3929\n",
      "Epoch 119/200 Batch 6, Loss 11.2399\n",
      "Epoch 119/200 Batch 7, Loss 11.2544\n",
      "Epoch 119/200 Batch 8, Loss 11.2605\n",
      "Epoch 119/200 Batch 9, Loss 11.4293\n",
      "Epoch 119/200 Batch 10, Loss 11.5431\n",
      "Epoch 119/200 Batch 11, Loss 11.3321\n",
      "Epoch 119/200 Batch 12, Loss 11.1372\n",
      "Epoch 119/200 Batch 13, Loss 11.2191\n",
      "Epoch 119/200 Batch 14, Loss 11.2640\n",
      "Epoch 119/200 Batch 15, Loss 11.3664\n",
      "Epoch 119/200 Batch 16, Loss 11.4890\n",
      "Epoch 119/200 Batch 17, Loss 11.4013\n",
      "Epoch 119/200 Batch 18, Loss 11.2186\n",
      "Epoch 119/200 Batch 19, Loss 11.4018\n",
      "Epoch 120/200 Batch 0, Loss 11.2439\n",
      "Epoch 120/200 Batch 1, Loss 11.2002\n",
      "Epoch 120/200 Batch 2, Loss 11.3069\n",
      "Epoch 120/200 Batch 3, Loss 11.2583\n",
      "Epoch 120/200 Batch 4, Loss 11.6660\n",
      "Epoch 120/200 Batch 5, Loss 11.2727\n",
      "Epoch 120/200 Batch 6, Loss 11.4617\n",
      "Epoch 120/200 Batch 7, Loss 11.3859\n",
      "Epoch 120/200 Batch 8, Loss 11.3630\n",
      "Epoch 120/200 Batch 9, Loss 11.1734\n",
      "Epoch 120/200 Batch 10, Loss 11.3587\n",
      "Epoch 120/200 Batch 11, Loss 11.0186\n",
      "Epoch 120/200 Batch 12, Loss 11.4435\n",
      "Epoch 120/200 Batch 13, Loss 11.4352\n",
      "Epoch 120/200 Batch 14, Loss 11.3342\n",
      "Epoch 120/200 Batch 15, Loss 11.3337\n",
      "Epoch 120/200 Batch 16, Loss 11.3615\n",
      "Epoch 120/200 Batch 17, Loss 11.2843\n",
      "Epoch 120/200 Batch 18, Loss 11.4006\n",
      "Epoch 120/200 Batch 19, Loss 11.4247\n",
      "Epoch 121/200 Batch 0, Loss 11.2726\n",
      "Epoch 121/200 Batch 1, Loss 11.4514\n",
      "Epoch 121/200 Batch 2, Loss 11.3481\n",
      "Epoch 121/200 Batch 3, Loss 11.4292\n",
      "Epoch 121/200 Batch 4, Loss 11.3263\n",
      "Epoch 121/200 Batch 5, Loss 11.2070\n",
      "Epoch 121/200 Batch 6, Loss 11.5481\n",
      "Epoch 121/200 Batch 7, Loss 11.5363\n",
      "Epoch 121/200 Batch 8, Loss 11.3375\n",
      "Epoch 121/200 Batch 9, Loss 11.2107\n",
      "Epoch 121/200 Batch 10, Loss 11.2322\n",
      "Epoch 121/200 Batch 11, Loss 11.3331\n",
      "Epoch 121/200 Batch 12, Loss 11.2846\n",
      "Epoch 121/200 Batch 13, Loss 11.5058\n",
      "Epoch 121/200 Batch 14, Loss 11.3792\n",
      "Epoch 121/200 Batch 15, Loss 11.2315\n",
      "Epoch 121/200 Batch 16, Loss 11.2022\n",
      "Epoch 121/200 Batch 17, Loss 11.0981\n",
      "Epoch 121/200 Batch 18, Loss 11.2823\n",
      "Epoch 121/200 Batch 19, Loss 11.3545\n",
      "Epoch 122/200 Batch 0, Loss 11.2826\n",
      "Epoch 122/200 Batch 1, Loss 11.4684\n",
      "Epoch 122/200 Batch 2, Loss 11.5510\n",
      "Epoch 122/200 Batch 3, Loss 11.3824\n",
      "Epoch 122/200 Batch 4, Loss 11.2656\n",
      "Epoch 122/200 Batch 5, Loss 11.1589\n",
      "Epoch 122/200 Batch 6, Loss 11.3440\n",
      "Epoch 122/200 Batch 7, Loss 11.3901\n",
      "Epoch 122/200 Batch 8, Loss 11.4836\n",
      "Epoch 122/200 Batch 9, Loss 11.4671\n",
      "Epoch 122/200 Batch 10, Loss 11.1369\n",
      "Epoch 122/200 Batch 11, Loss 11.4896\n",
      "Epoch 122/200 Batch 12, Loss 11.4788\n",
      "Epoch 122/200 Batch 13, Loss 11.2097\n",
      "Epoch 122/200 Batch 14, Loss 11.2474\n",
      "Epoch 122/200 Batch 15, Loss 11.1933\n",
      "Epoch 122/200 Batch 16, Loss 11.2646\n",
      "Epoch 122/200 Batch 17, Loss 11.1472\n",
      "Epoch 122/200 Batch 18, Loss 11.1726\n",
      "Epoch 122/200 Batch 19, Loss 11.2538\n",
      "Epoch 123/200 Batch 0, Loss 11.3919\n",
      "Epoch 123/200 Batch 1, Loss 11.2243\n",
      "Epoch 123/200 Batch 2, Loss 11.3098\n",
      "Epoch 123/200 Batch 3, Loss 11.2541\n",
      "Epoch 123/200 Batch 4, Loss 11.2747\n",
      "Epoch 123/200 Batch 5, Loss 11.4416\n",
      "Epoch 123/200 Batch 6, Loss 11.3527\n",
      "Epoch 123/200 Batch 7, Loss 11.2902\n",
      "Epoch 123/200 Batch 8, Loss 11.3261\n",
      "Epoch 123/200 Batch 9, Loss 11.4051\n",
      "Epoch 123/200 Batch 10, Loss 11.3717\n",
      "Epoch 123/200 Batch 11, Loss 11.2902\n",
      "Epoch 123/200 Batch 12, Loss 11.3997\n",
      "Epoch 123/200 Batch 13, Loss 11.2907\n",
      "Epoch 123/200 Batch 14, Loss 11.3132\n",
      "Epoch 123/200 Batch 15, Loss 11.3834\n",
      "Epoch 123/200 Batch 16, Loss 11.4113\n",
      "Epoch 123/200 Batch 17, Loss 11.2006\n",
      "Epoch 123/200 Batch 18, Loss 11.4442\n",
      "Epoch 123/200 Batch 19, Loss 11.3004\n",
      "Epoch 124/200 Batch 0, Loss 11.1141\n",
      "Epoch 124/200 Batch 1, Loss 11.3758\n",
      "Epoch 124/200 Batch 2, Loss 11.3004\n",
      "Epoch 124/200 Batch 3, Loss 11.2591\n",
      "Epoch 124/200 Batch 4, Loss 11.3285\n",
      "Epoch 124/200 Batch 5, Loss 11.2702\n",
      "Epoch 124/200 Batch 6, Loss 11.3180\n",
      "Epoch 124/200 Batch 7, Loss 11.4574\n",
      "Epoch 124/200 Batch 8, Loss 11.3144\n",
      "Epoch 124/200 Batch 9, Loss 11.3876\n",
      "Epoch 124/200 Batch 10, Loss 11.2290\n",
      "Epoch 124/200 Batch 11, Loss 11.2354\n",
      "Epoch 124/200 Batch 12, Loss 11.3196\n",
      "Epoch 124/200 Batch 13, Loss 11.3560\n",
      "Epoch 124/200 Batch 14, Loss 11.4386\n",
      "Epoch 124/200 Batch 15, Loss 11.7056\n",
      "Epoch 124/200 Batch 16, Loss 11.1281\n",
      "Epoch 124/200 Batch 17, Loss 11.4853\n",
      "Epoch 124/200 Batch 18, Loss 11.2377\n",
      "Epoch 124/200 Batch 19, Loss 11.3840\n",
      "Epoch 125/200 Batch 0, Loss 11.4907\n",
      "Epoch 125/200 Batch 1, Loss 11.4325\n",
      "Epoch 125/200 Batch 2, Loss 11.4750\n",
      "Epoch 125/200 Batch 3, Loss 11.2393\n",
      "Epoch 125/200 Batch 4, Loss 11.3056\n",
      "Epoch 125/200 Batch 5, Loss 11.5042\n",
      "Epoch 125/200 Batch 6, Loss 11.3685\n",
      "Epoch 125/200 Batch 7, Loss 11.1884\n",
      "Epoch 125/200 Batch 8, Loss 11.3583\n",
      "Epoch 125/200 Batch 9, Loss 11.1371\n",
      "Epoch 125/200 Batch 10, Loss 11.3737\n",
      "Epoch 125/200 Batch 11, Loss 11.1076\n",
      "Epoch 125/200 Batch 12, Loss 11.3470\n",
      "Epoch 125/200 Batch 13, Loss 11.4108\n",
      "Epoch 125/200 Batch 14, Loss 11.2711\n",
      "Epoch 125/200 Batch 15, Loss 11.2205\n",
      "Epoch 125/200 Batch 16, Loss 11.4484\n",
      "Epoch 125/200 Batch 17, Loss 11.2959\n",
      "Epoch 125/200 Batch 18, Loss 11.3430\n",
      "Epoch 125/200 Batch 19, Loss 11.3572\n",
      "Epoch 126/200 Batch 0, Loss 11.3517\n",
      "Epoch 126/200 Batch 1, Loss 11.2532\n",
      "Epoch 126/200 Batch 2, Loss 11.3422\n",
      "Epoch 126/200 Batch 3, Loss 11.4155\n",
      "Epoch 126/200 Batch 4, Loss 11.2221\n",
      "Epoch 126/200 Batch 5, Loss 11.2091\n",
      "Epoch 126/200 Batch 6, Loss 11.4247\n",
      "Epoch 126/200 Batch 7, Loss 11.3615\n",
      "Epoch 126/200 Batch 8, Loss 11.2370\n",
      "Epoch 126/200 Batch 9, Loss 11.4582\n",
      "Epoch 126/200 Batch 10, Loss 11.2335\n",
      "Epoch 126/200 Batch 11, Loss 11.2020\n",
      "Epoch 126/200 Batch 12, Loss 11.3665\n",
      "Epoch 126/200 Batch 13, Loss 11.2365\n",
      "Epoch 126/200 Batch 14, Loss 11.4519\n",
      "Epoch 126/200 Batch 15, Loss 11.5072\n",
      "Epoch 126/200 Batch 16, Loss 11.1944\n",
      "Epoch 126/200 Batch 17, Loss 11.4146\n",
      "Epoch 126/200 Batch 18, Loss 11.1783\n",
      "Epoch 126/200 Batch 19, Loss 11.2958\n",
      "Epoch 127/200 Batch 0, Loss 11.3688\n",
      "Epoch 127/200 Batch 1, Loss 11.3743\n",
      "Epoch 127/200 Batch 2, Loss 11.3803\n",
      "Epoch 127/200 Batch 3, Loss 11.4061\n",
      "Epoch 127/200 Batch 4, Loss 11.4312\n",
      "Epoch 127/200 Batch 5, Loss 11.3571\n",
      "Epoch 127/200 Batch 6, Loss 11.3483\n",
      "Epoch 127/200 Batch 7, Loss 11.4497\n",
      "Epoch 127/200 Batch 8, Loss 11.3220\n",
      "Epoch 127/200 Batch 9, Loss 11.4242\n",
      "Epoch 127/200 Batch 10, Loss 11.2241\n",
      "Epoch 127/200 Batch 11, Loss 11.3231\n",
      "Epoch 127/200 Batch 12, Loss 11.2537\n",
      "Epoch 127/200 Batch 13, Loss 11.2244\n",
      "Epoch 127/200 Batch 14, Loss 11.3059\n",
      "Epoch 127/200 Batch 15, Loss 11.2228\n",
      "Epoch 127/200 Batch 16, Loss 11.3619\n",
      "Epoch 127/200 Batch 17, Loss 11.1540\n",
      "Epoch 127/200 Batch 18, Loss 11.2931\n",
      "Epoch 127/200 Batch 19, Loss 11.4084\n",
      "Epoch 128/200 Batch 0, Loss 11.2379\n",
      "Epoch 128/200 Batch 1, Loss 11.3856\n",
      "Epoch 128/200 Batch 2, Loss 11.2686\n",
      "Epoch 128/200 Batch 3, Loss 11.4734\n",
      "Epoch 128/200 Batch 4, Loss 11.2245\n",
      "Epoch 128/200 Batch 5, Loss 11.3756\n",
      "Epoch 128/200 Batch 6, Loss 11.1039\n",
      "Epoch 128/200 Batch 7, Loss 11.4008\n",
      "Epoch 128/200 Batch 8, Loss 11.3007\n",
      "Epoch 128/200 Batch 9, Loss 11.3782\n",
      "Epoch 128/200 Batch 10, Loss 11.3618\n",
      "Epoch 128/200 Batch 11, Loss 11.1945\n",
      "Epoch 128/200 Batch 12, Loss 11.3819\n",
      "Epoch 128/200 Batch 13, Loss 11.4433\n",
      "Epoch 128/200 Batch 14, Loss 11.2002\n",
      "Epoch 128/200 Batch 15, Loss 11.2697\n",
      "Epoch 128/200 Batch 16, Loss 11.4077\n",
      "Epoch 128/200 Batch 17, Loss 11.2690\n",
      "Epoch 128/200 Batch 18, Loss 11.4491\n",
      "Epoch 128/200 Batch 19, Loss 11.4884\n",
      "Epoch 129/200 Batch 0, Loss 11.2720\n",
      "Epoch 129/200 Batch 1, Loss 11.2530\n",
      "Epoch 129/200 Batch 2, Loss 11.2266\n",
      "Epoch 129/200 Batch 3, Loss 11.2396\n",
      "Epoch 129/200 Batch 4, Loss 11.3004\n",
      "Epoch 129/200 Batch 5, Loss 11.2762\n",
      "Epoch 129/200 Batch 6, Loss 11.4950\n",
      "Epoch 129/200 Batch 7, Loss 11.1705\n",
      "Epoch 129/200 Batch 8, Loss 11.3137\n",
      "Epoch 129/200 Batch 9, Loss 11.2823\n",
      "Epoch 129/200 Batch 10, Loss 11.3886\n",
      "Epoch 129/200 Batch 11, Loss 11.3552\n",
      "Epoch 129/200 Batch 12, Loss 11.2092\n",
      "Epoch 129/200 Batch 13, Loss 11.2533\n",
      "Epoch 129/200 Batch 14, Loss 11.5234\n",
      "Epoch 129/200 Batch 15, Loss 11.5768\n",
      "Epoch 129/200 Batch 16, Loss 11.3512\n",
      "Epoch 129/200 Batch 17, Loss 11.3722\n",
      "Epoch 129/200 Batch 18, Loss 11.5179\n",
      "Epoch 129/200 Batch 19, Loss 11.3500\n",
      "Epoch 130/200 Batch 0, Loss 11.1515\n",
      "Epoch 130/200 Batch 1, Loss 11.4422\n",
      "Epoch 130/200 Batch 2, Loss 11.3823\n",
      "Epoch 130/200 Batch 3, Loss 11.2796\n",
      "Epoch 130/200 Batch 4, Loss 11.2983\n",
      "Epoch 130/200 Batch 5, Loss 11.4921\n",
      "Epoch 130/200 Batch 6, Loss 11.1987\n",
      "Epoch 130/200 Batch 7, Loss 11.3091\n",
      "Epoch 130/200 Batch 8, Loss 11.3994\n",
      "Epoch 130/200 Batch 9, Loss 11.3669\n",
      "Epoch 130/200 Batch 10, Loss 11.2758\n",
      "Epoch 130/200 Batch 11, Loss 11.3005\n",
      "Epoch 130/200 Batch 12, Loss 11.2277\n",
      "Epoch 130/200 Batch 13, Loss 11.3810\n",
      "Epoch 130/200 Batch 14, Loss 11.2521\n",
      "Epoch 130/200 Batch 15, Loss 11.2859\n",
      "Epoch 130/200 Batch 16, Loss 11.4406\n",
      "Epoch 130/200 Batch 17, Loss 11.3474\n",
      "Epoch 130/200 Batch 18, Loss 11.4580\n",
      "Epoch 130/200 Batch 19, Loss 11.4559\n",
      "Epoch 131/200 Batch 0, Loss 11.4668\n",
      "Epoch 131/200 Batch 1, Loss 11.2181\n",
      "Epoch 131/200 Batch 2, Loss 11.2955\n",
      "Epoch 131/200 Batch 3, Loss 11.5310\n",
      "Epoch 131/200 Batch 4, Loss 11.4087\n",
      "Epoch 131/200 Batch 5, Loss 11.3934\n",
      "Epoch 131/200 Batch 6, Loss 11.1545\n",
      "Epoch 131/200 Batch 7, Loss 11.1801\n",
      "Epoch 131/200 Batch 8, Loss 11.3980\n",
      "Epoch 131/200 Batch 9, Loss 11.3419\n",
      "Epoch 131/200 Batch 10, Loss 11.5903\n",
      "Epoch 131/200 Batch 11, Loss 11.2943\n",
      "Epoch 131/200 Batch 12, Loss 11.3305\n",
      "Epoch 131/200 Batch 13, Loss 11.3824\n",
      "Epoch 131/200 Batch 14, Loss 11.2961\n",
      "Epoch 131/200 Batch 15, Loss 11.4862\n",
      "Epoch 131/200 Batch 16, Loss 11.4359\n",
      "Epoch 131/200 Batch 17, Loss 11.2551\n",
      "Epoch 131/200 Batch 18, Loss 11.4256\n",
      "Epoch 131/200 Batch 19, Loss 11.1788\n",
      "Epoch 132/200 Batch 0, Loss 11.2305\n",
      "Epoch 132/200 Batch 1, Loss 11.2690\n",
      "Epoch 132/200 Batch 2, Loss 11.4347\n",
      "Epoch 132/200 Batch 3, Loss 11.4308\n",
      "Epoch 132/200 Batch 4, Loss 11.3335\n",
      "Epoch 132/200 Batch 5, Loss 11.2466\n",
      "Epoch 132/200 Batch 6, Loss 11.3558\n",
      "Epoch 132/200 Batch 7, Loss 11.0786\n",
      "Epoch 132/200 Batch 8, Loss 11.1405\n",
      "Epoch 132/200 Batch 9, Loss 11.2095\n",
      "Epoch 132/200 Batch 10, Loss 11.3382\n",
      "Epoch 132/200 Batch 11, Loss 11.2739\n",
      "Epoch 132/200 Batch 12, Loss 11.2811\n",
      "Epoch 132/200 Batch 13, Loss 11.1846\n",
      "Epoch 132/200 Batch 14, Loss 11.5213\n",
      "Epoch 132/200 Batch 15, Loss 11.4516\n",
      "Epoch 132/200 Batch 16, Loss 11.4121\n",
      "Epoch 132/200 Batch 17, Loss 11.2598\n",
      "Epoch 132/200 Batch 18, Loss 11.2675\n",
      "Epoch 132/200 Batch 19, Loss 11.5990\n",
      "Epoch 133/200 Batch 0, Loss 11.2260\n",
      "Epoch 133/200 Batch 1, Loss 11.1185\n",
      "Epoch 133/200 Batch 2, Loss 11.4942\n",
      "Epoch 133/200 Batch 3, Loss 11.3220\n",
      "Epoch 133/200 Batch 4, Loss 11.3013\n",
      "Epoch 133/200 Batch 5, Loss 11.4046\n",
      "Epoch 133/200 Batch 6, Loss 11.2172\n",
      "Epoch 133/200 Batch 7, Loss 11.2690\n",
      "Epoch 133/200 Batch 8, Loss 11.2676\n",
      "Epoch 133/200 Batch 9, Loss 11.4439\n",
      "Epoch 133/200 Batch 10, Loss 11.4734\n",
      "Epoch 133/200 Batch 11, Loss 11.2975\n",
      "Epoch 133/200 Batch 12, Loss 11.3438\n",
      "Epoch 133/200 Batch 13, Loss 11.3992\n",
      "Epoch 133/200 Batch 14, Loss 11.3366\n",
      "Epoch 133/200 Batch 15, Loss 11.4118\n",
      "Epoch 133/200 Batch 16, Loss 11.4200\n",
      "Epoch 133/200 Batch 17, Loss 11.3738\n",
      "Epoch 133/200 Batch 18, Loss 11.2039\n",
      "Epoch 133/200 Batch 19, Loss 11.3388\n",
      "Epoch 134/200 Batch 0, Loss 11.3074\n",
      "Epoch 134/200 Batch 1, Loss 11.1556\n",
      "Epoch 134/200 Batch 2, Loss 11.2266\n",
      "Epoch 134/200 Batch 3, Loss 11.1712\n",
      "Epoch 134/200 Batch 4, Loss 11.4394\n",
      "Epoch 134/200 Batch 5, Loss 11.4233\n",
      "Epoch 134/200 Batch 6, Loss 11.5069\n",
      "Epoch 134/200 Batch 7, Loss 11.3558\n",
      "Epoch 134/200 Batch 8, Loss 11.1417\n",
      "Epoch 134/200 Batch 9, Loss 11.1165\n",
      "Epoch 134/200 Batch 10, Loss 11.4490\n",
      "Epoch 134/200 Batch 11, Loss 11.2236\n",
      "Epoch 134/200 Batch 12, Loss 11.3675\n",
      "Epoch 134/200 Batch 13, Loss 11.4263\n",
      "Epoch 134/200 Batch 14, Loss 11.4488\n",
      "Epoch 134/200 Batch 15, Loss 11.2872\n",
      "Epoch 134/200 Batch 16, Loss 11.3761\n",
      "Epoch 134/200 Batch 17, Loss 11.3157\n",
      "Epoch 134/200 Batch 18, Loss 11.2216\n",
      "Epoch 134/200 Batch 19, Loss 11.3108\n",
      "Epoch 135/200 Batch 0, Loss 11.4225\n",
      "Epoch 135/200 Batch 1, Loss 11.5157\n",
      "Epoch 135/200 Batch 2, Loss 11.3770\n",
      "Epoch 135/200 Batch 3, Loss 11.3414\n",
      "Epoch 135/200 Batch 4, Loss 11.1487\n",
      "Epoch 135/200 Batch 5, Loss 11.1364\n",
      "Epoch 135/200 Batch 6, Loss 11.3890\n",
      "Epoch 135/200 Batch 7, Loss 11.2462\n",
      "Epoch 135/200 Batch 8, Loss 11.2976\n",
      "Epoch 135/200 Batch 9, Loss 11.3179\n",
      "Epoch 135/200 Batch 10, Loss 11.4171\n",
      "Epoch 135/200 Batch 11, Loss 11.1846\n",
      "Epoch 135/200 Batch 12, Loss 11.3404\n",
      "Epoch 135/200 Batch 13, Loss 11.1397\n",
      "Epoch 135/200 Batch 14, Loss 11.2318\n",
      "Epoch 135/200 Batch 15, Loss 11.2827\n",
      "Epoch 135/200 Batch 16, Loss 11.2186\n",
      "Epoch 135/200 Batch 17, Loss 11.5470\n",
      "Epoch 135/200 Batch 18, Loss 11.4080\n",
      "Epoch 135/200 Batch 19, Loss 11.5001\n",
      "Epoch 136/200 Batch 0, Loss 11.2691\n",
      "Epoch 136/200 Batch 1, Loss 11.2717\n",
      "Epoch 136/200 Batch 2, Loss 11.2777\n",
      "Epoch 136/200 Batch 3, Loss 11.4785\n",
      "Epoch 136/200 Batch 4, Loss 11.3942\n",
      "Epoch 136/200 Batch 5, Loss 11.1778\n",
      "Epoch 136/200 Batch 6, Loss 11.3540\n",
      "Epoch 136/200 Batch 7, Loss 11.2598\n",
      "Epoch 136/200 Batch 8, Loss 11.4153\n",
      "Epoch 136/200 Batch 9, Loss 11.3468\n",
      "Epoch 136/200 Batch 10, Loss 11.2087\n",
      "Epoch 136/200 Batch 11, Loss 11.1963\n",
      "Epoch 136/200 Batch 12, Loss 11.1637\n",
      "Epoch 136/200 Batch 13, Loss 11.3389\n",
      "Epoch 136/200 Batch 14, Loss 11.7560\n",
      "Epoch 136/200 Batch 15, Loss 11.3828\n",
      "Epoch 136/200 Batch 16, Loss 11.3614\n",
      "Epoch 136/200 Batch 17, Loss 11.3414\n",
      "Epoch 136/200 Batch 18, Loss 11.4110\n",
      "Epoch 136/200 Batch 19, Loss 11.2292\n",
      "Epoch 137/200 Batch 0, Loss 11.2952\n",
      "Epoch 137/200 Batch 1, Loss 11.3545\n",
      "Epoch 137/200 Batch 2, Loss 11.3356\n",
      "Epoch 137/200 Batch 3, Loss 11.3420\n",
      "Epoch 137/200 Batch 4, Loss 11.3194\n",
      "Epoch 137/200 Batch 5, Loss 11.1147\n",
      "Epoch 137/200 Batch 6, Loss 11.3223\n",
      "Epoch 137/200 Batch 7, Loss 11.2121\n",
      "Epoch 137/200 Batch 8, Loss 11.5018\n",
      "Epoch 137/200 Batch 9, Loss 11.4432\n",
      "Epoch 137/200 Batch 10, Loss 11.3887\n",
      "Epoch 137/200 Batch 11, Loss 11.3165\n",
      "Epoch 137/200 Batch 12, Loss 11.1823\n",
      "Epoch 137/200 Batch 13, Loss 11.4061\n",
      "Epoch 137/200 Batch 14, Loss 11.2151\n",
      "Epoch 137/200 Batch 15, Loss 11.3732\n",
      "Epoch 137/200 Batch 16, Loss 11.2984\n",
      "Epoch 137/200 Batch 17, Loss 11.2576\n",
      "Epoch 137/200 Batch 18, Loss 11.3411\n",
      "Epoch 137/200 Batch 19, Loss 11.3077\n",
      "Epoch 138/200 Batch 0, Loss 11.3106\n",
      "Epoch 138/200 Batch 1, Loss 11.1845\n",
      "Epoch 138/200 Batch 2, Loss 11.0954\n",
      "Epoch 138/200 Batch 3, Loss 11.2898\n",
      "Epoch 138/200 Batch 4, Loss 11.3016\n",
      "Epoch 138/200 Batch 5, Loss 11.3982\n",
      "Epoch 138/200 Batch 6, Loss 11.4799\n",
      "Epoch 138/200 Batch 7, Loss 11.4195\n",
      "Epoch 138/200 Batch 8, Loss 11.3597\n",
      "Epoch 138/200 Batch 9, Loss 11.2678\n",
      "Epoch 138/200 Batch 10, Loss 11.1640\n",
      "Epoch 138/200 Batch 11, Loss 11.2537\n",
      "Epoch 138/200 Batch 12, Loss 11.3542\n",
      "Epoch 138/200 Batch 13, Loss 11.2630\n",
      "Epoch 138/200 Batch 14, Loss 11.3724\n",
      "Epoch 138/200 Batch 15, Loss 11.4001\n",
      "Epoch 138/200 Batch 16, Loss 11.4025\n",
      "Epoch 138/200 Batch 17, Loss 11.3460\n",
      "Epoch 138/200 Batch 18, Loss 11.4220\n",
      "Epoch 138/200 Batch 19, Loss 11.5599\n",
      "Epoch 139/200 Batch 0, Loss 11.3894\n",
      "Epoch 139/200 Batch 1, Loss 11.4104\n",
      "Epoch 139/200 Batch 2, Loss 11.2300\n",
      "Epoch 139/200 Batch 3, Loss 11.3288\n",
      "Epoch 139/200 Batch 4, Loss 11.2515\n",
      "Epoch 139/200 Batch 5, Loss 11.4117\n",
      "Epoch 139/200 Batch 6, Loss 11.2333\n",
      "Epoch 139/200 Batch 7, Loss 11.2305\n",
      "Epoch 139/200 Batch 8, Loss 11.2774\n",
      "Epoch 139/200 Batch 9, Loss 11.3193\n",
      "Epoch 139/200 Batch 10, Loss 11.2498\n",
      "Epoch 139/200 Batch 11, Loss 11.3070\n",
      "Epoch 139/200 Batch 12, Loss 11.2422\n",
      "Epoch 139/200 Batch 13, Loss 11.2849\n",
      "Epoch 139/200 Batch 14, Loss 11.4003\n",
      "Epoch 139/200 Batch 15, Loss 11.2438\n",
      "Epoch 139/200 Batch 16, Loss 11.4071\n",
      "Epoch 139/200 Batch 17, Loss 11.3197\n",
      "Epoch 139/200 Batch 18, Loss 11.3758\n",
      "Epoch 139/200 Batch 19, Loss 11.4122\n",
      "Epoch 140/200 Batch 0, Loss 11.2897\n",
      "Epoch 140/200 Batch 1, Loss 11.3309\n",
      "Epoch 140/200 Batch 2, Loss 11.2012\n",
      "Epoch 140/200 Batch 3, Loss 11.2545\n",
      "Epoch 140/200 Batch 4, Loss 11.4140\n",
      "Epoch 140/200 Batch 5, Loss 11.5002\n",
      "Epoch 140/200 Batch 6, Loss 11.4501\n",
      "Epoch 140/200 Batch 7, Loss 11.2236\n",
      "Epoch 140/200 Batch 8, Loss 11.3438\n",
      "Epoch 140/200 Batch 9, Loss 11.4299\n",
      "Epoch 140/200 Batch 10, Loss 11.2420\n",
      "Epoch 140/200 Batch 11, Loss 11.2514\n",
      "Epoch 140/200 Batch 12, Loss 11.5806\n",
      "Epoch 140/200 Batch 13, Loss 11.1991\n",
      "Epoch 140/200 Batch 14, Loss 11.2824\n",
      "Epoch 140/200 Batch 15, Loss 11.4171\n",
      "Epoch 140/200 Batch 16, Loss 11.4073\n",
      "Epoch 140/200 Batch 17, Loss 11.3863\n",
      "Epoch 140/200 Batch 18, Loss 11.2306\n",
      "Epoch 140/200 Batch 19, Loss 11.3368\n",
      "Epoch 141/200 Batch 0, Loss 11.2907\n",
      "Epoch 141/200 Batch 1, Loss 11.2615\n",
      "Epoch 141/200 Batch 2, Loss 11.1785\n",
      "Epoch 141/200 Batch 3, Loss 11.4369\n",
      "Epoch 141/200 Batch 4, Loss 11.3373\n",
      "Epoch 141/200 Batch 5, Loss 11.2897\n",
      "Epoch 141/200 Batch 6, Loss 11.4136\n",
      "Epoch 141/200 Batch 7, Loss 11.3025\n",
      "Epoch 141/200 Batch 8, Loss 11.2594\n",
      "Epoch 141/200 Batch 9, Loss 11.2389\n",
      "Epoch 141/200 Batch 10, Loss 11.3668\n",
      "Epoch 141/200 Batch 11, Loss 11.5143\n",
      "Epoch 141/200 Batch 12, Loss 11.3244\n",
      "Epoch 141/200 Batch 13, Loss 11.1321\n",
      "Epoch 141/200 Batch 14, Loss 11.4139\n",
      "Epoch 141/200 Batch 15, Loss 11.1746\n",
      "Epoch 141/200 Batch 16, Loss 11.3988\n",
      "Epoch 141/200 Batch 17, Loss 11.2424\n",
      "Epoch 141/200 Batch 18, Loss 11.4660\n",
      "Epoch 141/200 Batch 19, Loss 11.4120\n",
      "Epoch 142/200 Batch 0, Loss 11.4208\n",
      "Epoch 142/200 Batch 1, Loss 11.2911\n",
      "Epoch 142/200 Batch 2, Loss 11.4119\n",
      "Epoch 142/200 Batch 3, Loss 11.2268\n",
      "Epoch 142/200 Batch 4, Loss 11.1185\n",
      "Epoch 142/200 Batch 5, Loss 11.2303\n",
      "Epoch 142/200 Batch 6, Loss 11.1430\n",
      "Epoch 142/200 Batch 7, Loss 11.2689\n",
      "Epoch 142/200 Batch 8, Loss 11.5515\n",
      "Epoch 142/200 Batch 9, Loss 11.3568\n",
      "Epoch 142/200 Batch 10, Loss 11.2380\n",
      "Epoch 142/200 Batch 11, Loss 11.3095\n",
      "Epoch 142/200 Batch 12, Loss 11.3286\n",
      "Epoch 142/200 Batch 13, Loss 11.2937\n",
      "Epoch 142/200 Batch 14, Loss 11.4350\n",
      "Epoch 142/200 Batch 15, Loss 11.3867\n",
      "Epoch 142/200 Batch 16, Loss 11.3760\n",
      "Epoch 142/200 Batch 17, Loss 11.4169\n",
      "Epoch 142/200 Batch 18, Loss 11.3916\n",
      "Epoch 142/200 Batch 19, Loss 11.2281\n",
      "Epoch 143/200 Batch 0, Loss 11.2780\n",
      "Epoch 143/200 Batch 1, Loss 11.2618\n",
      "Epoch 143/200 Batch 2, Loss 11.5245\n",
      "Epoch 143/200 Batch 3, Loss 11.3968\n",
      "Epoch 143/200 Batch 4, Loss 11.3553\n",
      "Epoch 143/200 Batch 5, Loss 11.3419\n",
      "Epoch 143/200 Batch 6, Loss 11.3782\n",
      "Epoch 143/200 Batch 7, Loss 11.4803\n",
      "Epoch 143/200 Batch 8, Loss 11.3391\n",
      "Epoch 143/200 Batch 9, Loss 11.3825\n",
      "Epoch 143/200 Batch 10, Loss 11.2003\n",
      "Epoch 143/200 Batch 11, Loss 11.2902\n",
      "Epoch 143/200 Batch 12, Loss 11.4010\n",
      "Epoch 143/200 Batch 13, Loss 11.1905\n",
      "Epoch 143/200 Batch 14, Loss 11.2744\n",
      "Epoch 143/200 Batch 15, Loss 11.3544\n",
      "Epoch 143/200 Batch 16, Loss 11.4010\n",
      "Epoch 143/200 Batch 17, Loss 11.4110\n",
      "Epoch 143/200 Batch 18, Loss 11.2286\n",
      "Epoch 143/200 Batch 19, Loss 11.1605\n",
      "Epoch 144/200 Batch 0, Loss 11.3326\n",
      "Epoch 144/200 Batch 1, Loss 11.3702\n",
      "Epoch 144/200 Batch 2, Loss 11.1230\n",
      "Epoch 144/200 Batch 3, Loss 11.1890\n",
      "Epoch 144/200 Batch 4, Loss 11.3777\n",
      "Epoch 144/200 Batch 5, Loss 11.4205\n",
      "Epoch 144/200 Batch 6, Loss 11.3505\n",
      "Epoch 144/200 Batch 7, Loss 11.1679\n",
      "Epoch 144/200 Batch 8, Loss 11.3154\n",
      "Epoch 144/200 Batch 9, Loss 11.2972\n",
      "Epoch 144/200 Batch 10, Loss 11.2686\n",
      "Epoch 144/200 Batch 11, Loss 11.6814\n",
      "Epoch 144/200 Batch 12, Loss 11.4549\n",
      "Epoch 144/200 Batch 13, Loss 11.1742\n",
      "Epoch 144/200 Batch 14, Loss 11.3836\n",
      "Epoch 144/200 Batch 15, Loss 11.2620\n",
      "Epoch 144/200 Batch 16, Loss 11.3417\n",
      "Epoch 144/200 Batch 17, Loss 11.5053\n",
      "Epoch 144/200 Batch 18, Loss 11.2092\n",
      "Epoch 144/200 Batch 19, Loss 11.3330\n",
      "Epoch 145/200 Batch 0, Loss 11.3620\n",
      "Epoch 145/200 Batch 1, Loss 11.1771\n",
      "Epoch 145/200 Batch 2, Loss 11.2870\n",
      "Epoch 145/200 Batch 3, Loss 11.3769\n",
      "Epoch 145/200 Batch 4, Loss 11.2970\n",
      "Epoch 145/200 Batch 5, Loss 11.3292\n",
      "Epoch 145/200 Batch 6, Loss 11.2272\n",
      "Epoch 145/200 Batch 7, Loss 11.2686\n",
      "Epoch 145/200 Batch 8, Loss 11.2531\n",
      "Epoch 145/200 Batch 9, Loss 11.2925\n",
      "Epoch 145/200 Batch 10, Loss 11.2301\n",
      "Epoch 145/200 Batch 11, Loss 11.2983\n",
      "Epoch 145/200 Batch 12, Loss 11.2607\n",
      "Epoch 145/200 Batch 13, Loss 11.4591\n",
      "Epoch 145/200 Batch 14, Loss 11.2982\n",
      "Epoch 145/200 Batch 15, Loss 11.3613\n",
      "Epoch 145/200 Batch 16, Loss 11.3329\n",
      "Epoch 145/200 Batch 17, Loss 11.3210\n",
      "Epoch 145/200 Batch 18, Loss 11.2996\n",
      "Epoch 145/200 Batch 19, Loss 11.3384\n",
      "Epoch 146/200 Batch 0, Loss 11.2085\n",
      "Epoch 146/200 Batch 1, Loss 11.3731\n",
      "Epoch 146/200 Batch 2, Loss 11.2859\n",
      "Epoch 146/200 Batch 3, Loss 11.2930\n",
      "Epoch 146/200 Batch 4, Loss 11.1686\n",
      "Epoch 146/200 Batch 5, Loss 11.1837\n",
      "Epoch 146/200 Batch 6, Loss 11.3590\n",
      "Epoch 146/200 Batch 7, Loss 11.3994\n",
      "Epoch 146/200 Batch 8, Loss 11.3750\n",
      "Epoch 146/200 Batch 9, Loss 11.2650\n",
      "Epoch 146/200 Batch 10, Loss 11.2147\n",
      "Epoch 146/200 Batch 11, Loss 11.4240\n",
      "Epoch 146/200 Batch 12, Loss 11.1681\n",
      "Epoch 146/200 Batch 13, Loss 11.2909\n",
      "Epoch 146/200 Batch 14, Loss 11.3141\n",
      "Epoch 146/200 Batch 15, Loss 11.1665\n",
      "Epoch 146/200 Batch 16, Loss 11.3003\n",
      "Epoch 146/200 Batch 17, Loss 11.3104\n",
      "Epoch 146/200 Batch 18, Loss 11.5875\n",
      "Epoch 146/200 Batch 19, Loss 11.2446\n",
      "Epoch 147/200 Batch 0, Loss 11.3446\n",
      "Epoch 147/200 Batch 1, Loss 11.3084\n",
      "Epoch 147/200 Batch 2, Loss 11.2642\n",
      "Epoch 147/200 Batch 3, Loss 11.3554\n",
      "Epoch 147/200 Batch 4, Loss 11.2806\n",
      "Epoch 147/200 Batch 5, Loss 11.4167\n",
      "Epoch 147/200 Batch 6, Loss 11.4398\n",
      "Epoch 147/200 Batch 7, Loss 11.1662\n",
      "Epoch 147/200 Batch 8, Loss 11.4230\n",
      "Epoch 147/200 Batch 9, Loss 11.3278\n",
      "Epoch 147/200 Batch 10, Loss 11.1383\n",
      "Epoch 147/200 Batch 11, Loss 11.3661\n",
      "Epoch 147/200 Batch 12, Loss 11.4807\n",
      "Epoch 147/200 Batch 13, Loss 11.1702\n",
      "Epoch 147/200 Batch 14, Loss 11.3399\n",
      "Epoch 147/200 Batch 15, Loss 11.3512\n",
      "Epoch 147/200 Batch 16, Loss 11.4112\n",
      "Epoch 147/200 Batch 17, Loss 11.3417\n",
      "Epoch 147/200 Batch 18, Loss 11.2784\n",
      "Epoch 147/200 Batch 19, Loss 11.2695\n",
      "Epoch 148/200 Batch 0, Loss 11.2640\n",
      "Epoch 148/200 Batch 1, Loss 11.3456\n",
      "Epoch 148/200 Batch 2, Loss 11.1604\n",
      "Epoch 148/200 Batch 3, Loss 11.3011\n",
      "Epoch 148/200 Batch 4, Loss 11.4371\n",
      "Epoch 148/200 Batch 5, Loss 11.3697\n",
      "Epoch 148/200 Batch 6, Loss 11.3356\n",
      "Epoch 148/200 Batch 7, Loss 11.1992\n",
      "Epoch 148/200 Batch 8, Loss 11.3988\n",
      "Epoch 148/200 Batch 9, Loss 11.3509\n",
      "Epoch 148/200 Batch 10, Loss 11.4419\n",
      "Epoch 148/200 Batch 11, Loss 11.1007\n",
      "Epoch 148/200 Batch 12, Loss 11.3750\n",
      "Epoch 148/200 Batch 13, Loss 11.2355\n",
      "Epoch 148/200 Batch 14, Loss 11.3512\n",
      "Epoch 148/200 Batch 15, Loss 11.2863\n",
      "Epoch 148/200 Batch 16, Loss 11.3392\n",
      "Epoch 148/200 Batch 17, Loss 11.3666\n",
      "Epoch 148/200 Batch 18, Loss 11.4075\n",
      "Epoch 148/200 Batch 19, Loss 11.2165\n",
      "Epoch 149/200 Batch 0, Loss 11.3191\n",
      "Epoch 149/200 Batch 1, Loss 11.4472\n",
      "Epoch 149/200 Batch 2, Loss 11.0826\n",
      "Epoch 149/200 Batch 3, Loss 11.3047\n",
      "Epoch 149/200 Batch 4, Loss 11.3001\n",
      "Epoch 149/200 Batch 5, Loss 11.2809\n",
      "Epoch 149/200 Batch 6, Loss 11.3590\n",
      "Epoch 149/200 Batch 7, Loss 11.3523\n",
      "Epoch 149/200 Batch 8, Loss 11.2492\n",
      "Epoch 149/200 Batch 9, Loss 11.2867\n",
      "Epoch 149/200 Batch 10, Loss 11.4266\n",
      "Epoch 149/200 Batch 11, Loss 11.2234\n",
      "Epoch 149/200 Batch 12, Loss 11.3633\n",
      "Epoch 149/200 Batch 13, Loss 11.4249\n",
      "Epoch 149/200 Batch 14, Loss 11.2416\n",
      "Epoch 149/200 Batch 15, Loss 11.3990\n",
      "Epoch 149/200 Batch 16, Loss 11.4276\n",
      "Epoch 149/200 Batch 17, Loss 11.3900\n",
      "Epoch 149/200 Batch 18, Loss 11.2887\n",
      "Epoch 149/200 Batch 19, Loss 11.2100\n",
      "Epoch 150/200 Batch 0, Loss 11.1890\n",
      "Epoch 150/200 Batch 1, Loss 11.1959\n",
      "Epoch 150/200 Batch 2, Loss 11.2962\n",
      "Epoch 150/200 Batch 3, Loss 11.3895\n",
      "Epoch 150/200 Batch 4, Loss 11.3484\n",
      "Epoch 150/200 Batch 5, Loss 11.1968\n",
      "Epoch 150/200 Batch 6, Loss 11.2586\n",
      "Epoch 150/200 Batch 7, Loss 11.3880\n",
      "Epoch 150/200 Batch 8, Loss 11.3151\n",
      "Epoch 150/200 Batch 9, Loss 11.2772\n",
      "Epoch 150/200 Batch 10, Loss 11.3549\n",
      "Epoch 150/200 Batch 11, Loss 11.3317\n",
      "Epoch 150/200 Batch 12, Loss 11.2948\n",
      "Epoch 150/200 Batch 13, Loss 11.3668\n",
      "Epoch 150/200 Batch 14, Loss 11.1714\n",
      "Epoch 150/200 Batch 15, Loss 11.5590\n",
      "Epoch 150/200 Batch 16, Loss 11.2778\n",
      "Epoch 150/200 Batch 17, Loss 11.3465\n",
      "Epoch 150/200 Batch 18, Loss 11.4238\n",
      "Epoch 150/200 Batch 19, Loss 11.2969\n",
      "Epoch 151/200 Batch 0, Loss 11.2077\n",
      "Epoch 151/200 Batch 1, Loss 11.3279\n",
      "Epoch 151/200 Batch 2, Loss 11.2286\n",
      "Epoch 151/200 Batch 3, Loss 11.4282\n",
      "Epoch 151/200 Batch 4, Loss 11.3011\n",
      "Epoch 151/200 Batch 5, Loss 11.2036\n",
      "Epoch 151/200 Batch 6, Loss 11.3084\n",
      "Epoch 151/200 Batch 7, Loss 11.3489\n",
      "Epoch 151/200 Batch 8, Loss 11.2451\n",
      "Epoch 151/200 Batch 9, Loss 11.2337\n",
      "Epoch 151/200 Batch 10, Loss 11.4849\n",
      "Epoch 151/200 Batch 11, Loss 11.3020\n",
      "Epoch 151/200 Batch 12, Loss 11.2441\n",
      "Epoch 151/200 Batch 13, Loss 11.3388\n",
      "Epoch 151/200 Batch 14, Loss 11.4694\n",
      "Epoch 151/200 Batch 15, Loss 11.3406\n",
      "Epoch 151/200 Batch 16, Loss 11.4385\n",
      "Epoch 151/200 Batch 17, Loss 11.3968\n",
      "Epoch 151/200 Batch 18, Loss 11.2218\n",
      "Epoch 151/200 Batch 19, Loss 11.5737\n",
      "Epoch 152/200 Batch 0, Loss 11.2423\n",
      "Epoch 152/200 Batch 1, Loss 11.4609\n",
      "Epoch 152/200 Batch 2, Loss 11.4041\n",
      "Epoch 152/200 Batch 3, Loss 11.2797\n",
      "Epoch 152/200 Batch 4, Loss 11.2531\n",
      "Epoch 152/200 Batch 5, Loss 11.2853\n",
      "Epoch 152/200 Batch 6, Loss 11.2358\n",
      "Epoch 152/200 Batch 7, Loss 11.3494\n",
      "Epoch 152/200 Batch 8, Loss 11.3495\n",
      "Epoch 152/200 Batch 9, Loss 11.2167\n",
      "Epoch 152/200 Batch 10, Loss 11.4900\n",
      "Epoch 152/200 Batch 11, Loss 11.2728\n",
      "Epoch 152/200 Batch 12, Loss 11.2578\n",
      "Epoch 152/200 Batch 13, Loss 11.3309\n",
      "Epoch 152/200 Batch 14, Loss 11.2644\n",
      "Epoch 152/200 Batch 15, Loss 11.2568\n",
      "Epoch 152/200 Batch 16, Loss 11.4596\n",
      "Epoch 152/200 Batch 17, Loss 11.3747\n",
      "Epoch 152/200 Batch 18, Loss 11.3777\n",
      "Epoch 152/200 Batch 19, Loss 11.1706\n",
      "Epoch 153/200 Batch 0, Loss 11.2979\n",
      "Epoch 153/200 Batch 1, Loss 11.3524\n",
      "Epoch 153/200 Batch 2, Loss 11.2827\n",
      "Epoch 153/200 Batch 3, Loss 11.3557\n",
      "Epoch 153/200 Batch 4, Loss 11.2819\n",
      "Epoch 153/200 Batch 5, Loss 11.1513\n",
      "Epoch 153/200 Batch 6, Loss 11.3914\n",
      "Epoch 153/200 Batch 7, Loss 11.4285\n",
      "Epoch 153/200 Batch 8, Loss 11.3306\n",
      "Epoch 153/200 Batch 9, Loss 11.2068\n",
      "Epoch 153/200 Batch 10, Loss 11.3369\n",
      "Epoch 153/200 Batch 11, Loss 11.6080\n",
      "Epoch 153/200 Batch 12, Loss 11.3356\n",
      "Epoch 153/200 Batch 13, Loss 11.3619\n",
      "Epoch 153/200 Batch 14, Loss 11.3080\n",
      "Epoch 153/200 Batch 15, Loss 11.1128\n",
      "Epoch 153/200 Batch 16, Loss 11.3862\n",
      "Epoch 153/200 Batch 17, Loss 11.3472\n",
      "Epoch 153/200 Batch 18, Loss 11.6134\n",
      "Epoch 153/200 Batch 19, Loss 11.1484\n",
      "Epoch 154/200 Batch 0, Loss 11.3170\n",
      "Epoch 154/200 Batch 1, Loss 11.3354\n",
      "Epoch 154/200 Batch 2, Loss 11.4226\n",
      "Epoch 154/200 Batch 3, Loss 11.3403\n",
      "Epoch 154/200 Batch 4, Loss 11.2537\n",
      "Epoch 154/200 Batch 5, Loss 11.1475\n",
      "Epoch 154/200 Batch 6, Loss 11.2486\n",
      "Epoch 154/200 Batch 7, Loss 11.3499\n",
      "Epoch 154/200 Batch 8, Loss 11.4564\n",
      "Epoch 154/200 Batch 9, Loss 11.3802\n",
      "Epoch 154/200 Batch 10, Loss 11.1921\n",
      "Epoch 154/200 Batch 11, Loss 11.3653\n",
      "Epoch 154/200 Batch 12, Loss 11.4206\n",
      "Epoch 154/200 Batch 13, Loss 11.4205\n",
      "Epoch 154/200 Batch 14, Loss 11.4642\n",
      "Epoch 154/200 Batch 15, Loss 11.4898\n",
      "Epoch 154/200 Batch 16, Loss 11.2671\n",
      "Epoch 154/200 Batch 17, Loss 11.1970\n",
      "Epoch 154/200 Batch 18, Loss 11.2444\n",
      "Epoch 154/200 Batch 19, Loss 11.3739\n",
      "Epoch 155/200 Batch 0, Loss 11.3930\n",
      "Epoch 155/200 Batch 1, Loss 11.2193\n",
      "Epoch 155/200 Batch 2, Loss 11.4006\n",
      "Epoch 155/200 Batch 3, Loss 11.5957\n",
      "Epoch 155/200 Batch 4, Loss 11.2317\n",
      "Epoch 155/200 Batch 5, Loss 11.2469\n",
      "Epoch 155/200 Batch 6, Loss 11.4762\n",
      "Epoch 155/200 Batch 7, Loss 11.3870\n",
      "Epoch 155/200 Batch 8, Loss 11.4872\n",
      "Epoch 155/200 Batch 9, Loss 11.1410\n",
      "Epoch 155/200 Batch 10, Loss 11.4990\n",
      "Epoch 155/200 Batch 11, Loss 11.4507\n",
      "Epoch 155/200 Batch 12, Loss 11.2124\n",
      "Epoch 155/200 Batch 13, Loss 11.2503\n",
      "Epoch 155/200 Batch 14, Loss 11.2696\n",
      "Epoch 155/200 Batch 15, Loss 11.3565\n",
      "Epoch 155/200 Batch 16, Loss 11.1365\n",
      "Epoch 155/200 Batch 17, Loss 11.1425\n",
      "Epoch 155/200 Batch 18, Loss 11.3634\n",
      "Epoch 155/200 Batch 19, Loss 11.2647\n",
      "Epoch 156/200 Batch 0, Loss 11.2841\n",
      "Epoch 156/200 Batch 1, Loss 11.4007\n",
      "Epoch 156/200 Batch 2, Loss 11.2018\n",
      "Epoch 156/200 Batch 3, Loss 11.4304\n",
      "Epoch 156/200 Batch 4, Loss 11.1772\n",
      "Epoch 156/200 Batch 5, Loss 11.4362\n",
      "Epoch 156/200 Batch 6, Loss 11.2126\n",
      "Epoch 156/200 Batch 7, Loss 11.4361\n",
      "Epoch 156/200 Batch 8, Loss 11.2570\n",
      "Epoch 156/200 Batch 9, Loss 11.2426\n",
      "Epoch 156/200 Batch 10, Loss 11.3274\n",
      "Epoch 156/200 Batch 11, Loss 11.2159\n",
      "Epoch 156/200 Batch 12, Loss 11.3857\n",
      "Epoch 156/200 Batch 13, Loss 11.2713\n",
      "Epoch 156/200 Batch 14, Loss 11.4183\n",
      "Epoch 156/200 Batch 15, Loss 11.2684\n",
      "Epoch 156/200 Batch 16, Loss 11.3814\n",
      "Epoch 156/200 Batch 17, Loss 11.3542\n",
      "Epoch 156/200 Batch 18, Loss 11.3095\n",
      "Epoch 156/200 Batch 19, Loss 11.2231\n",
      "Epoch 157/200 Batch 0, Loss 11.1573\n",
      "Epoch 157/200 Batch 1, Loss 11.1671\n",
      "Epoch 157/200 Batch 2, Loss 11.3118\n",
      "Epoch 157/200 Batch 3, Loss 11.4019\n",
      "Epoch 157/200 Batch 4, Loss 11.3851\n",
      "Epoch 157/200 Batch 5, Loss 11.2347\n",
      "Epoch 157/200 Batch 6, Loss 11.2676\n",
      "Epoch 157/200 Batch 7, Loss 11.3463\n",
      "Epoch 157/200 Batch 8, Loss 11.4668\n",
      "Epoch 157/200 Batch 9, Loss 11.2792\n",
      "Epoch 157/200 Batch 10, Loss 11.4549\n",
      "Epoch 157/200 Batch 11, Loss 11.3369\n",
      "Epoch 157/200 Batch 12, Loss 11.3230\n",
      "Epoch 157/200 Batch 13, Loss 11.5285\n",
      "Epoch 157/200 Batch 14, Loss 11.3774\n",
      "Epoch 157/200 Batch 15, Loss 11.5534\n",
      "Epoch 157/200 Batch 16, Loss 11.3292\n",
      "Epoch 157/200 Batch 17, Loss 11.2819\n",
      "Epoch 157/200 Batch 18, Loss 11.2950\n",
      "Epoch 157/200 Batch 19, Loss 11.2277\n",
      "Epoch 158/200 Batch 0, Loss 11.2264\n",
      "Epoch 158/200 Batch 1, Loss 11.3187\n",
      "Epoch 158/200 Batch 2, Loss 11.5455\n",
      "Epoch 158/200 Batch 3, Loss 11.2486\n",
      "Epoch 158/200 Batch 4, Loss 11.4057\n",
      "Epoch 158/200 Batch 5, Loss 11.1016\n",
      "Epoch 158/200 Batch 6, Loss 11.2619\n",
      "Epoch 158/200 Batch 7, Loss 11.3682\n",
      "Epoch 158/200 Batch 8, Loss 11.3482\n",
      "Epoch 158/200 Batch 9, Loss 11.4560\n",
      "Epoch 158/200 Batch 10, Loss 11.3718\n",
      "Epoch 158/200 Batch 11, Loss 11.3523\n",
      "Epoch 158/200 Batch 12, Loss 11.1820\n",
      "Epoch 158/200 Batch 13, Loss 11.3513\n",
      "Epoch 158/200 Batch 14, Loss 11.1311\n",
      "Epoch 158/200 Batch 15, Loss 11.4362\n",
      "Epoch 158/200 Batch 16, Loss 11.4385\n",
      "Epoch 158/200 Batch 17, Loss 11.4325\n",
      "Epoch 158/200 Batch 18, Loss 11.3431\n",
      "Epoch 158/200 Batch 19, Loss 11.3892\n",
      "Epoch 159/200 Batch 0, Loss 11.2556\n",
      "Epoch 159/200 Batch 1, Loss 11.2937\n",
      "Epoch 159/200 Batch 2, Loss 11.4142\n",
      "Epoch 159/200 Batch 3, Loss 11.3232\n",
      "Epoch 159/200 Batch 4, Loss 11.3661\n",
      "Epoch 159/200 Batch 5, Loss 11.4119\n",
      "Epoch 159/200 Batch 6, Loss 11.2677\n",
      "Epoch 159/200 Batch 7, Loss 11.3325\n",
      "Epoch 159/200 Batch 8, Loss 11.2090\n",
      "Epoch 159/200 Batch 9, Loss 11.5070\n",
      "Epoch 159/200 Batch 10, Loss 11.3810\n",
      "Epoch 159/200 Batch 11, Loss 11.2869\n",
      "Epoch 159/200 Batch 12, Loss 11.2227\n",
      "Epoch 159/200 Batch 13, Loss 11.3854\n",
      "Epoch 159/200 Batch 14, Loss 11.3898\n",
      "Epoch 159/200 Batch 15, Loss 11.1855\n",
      "Epoch 159/200 Batch 16, Loss 11.3070\n",
      "Epoch 159/200 Batch 17, Loss 11.4126\n",
      "Epoch 159/200 Batch 18, Loss 11.2562\n",
      "Epoch 159/200 Batch 19, Loss 11.3933\n",
      "Epoch 160/200 Batch 0, Loss 11.5718\n",
      "Epoch 160/200 Batch 1, Loss 11.3559\n",
      "Epoch 160/200 Batch 2, Loss 11.2232\n",
      "Epoch 160/200 Batch 3, Loss 11.4138\n",
      "Epoch 160/200 Batch 4, Loss 11.1134\n",
      "Epoch 160/200 Batch 5, Loss 11.2357\n",
      "Epoch 160/200 Batch 6, Loss 11.1255\n",
      "Epoch 160/200 Batch 7, Loss 11.2703\n",
      "Epoch 160/200 Batch 8, Loss 11.4105\n",
      "Epoch 160/200 Batch 9, Loss 11.1597\n",
      "Epoch 160/200 Batch 10, Loss 11.1887\n",
      "Epoch 160/200 Batch 11, Loss 11.3457\n",
      "Epoch 160/200 Batch 12, Loss 11.3103\n",
      "Epoch 160/200 Batch 13, Loss 11.2101\n",
      "Epoch 160/200 Batch 14, Loss 11.2465\n",
      "Epoch 160/200 Batch 15, Loss 11.4529\n",
      "Epoch 160/200 Batch 16, Loss 11.3305\n",
      "Epoch 160/200 Batch 17, Loss 11.3946\n",
      "Epoch 160/200 Batch 18, Loss 11.4574\n",
      "Epoch 160/200 Batch 19, Loss 11.2612\n",
      "Epoch 161/200 Batch 0, Loss 11.3235\n",
      "Epoch 161/200 Batch 1, Loss 11.3288\n",
      "Epoch 161/200 Batch 2, Loss 11.4089\n",
      "Epoch 161/200 Batch 3, Loss 11.2518\n",
      "Epoch 161/200 Batch 4, Loss 11.3464\n",
      "Epoch 161/200 Batch 5, Loss 11.2194\n",
      "Epoch 161/200 Batch 6, Loss 11.1902\n",
      "Epoch 161/200 Batch 7, Loss 11.3708\n",
      "Epoch 161/200 Batch 8, Loss 11.2927\n",
      "Epoch 161/200 Batch 9, Loss 11.3644\n",
      "Epoch 161/200 Batch 10, Loss 11.4727\n",
      "Epoch 161/200 Batch 11, Loss 11.3710\n",
      "Epoch 161/200 Batch 12, Loss 11.1722\n",
      "Epoch 161/200 Batch 13, Loss 11.3395\n",
      "Epoch 161/200 Batch 14, Loss 11.3197\n",
      "Epoch 161/200 Batch 15, Loss 11.2719\n",
      "Epoch 161/200 Batch 16, Loss 11.3752\n",
      "Epoch 161/200 Batch 17, Loss 11.2761\n",
      "Epoch 161/200 Batch 18, Loss 11.4496\n",
      "Epoch 161/200 Batch 19, Loss 11.1029\n",
      "Epoch 162/200 Batch 0, Loss 11.3326\n",
      "Epoch 162/200 Batch 1, Loss 11.3787\n",
      "Epoch 162/200 Batch 2, Loss 11.3542\n",
      "Epoch 162/200 Batch 3, Loss 11.3656\n",
      "Epoch 162/200 Batch 4, Loss 11.4398\n",
      "Epoch 162/200 Batch 5, Loss 11.3697\n",
      "Epoch 162/200 Batch 6, Loss 11.2895\n",
      "Epoch 162/200 Batch 7, Loss 11.2609\n",
      "Epoch 162/200 Batch 8, Loss 11.2790\n",
      "Epoch 162/200 Batch 9, Loss 11.4545\n",
      "Epoch 162/200 Batch 10, Loss 11.4049\n",
      "Epoch 162/200 Batch 11, Loss 11.4138\n",
      "Epoch 162/200 Batch 12, Loss 11.3586\n",
      "Epoch 162/200 Batch 13, Loss 11.4038\n",
      "Epoch 162/200 Batch 14, Loss 11.4413\n",
      "Epoch 162/200 Batch 15, Loss 11.1317\n",
      "Epoch 162/200 Batch 16, Loss 11.3101\n",
      "Epoch 162/200 Batch 17, Loss 11.3105\n",
      "Epoch 162/200 Batch 18, Loss 11.1456\n",
      "Epoch 162/200 Batch 19, Loss 11.1634\n",
      "Epoch 163/200 Batch 0, Loss 11.2364\n",
      "Epoch 163/200 Batch 1, Loss 11.2215\n",
      "Epoch 163/200 Batch 2, Loss 11.2702\n",
      "Epoch 163/200 Batch 3, Loss 11.2460\n",
      "Epoch 163/200 Batch 4, Loss 11.4878\n",
      "Epoch 163/200 Batch 5, Loss 11.1812\n",
      "Epoch 163/200 Batch 6, Loss 11.2651\n",
      "Epoch 163/200 Batch 7, Loss 11.2914\n",
      "Epoch 163/200 Batch 8, Loss 11.3213\n",
      "Epoch 163/200 Batch 9, Loss 11.4409\n",
      "Epoch 163/200 Batch 10, Loss 11.4114\n",
      "Epoch 163/200 Batch 11, Loss 11.4217\n",
      "Epoch 163/200 Batch 12, Loss 11.2773\n",
      "Epoch 163/200 Batch 13, Loss 11.4098\n",
      "Epoch 163/200 Batch 14, Loss 11.2638\n",
      "Epoch 163/200 Batch 15, Loss 11.5037\n",
      "Epoch 163/200 Batch 16, Loss 11.3433\n",
      "Epoch 163/200 Batch 17, Loss 11.2064\n",
      "Epoch 163/200 Batch 18, Loss 11.3293\n",
      "Epoch 163/200 Batch 19, Loss 11.4474\n",
      "Epoch 164/200 Batch 0, Loss 11.4249\n",
      "Epoch 164/200 Batch 1, Loss 11.2828\n",
      "Epoch 164/200 Batch 2, Loss 11.3451\n",
      "Epoch 164/200 Batch 3, Loss 11.2094\n",
      "Epoch 164/200 Batch 4, Loss 11.3956\n",
      "Epoch 164/200 Batch 5, Loss 11.3066\n",
      "Epoch 164/200 Batch 6, Loss 11.4827\n",
      "Epoch 164/200 Batch 7, Loss 11.4716\n",
      "Epoch 164/200 Batch 8, Loss 11.3169\n",
      "Epoch 164/200 Batch 9, Loss 11.3605\n",
      "Epoch 164/200 Batch 10, Loss 11.3527\n",
      "Epoch 164/200 Batch 11, Loss 11.3048\n",
      "Epoch 164/200 Batch 12, Loss 11.3383\n",
      "Epoch 164/200 Batch 13, Loss 11.3137\n",
      "Epoch 164/200 Batch 14, Loss 11.5204\n",
      "Epoch 164/200 Batch 15, Loss 11.3440\n",
      "Epoch 164/200 Batch 16, Loss 11.1675\n",
      "Epoch 164/200 Batch 17, Loss 11.2024\n",
      "Epoch 164/200 Batch 18, Loss 11.3199\n",
      "Epoch 164/200 Batch 19, Loss 11.3635\n",
      "Epoch 165/200 Batch 0, Loss 11.4451\n",
      "Epoch 165/200 Batch 1, Loss 11.4032\n",
      "Epoch 165/200 Batch 2, Loss 11.2797\n",
      "Epoch 165/200 Batch 3, Loss 11.3947\n",
      "Epoch 165/200 Batch 4, Loss 11.2591\n",
      "Epoch 165/200 Batch 5, Loss 11.4278\n",
      "Epoch 165/200 Batch 6, Loss 11.2462\n",
      "Epoch 165/200 Batch 7, Loss 11.2369\n",
      "Epoch 165/200 Batch 8, Loss 11.1990\n",
      "Epoch 165/200 Batch 9, Loss 11.3411\n",
      "Epoch 165/200 Batch 10, Loss 11.5740\n",
      "Epoch 165/200 Batch 11, Loss 11.3547\n",
      "Epoch 165/200 Batch 12, Loss 11.1765\n",
      "Epoch 165/200 Batch 13, Loss 11.1928\n",
      "Epoch 165/200 Batch 14, Loss 11.3687\n",
      "Epoch 165/200 Batch 15, Loss 11.2824\n",
      "Epoch 165/200 Batch 16, Loss 11.4357\n",
      "Epoch 165/200 Batch 17, Loss 11.2911\n",
      "Epoch 165/200 Batch 18, Loss 11.1868\n",
      "Epoch 165/200 Batch 19, Loss 11.4072\n",
      "Epoch 166/200 Batch 0, Loss 11.3806\n",
      "Epoch 166/200 Batch 1, Loss 11.3946\n",
      "Epoch 166/200 Batch 2, Loss 11.3135\n",
      "Epoch 166/200 Batch 3, Loss 11.2500\n",
      "Epoch 166/200 Batch 4, Loss 11.2979\n",
      "Epoch 166/200 Batch 5, Loss 11.2638\n",
      "Epoch 166/200 Batch 6, Loss 11.1419\n",
      "Epoch 166/200 Batch 7, Loss 11.2505\n",
      "Epoch 166/200 Batch 8, Loss 11.3447\n",
      "Epoch 166/200 Batch 9, Loss 11.1834\n",
      "Epoch 166/200 Batch 10, Loss 11.2926\n",
      "Epoch 166/200 Batch 11, Loss 11.3334\n",
      "Epoch 166/200 Batch 12, Loss 11.4646\n",
      "Epoch 166/200 Batch 13, Loss 11.4909\n",
      "Epoch 166/200 Batch 14, Loss 11.2021\n",
      "Epoch 166/200 Batch 15, Loss 11.2268\n",
      "Epoch 166/200 Batch 16, Loss 11.2178\n",
      "Epoch 166/200 Batch 17, Loss 11.4711\n",
      "Epoch 166/200 Batch 18, Loss 11.4439\n",
      "Epoch 166/200 Batch 19, Loss 11.1747\n",
      "Epoch 167/200 Batch 0, Loss 11.3119\n",
      "Epoch 167/200 Batch 1, Loss 11.2867\n",
      "Epoch 167/200 Batch 2, Loss 11.4004\n",
      "Epoch 167/200 Batch 3, Loss 11.1834\n",
      "Epoch 167/200 Batch 4, Loss 11.3105\n",
      "Epoch 167/200 Batch 5, Loss 11.5357\n",
      "Epoch 167/200 Batch 6, Loss 11.3602\n",
      "Epoch 167/200 Batch 7, Loss 11.1881\n",
      "Epoch 167/200 Batch 8, Loss 11.2135\n",
      "Epoch 167/200 Batch 9, Loss 11.2959\n",
      "Epoch 167/200 Batch 10, Loss 11.3882\n",
      "Epoch 167/200 Batch 11, Loss 11.3454\n",
      "Epoch 167/200 Batch 12, Loss 11.2653\n",
      "Epoch 167/200 Batch 13, Loss 11.2953\n",
      "Epoch 167/200 Batch 14, Loss 11.4114\n",
      "Epoch 167/200 Batch 15, Loss 11.4844\n",
      "Epoch 167/200 Batch 16, Loss 11.2341\n",
      "Epoch 167/200 Batch 17, Loss 11.2969\n",
      "Epoch 167/200 Batch 18, Loss 11.2212\n",
      "Epoch 167/200 Batch 19, Loss 11.3914\n",
      "Epoch 168/200 Batch 0, Loss 11.4374\n",
      "Epoch 168/200 Batch 1, Loss 11.2169\n",
      "Epoch 168/200 Batch 2, Loss 11.2300\n",
      "Epoch 168/200 Batch 3, Loss 11.2398\n",
      "Epoch 168/200 Batch 4, Loss 11.4354\n",
      "Epoch 168/200 Batch 5, Loss 11.2957\n",
      "Epoch 168/200 Batch 6, Loss 11.3907\n",
      "Epoch 168/200 Batch 7, Loss 11.3940\n",
      "Epoch 168/200 Batch 8, Loss 11.4200\n",
      "Epoch 168/200 Batch 9, Loss 11.4203\n",
      "Epoch 168/200 Batch 10, Loss 11.1519\n",
      "Epoch 168/200 Batch 11, Loss 11.1776\n",
      "Epoch 168/200 Batch 12, Loss 11.3057\n",
      "Epoch 168/200 Batch 13, Loss 11.2725\n",
      "Epoch 168/200 Batch 14, Loss 11.1726\n",
      "Epoch 168/200 Batch 15, Loss 11.4166\n",
      "Epoch 168/200 Batch 16, Loss 11.2504\n",
      "Epoch 168/200 Batch 17, Loss 11.6766\n",
      "Epoch 168/200 Batch 18, Loss 11.2865\n",
      "Epoch 168/200 Batch 19, Loss 11.3058\n",
      "Epoch 169/200 Batch 0, Loss 11.3153\n",
      "Epoch 169/200 Batch 1, Loss 11.2335\n",
      "Epoch 169/200 Batch 2, Loss 11.4400\n",
      "Epoch 169/200 Batch 3, Loss 11.3878\n",
      "Epoch 169/200 Batch 4, Loss 11.3158\n",
      "Epoch 169/200 Batch 5, Loss 11.3763\n",
      "Epoch 169/200 Batch 6, Loss 11.4172\n",
      "Epoch 169/200 Batch 7, Loss 11.2647\n",
      "Epoch 169/200 Batch 8, Loss 11.4589\n",
      "Epoch 169/200 Batch 9, Loss 11.3151\n",
      "Epoch 169/200 Batch 10, Loss 11.1487\n",
      "Epoch 169/200 Batch 11, Loss 11.3227\n",
      "Epoch 169/200 Batch 12, Loss 11.2694\n",
      "Epoch 169/200 Batch 13, Loss 11.3212\n",
      "Epoch 169/200 Batch 14, Loss 11.2579\n",
      "Epoch 169/200 Batch 15, Loss 11.2190\n",
      "Epoch 169/200 Batch 16, Loss 11.3133\n",
      "Epoch 169/200 Batch 17, Loss 11.4598\n",
      "Epoch 169/200 Batch 18, Loss 11.4418\n",
      "Epoch 169/200 Batch 19, Loss 11.3444\n",
      "Epoch 170/200 Batch 0, Loss 11.3284\n",
      "Epoch 170/200 Batch 1, Loss 11.3480\n",
      "Epoch 170/200 Batch 2, Loss 11.4400\n",
      "Epoch 170/200 Batch 3, Loss 11.1153\n",
      "Epoch 170/200 Batch 4, Loss 11.4306\n",
      "Epoch 170/200 Batch 5, Loss 11.4107\n",
      "Epoch 170/200 Batch 6, Loss 11.3116\n",
      "Epoch 170/200 Batch 7, Loss 11.0746\n",
      "Epoch 170/200 Batch 8, Loss 11.4119\n",
      "Epoch 170/200 Batch 9, Loss 11.2128\n",
      "Epoch 170/200 Batch 10, Loss 11.3693\n",
      "Epoch 170/200 Batch 11, Loss 11.3285\n",
      "Epoch 170/200 Batch 12, Loss 11.3121\n",
      "Epoch 170/200 Batch 13, Loss 11.3978\n",
      "Epoch 170/200 Batch 14, Loss 11.2686\n",
      "Epoch 170/200 Batch 15, Loss 11.3866\n",
      "Epoch 170/200 Batch 16, Loss 11.3900\n",
      "Epoch 170/200 Batch 17, Loss 11.2575\n",
      "Epoch 170/200 Batch 18, Loss 11.3952\n",
      "Epoch 170/200 Batch 19, Loss 11.3396\n",
      "Epoch 171/200 Batch 0, Loss 11.3012\n",
      "Epoch 171/200 Batch 1, Loss 11.5435\n",
      "Epoch 171/200 Batch 2, Loss 11.2381\n",
      "Epoch 171/200 Batch 3, Loss 11.1379\n",
      "Epoch 171/200 Batch 4, Loss 11.3067\n",
      "Epoch 171/200 Batch 5, Loss 11.3047\n",
      "Epoch 171/200 Batch 6, Loss 11.2770\n",
      "Epoch 171/200 Batch 7, Loss 11.5099\n",
      "Epoch 171/200 Batch 8, Loss 11.3222\n",
      "Epoch 171/200 Batch 9, Loss 11.2195\n",
      "Epoch 171/200 Batch 10, Loss 11.2189\n",
      "Epoch 171/200 Batch 11, Loss 11.4107\n",
      "Epoch 171/200 Batch 12, Loss 11.3588\n",
      "Epoch 171/200 Batch 13, Loss 11.4311\n",
      "Epoch 171/200 Batch 14, Loss 11.2671\n",
      "Epoch 171/200 Batch 15, Loss 11.3259\n",
      "Epoch 171/200 Batch 16, Loss 11.3909\n",
      "Epoch 171/200 Batch 17, Loss 11.5226\n",
      "Epoch 171/200 Batch 18, Loss 11.2598\n",
      "Epoch 171/200 Batch 19, Loss 11.3711\n",
      "Epoch 172/200 Batch 0, Loss 11.2739\n",
      "Epoch 172/200 Batch 1, Loss 11.4448\n",
      "Epoch 172/200 Batch 2, Loss 11.2497\n",
      "Epoch 172/200 Batch 3, Loss 11.2217\n",
      "Epoch 172/200 Batch 4, Loss 11.3623\n",
      "Epoch 172/200 Batch 5, Loss 11.3662\n",
      "Epoch 172/200 Batch 6, Loss 11.4069\n",
      "Epoch 172/200 Batch 7, Loss 11.3091\n",
      "Epoch 172/200 Batch 8, Loss 11.3430\n",
      "Epoch 172/200 Batch 9, Loss 11.4608\n",
      "Epoch 172/200 Batch 10, Loss 11.3792\n",
      "Epoch 172/200 Batch 11, Loss 11.4604\n",
      "Epoch 172/200 Batch 12, Loss 11.3281\n",
      "Epoch 172/200 Batch 13, Loss 11.2469\n",
      "Epoch 172/200 Batch 14, Loss 11.3655\n",
      "Epoch 172/200 Batch 15, Loss 11.2768\n",
      "Epoch 172/200 Batch 16, Loss 11.2718\n",
      "Epoch 172/200 Batch 17, Loss 11.3063\n",
      "Epoch 172/200 Batch 18, Loss 11.3878\n",
      "Epoch 172/200 Batch 19, Loss 11.2572\n",
      "Epoch 173/200 Batch 0, Loss 11.1138\n",
      "Epoch 173/200 Batch 1, Loss 11.2699\n",
      "Epoch 173/200 Batch 2, Loss 11.2361\n",
      "Epoch 173/200 Batch 3, Loss 11.3683\n",
      "Epoch 173/200 Batch 4, Loss 11.2171\n",
      "Epoch 173/200 Batch 5, Loss 11.2055\n",
      "Epoch 173/200 Batch 6, Loss 11.2837\n",
      "Epoch 173/200 Batch 7, Loss 11.4173\n",
      "Epoch 173/200 Batch 8, Loss 11.4014\n",
      "Epoch 173/200 Batch 9, Loss 11.4493\n",
      "Epoch 173/200 Batch 10, Loss 11.3936\n",
      "Epoch 173/200 Batch 11, Loss 11.3993\n",
      "Epoch 173/200 Batch 12, Loss 11.2433\n",
      "Epoch 173/200 Batch 13, Loss 11.3404\n",
      "Epoch 173/200 Batch 14, Loss 11.4621\n",
      "Epoch 173/200 Batch 15, Loss 11.2808\n",
      "Epoch 173/200 Batch 16, Loss 11.3374\n",
      "Epoch 173/200 Batch 17, Loss 11.2561\n",
      "Epoch 173/200 Batch 18, Loss 11.3534\n",
      "Epoch 173/200 Batch 19, Loss 11.2372\n",
      "Epoch 174/200 Batch 0, Loss 11.1895\n",
      "Epoch 174/200 Batch 1, Loss 11.2327\n",
      "Epoch 174/200 Batch 2, Loss 11.4050\n",
      "Epoch 174/200 Batch 3, Loss 11.1184\n",
      "Epoch 174/200 Batch 4, Loss 11.4749\n",
      "Epoch 174/200 Batch 5, Loss 11.4531\n",
      "Epoch 174/200 Batch 6, Loss 11.4076\n",
      "Epoch 174/200 Batch 7, Loss 11.2612\n",
      "Epoch 174/200 Batch 8, Loss 11.3051\n",
      "Epoch 174/200 Batch 9, Loss 11.2200\n",
      "Epoch 174/200 Batch 10, Loss 11.2726\n",
      "Epoch 174/200 Batch 11, Loss 11.0981\n",
      "Epoch 174/200 Batch 12, Loss 11.1783\n",
      "Epoch 174/200 Batch 13, Loss 11.3304\n",
      "Epoch 174/200 Batch 14, Loss 11.3036\n",
      "Epoch 174/200 Batch 15, Loss 11.3551\n",
      "Epoch 174/200 Batch 16, Loss 11.2863\n",
      "Epoch 174/200 Batch 17, Loss 11.2336\n",
      "Epoch 174/200 Batch 18, Loss 11.5223\n",
      "Epoch 174/200 Batch 19, Loss 11.4529\n",
      "Epoch 175/200 Batch 0, Loss 11.1883\n",
      "Epoch 175/200 Batch 1, Loss 11.3082\n",
      "Epoch 175/200 Batch 2, Loss 11.3251\n",
      "Epoch 175/200 Batch 3, Loss 11.3221\n",
      "Epoch 175/200 Batch 4, Loss 11.0664\n",
      "Epoch 175/200 Batch 5, Loss 11.3655\n",
      "Epoch 175/200 Batch 6, Loss 11.3099\n",
      "Epoch 175/200 Batch 7, Loss 11.3338\n",
      "Epoch 175/200 Batch 8, Loss 11.2374\n",
      "Epoch 175/200 Batch 9, Loss 11.3628\n",
      "Epoch 175/200 Batch 10, Loss 11.2290\n",
      "Epoch 175/200 Batch 11, Loss 11.2883\n",
      "Epoch 175/200 Batch 12, Loss 11.4172\n",
      "Epoch 175/200 Batch 13, Loss 11.2679\n",
      "Epoch 175/200 Batch 14, Loss 11.3116\n",
      "Epoch 175/200 Batch 15, Loss 11.4362\n",
      "Epoch 175/200 Batch 16, Loss 11.6188\n",
      "Epoch 175/200 Batch 17, Loss 11.5238\n",
      "Epoch 175/200 Batch 18, Loss 11.3275\n",
      "Epoch 175/200 Batch 19, Loss 11.3012\n",
      "Epoch 176/200 Batch 0, Loss 11.3554\n",
      "Epoch 176/200 Batch 1, Loss 11.3211\n",
      "Epoch 176/200 Batch 2, Loss 11.1733\n",
      "Epoch 176/200 Batch 3, Loss 11.3345\n",
      "Epoch 176/200 Batch 4, Loss 11.4063\n",
      "Epoch 176/200 Batch 5, Loss 11.2450\n",
      "Epoch 176/200 Batch 6, Loss 11.2512\n",
      "Epoch 176/200 Batch 7, Loss 11.4522\n",
      "Epoch 176/200 Batch 8, Loss 11.2157\n",
      "Epoch 176/200 Batch 9, Loss 11.3944\n",
      "Epoch 176/200 Batch 10, Loss 11.3103\n",
      "Epoch 176/200 Batch 11, Loss 11.2399\n",
      "Epoch 176/200 Batch 12, Loss 11.4297\n",
      "Epoch 176/200 Batch 13, Loss 11.1568\n",
      "Epoch 176/200 Batch 14, Loss 11.4199\n",
      "Epoch 176/200 Batch 15, Loss 11.3634\n",
      "Epoch 176/200 Batch 16, Loss 11.4604\n",
      "Epoch 176/200 Batch 17, Loss 11.3669\n",
      "Epoch 176/200 Batch 18, Loss 11.4478\n",
      "Epoch 176/200 Batch 19, Loss 11.3167\n",
      "Epoch 177/200 Batch 0, Loss 11.3636\n",
      "Epoch 177/200 Batch 1, Loss 11.3970\n",
      "Epoch 177/200 Batch 2, Loss 11.1839\n",
      "Epoch 177/200 Batch 3, Loss 11.3888\n",
      "Epoch 177/200 Batch 4, Loss 11.4206\n",
      "Epoch 177/200 Batch 5, Loss 11.2487\n",
      "Epoch 177/200 Batch 6, Loss 11.3403\n",
      "Epoch 177/200 Batch 7, Loss 11.5096\n",
      "Epoch 177/200 Batch 8, Loss 11.2502\n",
      "Epoch 177/200 Batch 9, Loss 11.3926\n",
      "Epoch 177/200 Batch 10, Loss 11.3194\n",
      "Epoch 177/200 Batch 11, Loss 11.2255\n",
      "Epoch 177/200 Batch 12, Loss 11.3492\n",
      "Epoch 177/200 Batch 13, Loss 11.3513\n",
      "Epoch 177/200 Batch 14, Loss 11.2110\n",
      "Epoch 177/200 Batch 15, Loss 11.1991\n",
      "Epoch 177/200 Batch 16, Loss 11.2792\n",
      "Epoch 177/200 Batch 17, Loss 11.3198\n",
      "Epoch 177/200 Batch 18, Loss 11.2587\n",
      "Epoch 177/200 Batch 19, Loss 11.3576\n",
      "Epoch 178/200 Batch 0, Loss 11.4273\n",
      "Epoch 178/200 Batch 1, Loss 11.3056\n",
      "Epoch 178/200 Batch 2, Loss 11.3035\n",
      "Epoch 178/200 Batch 3, Loss 11.2158\n",
      "Epoch 178/200 Batch 4, Loss 11.1801\n",
      "Epoch 178/200 Batch 5, Loss 11.1910\n",
      "Epoch 178/200 Batch 6, Loss 11.1568\n",
      "Epoch 178/200 Batch 7, Loss 11.1443\n",
      "Epoch 178/200 Batch 8, Loss 11.4843\n",
      "Epoch 178/200 Batch 9, Loss 11.5931\n",
      "Epoch 178/200 Batch 10, Loss 11.3997\n",
      "Epoch 178/200 Batch 11, Loss 11.3467\n",
      "Epoch 178/200 Batch 12, Loss 11.3896\n",
      "Epoch 178/200 Batch 13, Loss 11.3857\n",
      "Epoch 178/200 Batch 14, Loss 11.2544\n",
      "Epoch 178/200 Batch 15, Loss 11.3847\n",
      "Epoch 178/200 Batch 16, Loss 11.3238\n",
      "Epoch 178/200 Batch 17, Loss 11.3027\n",
      "Epoch 178/200 Batch 18, Loss 11.3503\n",
      "Epoch 178/200 Batch 19, Loss 11.4664\n",
      "Epoch 179/200 Batch 0, Loss 11.2919\n",
      "Epoch 179/200 Batch 1, Loss 11.3278\n",
      "Epoch 179/200 Batch 2, Loss 11.2320\n",
      "Epoch 179/200 Batch 3, Loss 11.1871\n",
      "Epoch 179/200 Batch 4, Loss 11.2491\n",
      "Epoch 179/200 Batch 5, Loss 11.3283\n",
      "Epoch 179/200 Batch 6, Loss 11.3158\n",
      "Epoch 179/200 Batch 7, Loss 11.2056\n",
      "Epoch 179/200 Batch 8, Loss 11.2540\n",
      "Epoch 179/200 Batch 9, Loss 11.2963\n",
      "Epoch 179/200 Batch 10, Loss 11.4354\n",
      "Epoch 179/200 Batch 11, Loss 11.4901\n",
      "Epoch 179/200 Batch 12, Loss 11.3945\n",
      "Epoch 179/200 Batch 13, Loss 11.3622\n",
      "Epoch 179/200 Batch 14, Loss 11.2994\n",
      "Epoch 179/200 Batch 15, Loss 11.1973\n",
      "Epoch 179/200 Batch 16, Loss 11.3686\n",
      "Epoch 179/200 Batch 17, Loss 11.2364\n",
      "Epoch 179/200 Batch 18, Loss 11.4942\n",
      "Epoch 179/200 Batch 19, Loss 11.3937\n",
      "Epoch 180/200 Batch 0, Loss 11.5250\n",
      "Epoch 180/200 Batch 1, Loss 11.4609\n",
      "Epoch 180/200 Batch 2, Loss 11.3209\n",
      "Epoch 180/200 Batch 3, Loss 11.3791\n",
      "Epoch 180/200 Batch 4, Loss 11.1216\n",
      "Epoch 180/200 Batch 5, Loss 11.2687\n",
      "Epoch 180/200 Batch 6, Loss 11.3242\n",
      "Epoch 180/200 Batch 7, Loss 11.4060\n",
      "Epoch 180/200 Batch 8, Loss 11.1040\n",
      "Epoch 180/200 Batch 9, Loss 11.3596\n",
      "Epoch 180/200 Batch 10, Loss 11.4201\n",
      "Epoch 180/200 Batch 11, Loss 11.3667\n",
      "Epoch 180/200 Batch 12, Loss 11.2085\n",
      "Epoch 180/200 Batch 13, Loss 11.3222\n",
      "Epoch 180/200 Batch 14, Loss 11.3770\n",
      "Epoch 180/200 Batch 15, Loss 11.2816\n",
      "Epoch 180/200 Batch 16, Loss 11.3524\n",
      "Epoch 180/200 Batch 17, Loss 11.2371\n",
      "Epoch 180/200 Batch 18, Loss 11.3956\n",
      "Epoch 180/200 Batch 19, Loss 11.3150\n",
      "Epoch 181/200 Batch 0, Loss 11.3156\n",
      "Epoch 181/200 Batch 1, Loss 11.4911\n",
      "Epoch 181/200 Batch 2, Loss 11.4296\n",
      "Epoch 181/200 Batch 3, Loss 11.3364\n",
      "Epoch 181/200 Batch 4, Loss 11.2514\n",
      "Epoch 181/200 Batch 5, Loss 11.3581\n",
      "Epoch 181/200 Batch 6, Loss 11.1857\n",
      "Epoch 181/200 Batch 7, Loss 11.2634\n",
      "Epoch 181/200 Batch 8, Loss 11.3266\n",
      "Epoch 181/200 Batch 9, Loss 11.1103\n",
      "Epoch 181/200 Batch 10, Loss 11.2644\n",
      "Epoch 181/200 Batch 11, Loss 11.3356\n",
      "Epoch 181/200 Batch 12, Loss 11.2247\n",
      "Epoch 181/200 Batch 13, Loss 11.3913\n",
      "Epoch 181/200 Batch 14, Loss 11.4405\n",
      "Epoch 181/200 Batch 15, Loss 11.3297\n",
      "Epoch 181/200 Batch 16, Loss 11.2990\n",
      "Epoch 181/200 Batch 17, Loss 11.4272\n",
      "Epoch 181/200 Batch 18, Loss 11.5601\n",
      "Epoch 181/200 Batch 19, Loss 11.4399\n",
      "Epoch 182/200 Batch 0, Loss 11.4477\n",
      "Epoch 182/200 Batch 1, Loss 11.3366\n",
      "Epoch 182/200 Batch 2, Loss 11.1955\n",
      "Epoch 182/200 Batch 3, Loss 11.4170\n",
      "Epoch 182/200 Batch 4, Loss 11.4293\n",
      "Epoch 182/200 Batch 5, Loss 11.3515\n",
      "Epoch 182/200 Batch 6, Loss 11.3094\n",
      "Epoch 182/200 Batch 7, Loss 11.1941\n",
      "Epoch 182/200 Batch 8, Loss 11.4880\n",
      "Epoch 182/200 Batch 9, Loss 11.2258\n",
      "Epoch 182/200 Batch 10, Loss 11.2957\n",
      "Epoch 182/200 Batch 11, Loss 11.2786\n",
      "Epoch 182/200 Batch 12, Loss 11.3144\n",
      "Epoch 182/200 Batch 13, Loss 11.3699\n",
      "Epoch 182/200 Batch 14, Loss 11.2991\n",
      "Epoch 182/200 Batch 15, Loss 11.4133\n",
      "Epoch 182/200 Batch 16, Loss 11.3722\n",
      "Epoch 182/200 Batch 17, Loss 11.2344\n",
      "Epoch 182/200 Batch 18, Loss 11.2272\n",
      "Epoch 182/200 Batch 19, Loss 10.9416\n",
      "Epoch 183/200 Batch 0, Loss 11.2234\n",
      "Epoch 183/200 Batch 1, Loss 11.1799\n",
      "Epoch 183/200 Batch 2, Loss 11.2699\n",
      "Epoch 183/200 Batch 3, Loss 11.3234\n",
      "Epoch 183/200 Batch 4, Loss 11.3702\n",
      "Epoch 183/200 Batch 5, Loss 11.3219\n",
      "Epoch 183/200 Batch 6, Loss 11.4610\n",
      "Epoch 183/200 Batch 7, Loss 11.3781\n",
      "Epoch 183/200 Batch 8, Loss 11.3847\n",
      "Epoch 183/200 Batch 9, Loss 11.2529\n",
      "Epoch 183/200 Batch 10, Loss 11.2720\n",
      "Epoch 183/200 Batch 11, Loss 11.1987\n",
      "Epoch 183/200 Batch 12, Loss 11.3576\n",
      "Epoch 183/200 Batch 13, Loss 11.3294\n",
      "Epoch 183/200 Batch 14, Loss 11.2815\n",
      "Epoch 183/200 Batch 15, Loss 11.3522\n",
      "Epoch 183/200 Batch 16, Loss 11.3754\n",
      "Epoch 183/200 Batch 17, Loss 11.2048\n",
      "Epoch 183/200 Batch 18, Loss 11.2567\n",
      "Epoch 183/200 Batch 19, Loss 11.1708\n",
      "Epoch 184/200 Batch 0, Loss 11.3517\n",
      "Epoch 184/200 Batch 1, Loss 11.3827\n",
      "Epoch 184/200 Batch 2, Loss 11.2697\n",
      "Epoch 184/200 Batch 3, Loss 11.1623\n",
      "Epoch 184/200 Batch 4, Loss 11.4431\n",
      "Epoch 184/200 Batch 5, Loss 11.2043\n",
      "Epoch 184/200 Batch 6, Loss 11.4805\n",
      "Epoch 184/200 Batch 7, Loss 11.3126\n",
      "Epoch 184/200 Batch 8, Loss 11.3949\n",
      "Epoch 184/200 Batch 9, Loss 11.3341\n",
      "Epoch 184/200 Batch 10, Loss 11.1908\n",
      "Epoch 184/200 Batch 11, Loss 11.3320\n",
      "Epoch 184/200 Batch 12, Loss 11.3461\n",
      "Epoch 184/200 Batch 13, Loss 11.3136\n",
      "Epoch 184/200 Batch 14, Loss 11.1064\n",
      "Epoch 184/200 Batch 15, Loss 11.3047\n",
      "Epoch 184/200 Batch 16, Loss 11.4163\n",
      "Epoch 184/200 Batch 17, Loss 11.2875\n",
      "Epoch 184/200 Batch 18, Loss 11.3397\n",
      "Epoch 184/200 Batch 19, Loss 11.3319\n",
      "Epoch 185/200 Batch 0, Loss 11.6444\n",
      "Epoch 185/200 Batch 1, Loss 11.2749\n",
      "Epoch 185/200 Batch 2, Loss 11.2633\n",
      "Epoch 185/200 Batch 3, Loss 11.1251\n",
      "Epoch 185/200 Batch 4, Loss 11.3187\n",
      "Epoch 185/200 Batch 5, Loss 11.3875\n",
      "Epoch 185/200 Batch 6, Loss 11.2010\n",
      "Epoch 185/200 Batch 7, Loss 11.3760\n",
      "Epoch 185/200 Batch 8, Loss 11.2600\n",
      "Epoch 185/200 Batch 9, Loss 11.2732\n",
      "Epoch 185/200 Batch 10, Loss 11.3637\n",
      "Epoch 185/200 Batch 11, Loss 11.2247\n",
      "Epoch 185/200 Batch 12, Loss 11.3768\n",
      "Epoch 185/200 Batch 13, Loss 11.3704\n",
      "Epoch 185/200 Batch 14, Loss 11.3636\n",
      "Epoch 185/200 Batch 15, Loss 11.2269\n",
      "Epoch 185/200 Batch 16, Loss 11.1741\n",
      "Epoch 185/200 Batch 17, Loss 11.2243\n",
      "Epoch 185/200 Batch 18, Loss 11.3674\n",
      "Epoch 185/200 Batch 19, Loss 11.4757\n",
      "Epoch 186/200 Batch 0, Loss 11.1953\n",
      "Epoch 186/200 Batch 1, Loss 11.3586\n",
      "Epoch 186/200 Batch 2, Loss 11.3481\n",
      "Epoch 186/200 Batch 3, Loss 11.2556\n",
      "Epoch 186/200 Batch 4, Loss 11.2761\n",
      "Epoch 186/200 Batch 5, Loss 11.3349\n",
      "Epoch 186/200 Batch 6, Loss 11.3281\n",
      "Epoch 186/200 Batch 7, Loss 11.3310\n",
      "Epoch 186/200 Batch 8, Loss 11.3548\n",
      "Epoch 186/200 Batch 9, Loss 11.2380\n",
      "Epoch 186/200 Batch 10, Loss 11.5195\n",
      "Epoch 186/200 Batch 11, Loss 11.2636\n",
      "Epoch 186/200 Batch 12, Loss 11.2452\n",
      "Epoch 186/200 Batch 13, Loss 11.3415\n",
      "Epoch 186/200 Batch 14, Loss 11.3861\n",
      "Epoch 186/200 Batch 15, Loss 11.3308\n",
      "Epoch 186/200 Batch 16, Loss 11.3380\n",
      "Epoch 186/200 Batch 17, Loss 11.3570\n",
      "Epoch 186/200 Batch 18, Loss 11.2403\n",
      "Epoch 186/200 Batch 19, Loss 11.3993\n",
      "Epoch 187/200 Batch 0, Loss 11.2706\n",
      "Epoch 187/200 Batch 1, Loss 11.4594\n",
      "Epoch 187/200 Batch 2, Loss 11.2575\n",
      "Epoch 187/200 Batch 3, Loss 11.2286\n",
      "Epoch 187/200 Batch 4, Loss 11.2536\n",
      "Epoch 187/200 Batch 5, Loss 11.2528\n",
      "Epoch 187/200 Batch 6, Loss 11.2105\n",
      "Epoch 187/200 Batch 7, Loss 11.3727\n",
      "Epoch 187/200 Batch 8, Loss 11.2077\n",
      "Epoch 187/200 Batch 9, Loss 11.2249\n",
      "Epoch 187/200 Batch 10, Loss 11.6050\n",
      "Epoch 187/200 Batch 11, Loss 11.3003\n",
      "Epoch 187/200 Batch 12, Loss 11.2784\n",
      "Epoch 187/200 Batch 13, Loss 11.3361\n",
      "Epoch 187/200 Batch 14, Loss 11.2908\n",
      "Epoch 187/200 Batch 15, Loss 11.4210\n",
      "Epoch 187/200 Batch 16, Loss 11.2101\n",
      "Epoch 187/200 Batch 17, Loss 11.4313\n",
      "Epoch 187/200 Batch 18, Loss 11.2625\n",
      "Epoch 187/200 Batch 19, Loss 11.4897\n",
      "Epoch 188/200 Batch 0, Loss 11.2231\n",
      "Epoch 188/200 Batch 1, Loss 11.0963\n",
      "Epoch 188/200 Batch 2, Loss 11.2000\n",
      "Epoch 188/200 Batch 3, Loss 11.3440\n",
      "Epoch 188/200 Batch 4, Loss 11.1484\n",
      "Epoch 188/200 Batch 5, Loss 11.5342\n",
      "Epoch 188/200 Batch 6, Loss 11.4154\n",
      "Epoch 188/200 Batch 7, Loss 11.3689\n",
      "Epoch 188/200 Batch 8, Loss 11.1582\n",
      "Epoch 188/200 Batch 9, Loss 11.3322\n",
      "Epoch 188/200 Batch 10, Loss 11.1981\n",
      "Epoch 188/200 Batch 11, Loss 11.4349\n",
      "Epoch 188/200 Batch 12, Loss 11.3894\n",
      "Epoch 188/200 Batch 13, Loss 11.3500\n",
      "Epoch 188/200 Batch 14, Loss 11.3835\n",
      "Epoch 188/200 Batch 15, Loss 11.3055\n",
      "Epoch 188/200 Batch 16, Loss 11.5980\n",
      "Epoch 188/200 Batch 17, Loss 11.3486\n",
      "Epoch 188/200 Batch 18, Loss 11.3517\n",
      "Epoch 188/200 Batch 19, Loss 11.2093\n",
      "Epoch 189/200 Batch 0, Loss 11.3686\n",
      "Epoch 189/200 Batch 1, Loss 11.2901\n",
      "Epoch 189/200 Batch 2, Loss 11.3609\n",
      "Epoch 189/200 Batch 3, Loss 11.3686\n",
      "Epoch 189/200 Batch 4, Loss 11.5245\n",
      "Epoch 189/200 Batch 5, Loss 11.3523\n",
      "Epoch 189/200 Batch 6, Loss 11.2582\n",
      "Epoch 189/200 Batch 7, Loss 11.2859\n",
      "Epoch 189/200 Batch 8, Loss 11.1407\n",
      "Epoch 189/200 Batch 9, Loss 11.3936\n",
      "Epoch 189/200 Batch 10, Loss 11.2780\n",
      "Epoch 189/200 Batch 11, Loss 11.3811\n",
      "Epoch 189/200 Batch 12, Loss 11.1493\n",
      "Epoch 189/200 Batch 13, Loss 11.2173\n",
      "Epoch 189/200 Batch 14, Loss 11.3681\n",
      "Epoch 189/200 Batch 15, Loss 11.3534\n",
      "Epoch 189/200 Batch 16, Loss 11.3775\n",
      "Epoch 189/200 Batch 17, Loss 11.3308\n",
      "Epoch 189/200 Batch 18, Loss 11.2454\n",
      "Epoch 189/200 Batch 19, Loss 11.3060\n",
      "Epoch 190/200 Batch 0, Loss 11.4917\n",
      "Epoch 190/200 Batch 1, Loss 11.4726\n",
      "Epoch 190/200 Batch 2, Loss 11.3907\n",
      "Epoch 190/200 Batch 3, Loss 11.3883\n",
      "Epoch 190/200 Batch 4, Loss 11.2286\n",
      "Epoch 190/200 Batch 5, Loss 11.0825\n",
      "Epoch 190/200 Batch 6, Loss 11.3597\n",
      "Epoch 190/200 Batch 7, Loss 11.2643\n",
      "Epoch 190/200 Batch 8, Loss 11.3343\n",
      "Epoch 190/200 Batch 9, Loss 11.3876\n",
      "Epoch 190/200 Batch 10, Loss 11.3971\n",
      "Epoch 190/200 Batch 11, Loss 11.3786\n",
      "Epoch 190/200 Batch 12, Loss 11.3295\n",
      "Epoch 190/200 Batch 13, Loss 11.3275\n",
      "Epoch 190/200 Batch 14, Loss 11.3505\n",
      "Epoch 190/200 Batch 15, Loss 11.2053\n",
      "Epoch 190/200 Batch 16, Loss 11.3355\n",
      "Epoch 190/200 Batch 17, Loss 11.1179\n",
      "Epoch 190/200 Batch 18, Loss 11.3100\n",
      "Epoch 190/200 Batch 19, Loss 11.2535\n",
      "Epoch 191/200 Batch 0, Loss 11.4195\n",
      "Epoch 191/200 Batch 1, Loss 11.2569\n",
      "Epoch 191/200 Batch 2, Loss 11.3173\n",
      "Epoch 191/200 Batch 3, Loss 11.2886\n",
      "Epoch 191/200 Batch 4, Loss 11.1369\n",
      "Epoch 191/200 Batch 5, Loss 11.2354\n",
      "Epoch 191/200 Batch 6, Loss 11.3838\n",
      "Epoch 191/200 Batch 7, Loss 11.3015\n",
      "Epoch 191/200 Batch 8, Loss 11.2410\n",
      "Epoch 191/200 Batch 9, Loss 11.2484\n",
      "Epoch 191/200 Batch 10, Loss 11.5847\n",
      "Epoch 191/200 Batch 11, Loss 11.3529\n",
      "Epoch 191/200 Batch 12, Loss 11.1946\n",
      "Epoch 191/200 Batch 13, Loss 11.4081\n",
      "Epoch 191/200 Batch 14, Loss 11.2162\n",
      "Epoch 191/200 Batch 15, Loss 11.3527\n",
      "Epoch 191/200 Batch 16, Loss 11.2763\n",
      "Epoch 191/200 Batch 17, Loss 11.2540\n",
      "Epoch 191/200 Batch 18, Loss 11.4231\n",
      "Epoch 191/200 Batch 19, Loss 11.3155\n",
      "Epoch 192/200 Batch 0, Loss 11.2188\n",
      "Epoch 192/200 Batch 1, Loss 11.3461\n",
      "Epoch 192/200 Batch 2, Loss 11.3052\n",
      "Epoch 192/200 Batch 3, Loss 11.2922\n",
      "Epoch 192/200 Batch 4, Loss 11.2943\n",
      "Epoch 192/200 Batch 5, Loss 11.2248\n",
      "Epoch 192/200 Batch 6, Loss 11.5870\n",
      "Epoch 192/200 Batch 7, Loss 11.2395\n",
      "Epoch 192/200 Batch 8, Loss 11.3076\n",
      "Epoch 192/200 Batch 9, Loss 11.4251\n",
      "Epoch 192/200 Batch 10, Loss 11.3590\n",
      "Epoch 192/200 Batch 11, Loss 11.2127\n",
      "Epoch 192/200 Batch 12, Loss 11.1849\n",
      "Epoch 192/200 Batch 13, Loss 11.4227\n",
      "Epoch 192/200 Batch 14, Loss 11.4124\n",
      "Epoch 192/200 Batch 15, Loss 11.4313\n",
      "Epoch 192/200 Batch 16, Loss 11.2383\n",
      "Epoch 192/200 Batch 17, Loss 11.1968\n",
      "Epoch 192/200 Batch 18, Loss 11.3933\n",
      "Epoch 192/200 Batch 19, Loss 11.2661\n",
      "Epoch 193/200 Batch 0, Loss 11.3464\n",
      "Epoch 193/200 Batch 1, Loss 11.3347\n",
      "Epoch 193/200 Batch 2, Loss 11.3092\n",
      "Epoch 193/200 Batch 3, Loss 11.2389\n",
      "Epoch 193/200 Batch 4, Loss 11.3596\n",
      "Epoch 193/200 Batch 5, Loss 11.4418\n",
      "Epoch 193/200 Batch 6, Loss 11.1735\n",
      "Epoch 193/200 Batch 7, Loss 11.2726\n",
      "Epoch 193/200 Batch 8, Loss 11.3121\n",
      "Epoch 193/200 Batch 9, Loss 11.3309\n",
      "Epoch 193/200 Batch 10, Loss 11.3506\n",
      "Epoch 193/200 Batch 11, Loss 11.0319\n",
      "Epoch 193/200 Batch 12, Loss 11.3985\n",
      "Epoch 193/200 Batch 13, Loss 11.3456\n",
      "Epoch 193/200 Batch 14, Loss 11.3853\n",
      "Epoch 193/200 Batch 15, Loss 11.4532\n",
      "Epoch 193/200 Batch 16, Loss 11.1589\n",
      "Epoch 193/200 Batch 17, Loss 11.4768\n",
      "Epoch 193/200 Batch 18, Loss 11.2077\n",
      "Epoch 193/200 Batch 19, Loss 11.4927\n",
      "Epoch 194/200 Batch 0, Loss 11.3567\n",
      "Epoch 194/200 Batch 1, Loss 11.0986\n",
      "Epoch 194/200 Batch 2, Loss 11.4686\n",
      "Epoch 194/200 Batch 3, Loss 11.2919\n",
      "Epoch 194/200 Batch 4, Loss 11.4261\n",
      "Epoch 194/200 Batch 5, Loss 11.2420\n",
      "Epoch 194/200 Batch 6, Loss 11.1778\n",
      "Epoch 194/200 Batch 7, Loss 11.2416\n",
      "Epoch 194/200 Batch 8, Loss 11.3627\n",
      "Epoch 194/200 Batch 9, Loss 11.2799\n",
      "Epoch 194/200 Batch 10, Loss 11.1322\n",
      "Epoch 194/200 Batch 11, Loss 11.3250\n",
      "Epoch 194/200 Batch 12, Loss 11.2807\n",
      "Epoch 194/200 Batch 13, Loss 11.4590\n",
      "Epoch 194/200 Batch 14, Loss 11.3354\n",
      "Epoch 194/200 Batch 15, Loss 11.3856\n",
      "Epoch 194/200 Batch 16, Loss 11.4374\n",
      "Epoch 194/200 Batch 17, Loss 11.4032\n",
      "Epoch 194/200 Batch 18, Loss 11.4223\n",
      "Epoch 194/200 Batch 19, Loss 11.3956\n",
      "Epoch 195/200 Batch 0, Loss 11.3580\n",
      "Epoch 195/200 Batch 1, Loss 11.3489\n",
      "Epoch 195/200 Batch 2, Loss 11.2049\n",
      "Epoch 195/200 Batch 3, Loss 11.1837\n",
      "Epoch 195/200 Batch 4, Loss 11.2104\n",
      "Epoch 195/200 Batch 5, Loss 11.3038\n",
      "Epoch 195/200 Batch 6, Loss 11.3439\n",
      "Epoch 195/200 Batch 7, Loss 11.3442\n",
      "Epoch 195/200 Batch 8, Loss 11.2079\n",
      "Epoch 195/200 Batch 9, Loss 11.0874\n",
      "Epoch 195/200 Batch 10, Loss 11.1736\n",
      "Epoch 195/200 Batch 11, Loss 11.5465\n",
      "Epoch 195/200 Batch 12, Loss 11.3121\n",
      "Epoch 195/200 Batch 13, Loss 11.4004\n",
      "Epoch 195/200 Batch 14, Loss 11.3923\n",
      "Epoch 195/200 Batch 15, Loss 11.3218\n",
      "Epoch 195/200 Batch 16, Loss 11.3868\n",
      "Epoch 195/200 Batch 17, Loss 11.2831\n",
      "Epoch 195/200 Batch 18, Loss 11.3793\n",
      "Epoch 195/200 Batch 19, Loss 11.2209\n",
      "Epoch 196/200 Batch 0, Loss 11.4438\n",
      "Epoch 196/200 Batch 1, Loss 11.2244\n",
      "Epoch 196/200 Batch 2, Loss 11.2202\n",
      "Epoch 196/200 Batch 3, Loss 11.4700\n",
      "Epoch 196/200 Batch 4, Loss 11.4883\n",
      "Epoch 196/200 Batch 5, Loss 11.3448\n",
      "Epoch 196/200 Batch 6, Loss 11.3834\n",
      "Epoch 196/200 Batch 7, Loss 11.3227\n",
      "Epoch 196/200 Batch 8, Loss 11.3248\n",
      "Epoch 196/200 Batch 9, Loss 11.2196\n",
      "Epoch 196/200 Batch 10, Loss 11.2885\n",
      "Epoch 196/200 Batch 11, Loss 11.3585\n",
      "Epoch 196/200 Batch 12, Loss 11.2689\n",
      "Epoch 196/200 Batch 13, Loss 11.3499\n",
      "Epoch 196/200 Batch 14, Loss 11.2583\n",
      "Epoch 196/200 Batch 15, Loss 11.2829\n",
      "Epoch 196/200 Batch 16, Loss 11.1110\n",
      "Epoch 196/200 Batch 17, Loss 11.2691\n",
      "Epoch 196/200 Batch 18, Loss 11.3070\n",
      "Epoch 196/200 Batch 19, Loss 11.5267\n",
      "Epoch 197/200 Batch 0, Loss 11.3132\n",
      "Epoch 197/200 Batch 1, Loss 11.1451\n",
      "Epoch 197/200 Batch 2, Loss 11.2294\n",
      "Epoch 197/200 Batch 3, Loss 11.1479\n",
      "Epoch 197/200 Batch 4, Loss 11.4738\n",
      "Epoch 197/200 Batch 5, Loss 11.5060\n",
      "Epoch 197/200 Batch 6, Loss 11.2170\n",
      "Epoch 197/200 Batch 7, Loss 11.2051\n",
      "Epoch 197/200 Batch 8, Loss 11.3152\n",
      "Epoch 197/200 Batch 9, Loss 11.4538\n",
      "Epoch 197/200 Batch 10, Loss 11.4282\n",
      "Epoch 197/200 Batch 11, Loss 11.3917\n",
      "Epoch 197/200 Batch 12, Loss 11.4442\n",
      "Epoch 197/200 Batch 13, Loss 11.2954\n",
      "Epoch 197/200 Batch 14, Loss 11.3774\n",
      "Epoch 197/200 Batch 15, Loss 11.1581\n",
      "Epoch 197/200 Batch 16, Loss 11.3916\n",
      "Epoch 197/200 Batch 17, Loss 11.3678\n",
      "Epoch 197/200 Batch 18, Loss 11.1973\n",
      "Epoch 197/200 Batch 19, Loss 11.2800\n",
      "Epoch 198/200 Batch 0, Loss 11.3855\n",
      "Epoch 198/200 Batch 1, Loss 11.2210\n",
      "Epoch 198/200 Batch 2, Loss 11.3473\n",
      "Epoch 198/200 Batch 3, Loss 11.1481\n",
      "Epoch 198/200 Batch 4, Loss 11.2815\n",
      "Epoch 198/200 Batch 5, Loss 11.4122\n",
      "Epoch 198/200 Batch 6, Loss 11.3330\n",
      "Epoch 198/200 Batch 7, Loss 11.3496\n",
      "Epoch 198/200 Batch 8, Loss 11.1413\n",
      "Epoch 198/200 Batch 9, Loss 11.4109\n",
      "Epoch 198/200 Batch 10, Loss 11.4309\n",
      "Epoch 198/200 Batch 11, Loss 11.3985\n",
      "Epoch 198/200 Batch 12, Loss 11.3929\n",
      "Epoch 198/200 Batch 13, Loss 11.2995\n",
      "Epoch 198/200 Batch 14, Loss 11.1997\n",
      "Epoch 198/200 Batch 15, Loss 11.2922\n",
      "Epoch 198/200 Batch 16, Loss 11.4572\n",
      "Epoch 198/200 Batch 17, Loss 11.1730\n",
      "Epoch 198/200 Batch 18, Loss 11.2058\n",
      "Epoch 198/200 Batch 19, Loss 11.3846\n",
      "Epoch 199/200 Batch 0, Loss 11.3461\n",
      "Epoch 199/200 Batch 1, Loss 11.4719\n",
      "Epoch 199/200 Batch 2, Loss 11.3662\n",
      "Epoch 199/200 Batch 3, Loss 11.5759\n",
      "Epoch 199/200 Batch 4, Loss 11.4234\n",
      "Epoch 199/200 Batch 5, Loss 11.0935\n",
      "Epoch 199/200 Batch 6, Loss 11.0641\n",
      "Epoch 199/200 Batch 7, Loss 11.3527\n",
      "Epoch 199/200 Batch 8, Loss 11.2677\n",
      "Epoch 199/200 Batch 9, Loss 11.3581\n",
      "Epoch 199/200 Batch 10, Loss 11.3167\n",
      "Epoch 199/200 Batch 11, Loss 11.3820\n",
      "Epoch 199/200 Batch 12, Loss 11.2884\n",
      "Epoch 199/200 Batch 13, Loss 11.2989\n",
      "Epoch 199/200 Batch 14, Loss 11.3669\n",
      "Epoch 199/200 Batch 15, Loss 11.2303\n",
      "Epoch 199/200 Batch 16, Loss 11.3860\n",
      "Epoch 199/200 Batch 17, Loss 11.3046\n",
      "Epoch 199/200 Batch 18, Loss 11.0292\n",
      "Epoch 199/200 Batch 19, Loss 11.4667\n",
      "Epoch 200/200 Batch 0, Loss 11.3097\n",
      "Epoch 200/200 Batch 1, Loss 11.1729\n",
      "Epoch 200/200 Batch 2, Loss 11.1407\n",
      "Epoch 200/200 Batch 3, Loss 11.3161\n",
      "Epoch 200/200 Batch 4, Loss 11.3825\n",
      "Epoch 200/200 Batch 5, Loss 11.4190\n",
      "Epoch 200/200 Batch 6, Loss 11.2418\n",
      "Epoch 200/200 Batch 7, Loss 11.3653\n",
      "Epoch 200/200 Batch 8, Loss 11.2447\n",
      "Epoch 200/200 Batch 9, Loss 11.3396\n",
      "Epoch 200/200 Batch 10, Loss 11.5204\n",
      "Epoch 200/200 Batch 11, Loss 11.5400\n",
      "Epoch 200/200 Batch 12, Loss 11.2620\n",
      "Epoch 200/200 Batch 13, Loss 11.4534\n",
      "Epoch 200/200 Batch 14, Loss 11.4109\n",
      "Epoch 200/200 Batch 15, Loss 11.2191\n",
      "Epoch 200/200 Batch 16, Loss 11.2899\n",
      "Epoch 200/200 Batch 17, Loss 11.3387\n",
      "Epoch 200/200 Batch 18, Loss 11.2559\n",
      "Epoch 200/200 Batch 19, Loss 11.3609\n"
     ]
    }
   ],
   "source": [
    "model.train(training_data, intervention_sets, batch_size=512)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ca3d29e1",
   "metadata": {},
   "source": [
    "Plot the ground truth and learned adjacencies as well as the SHD and AUPRC score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "968f98f4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SHD between true and estimated graph: 1.0\n",
      "AUPRC between true and estimated graph: 0.9999999999999999\n"
     ]
    },
    {
     "data": {
      "image/png": "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88lPfrIYRnzxxRcX2yECXoTCCOkR/KKORoCLc4H999+/2GYhfn7U2hj2HMOpY8pODHc+8sgjizodcy8jhF5zzTVFb2QMf44h1bVDlSNcRi9lzN0966yzijAb5w7HHXdc+va3v902ZPrVV18thm7H7776uri4EMGuO+dBcU4SobB6gWJTz8FipFjMLz3jjDOK/8b3j1Ae2yQuftR644030kc/+tHiPCW2VXy+2B7xuz3llFPavTZ+B01NTcW2XrVqVXGBJM6XfvzjH/eo3WRSgQYxY8aMSsdd+tBDDy2eu/baa9d5fTx/3nnnrfP8TjvtVDn55JPbvp4zZ05lq622qixZsqTd684666zKwIEDK0uXLu2yTV/72teKn3PnnXe2e/43v/lNZcWKFe0era2t7drW1NRU+dnPfrbO93z77bfbff3OO+9UJk2aVPnIRz6yzueLx6JFi9qee+mllypDhw6tHH/88W3PxTaI151yyint3h+vGTVqVJefDYDy+N73vlfUpHgceOCBlS984QuV++67r6gRtU4//fTimP/UU09t8HuuXLmyeO2xxx673td97GMfK17X0tLSrq5EbevMHnvsUdTnznzzm98s3vuDH/yg0l1Rs6s1r+PjyCOPbHvdXnvtVZk6dWqPzyW6Om+ofs4///M/b1ffx44dWxkwYEDl4osvbnv+jTfeqAwbNqzd+UW8ds2aNe1+Rrxu++23b1eTYzt2dc5y2GGHVSZPnlz53//937bn4nzioIMOquy6665tz82ePbv4Hj/+8Y/bnlu+fHmlubm5eP5Xv/pVl9vk6aefLl4T36OjX//61+3OZWo/z/rOwTqey4TPfvazlS233LLdZ6l+j8suu6ztufgZe++9d2X06NFt+3fsL/G63XbbrV0bqudhzzzzTJefj/oxNJeGFz2BMcx0Y33zm98srgRvvfXWxdXW6uPwww8vhpB0NdQ1VFfDjat9HVc2jKuctY+4algremF33333db5n7dXLuEoYV/yifXFFt6MDDzywGPJTFb25MUzovvvuW2f4y1/8xV+0+zq+Z7TJir4A5Rc9etEjGiNmnn766aInKHrWoqesdphm9Zje2fDKjqKHrjuvrf57PetFDMOMnsyOj+ghq4phy9GD+Itf/GKz/uzaxZZi9FMMjY3cGgs71f7smCZTu7JsvDZ69apDSv/7v/+7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6/zzz293e47evn1LbR274IILKlOmTCnqb9xKJdpz4YUXtqvjsV1im0Wtjluw1NbWrm7f0rF+RnviM3fU8ZwkbrNy0UUXFdu9WqPvueee4v3xXK1HH320su+++xa/147t+OUvf1n5kz/5k+J3Er+b9773vZWjjz668q1vfWud32G0IW7jFq+J29PFOUVPan3sG/Gzxo8fX7QlPueee+5Z+au/+qviHGp9n7fWj370o2LfiN/DmDFj2m431PF3X/0ecSu6uC1RtD22zVVXXdXu+1Vv3xL7T634XPF8nNNQPgPif+odhoHNL64wzpgxo7iCCQDQ10QPdvS6d7ZQEn2fOaIAAABkJYgCAACQlSAKAABAVuaIAgAAkJUeUQAAALISRAEAAMhqUN4fl1Jra2t65ZVX0vDhw4vbSwDQf8Qdw1avXl3coLypybXQRqXWA/RflW7W+uxBNELouHHjcv9YAEpk2bJlaezYsfVuBr1ErQdg2QZqffYgGj2hYdnSpWnEiBGpdEaOTKW0cmW9WwD1Vda/zTIr4XGjpaUljRs/vq0W0JhKXevLfCwp4d8sZFPmv82yWlnOY0Z3a332IFodjhuFqXTFqcxsK6CBjhumZjQ2tb7x/maBEhpR7mPGhmq9CToAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAADlD6JXX3112nnnndPQoUPTAQcckB5//PHN3zIAoG7UegBKFURvv/32dMYZZ6TzzjsvLV68OO21117pyCOPTMuXL++dFgIAWan1AJQuiF5++eXpM5/5TJo+fXrafffd07XXXpu23HLL9A//8A+900IAICu1HoBSBdF33nknPfnkk+nwww//v2/Q1FR8/dhjj/VG+wCAjNR6AHIY1JMXv/7662nt2rVp++23b/d8fP3cc891+p41a9YUj6qWlpaNbSsA0MvUegAaYtXcuXPnpubm5rbHuHHjevtHAgAZqfUA9GoQ3XbbbdPAgQPTa6+91u75+HqHHXbo9D1nn312WrVqVdtj2bJlPW4kAJCHWg9A6YLo4MGD07777pseeOCBtudaW1uLrw888MBO3zNkyJA0YsSIdg8AoJzUegBKN0c0xK1bTj755LTffvulKVOmpCuuuCK99dZbxSq6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BQCbLC5GNo8cmVatWlXOGkDj1/qy1vmg1gP9qNb36Gi84447pt13373dc7vttltaunRpl+85++yzi0ZUH8uWLevJjwQAMlLrASjdYkWxYu7zzz/f7rklS5aknXbaqcv3DBkypHgAAOWn1gOQQ496RE8//fS0cOHCdNFFF6UXXnghzZ8/P11//fVpxowZvddCACAbtR6A0gXR/fffPy1YsCDdeuutadKkSWnOnDnpiiuuSNOmTeu9FgIA2aj1AJRusaLNNnm1ubmcCxiUeREDCxgADcBiRf1DqWt9Wet8UOuBBtArixUBAADAphJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArAbl/XF9QGtrvVsAAPQWdR6gFPSIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaDUr2MHJlKqbW13i0AgMZQxlqvzgOUgh5RAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAKG8QXbt2bTrnnHPShAkT0rBhw9Iuu+yS5syZkyqVSu+1EADIRq0HIIdBPXnxJZdckq655pp00003pT322CMtWrQoTZ8+PTU3N6fTTjut91oJAGSh1gNQuiD66KOPpmOPPTZNnTq1+HrnnXdOt956a3r88cd7q30AQEZqPQClG5p70EEHpQceeCAtWbKk+Prpp59OjzzySDrqqKN6q30AQEZqPQCl6xE966yzUktLS5o4cWIaOHBgMY/kwgsvTNOmTevyPWvWrCkeVfF+AKCc1HoAStcjescdd6RbbrklzZ8/Py1evLiYK3rppZcW/+3K3Llzizmk1ce4ceM2R7sBgF6g1gOQw4BKD5a8jRAZV0pnzJjR9twFF1yQbr755vTcc891u0c0vs+qlNKIVEKtrfVuAUDDihrQPHJkWrVqVRoxopRVoN9r+FqvzgOUotb3aGju22+/nZqa2neixhDd1vUc1IcMGVI8AIDyU+sByKFHQfSYY44p5oSOHz++uH3LU089lS6//PJ0yimn9F4LAYBs1HoASjc0d/Xq1emcc85JCxYsSMuXL09jxoxJJ554Yjr33HPT4MGDu99V29xczuE6wZAdgF5jaG75NXytV+cBSlHrexREN1vDylqcggIF0GsE0f6h1LVenQcoRa3v0aq5AAAAsKkEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALIalPfHpVSpVIr/tqSSailtywD6vJb//xhbrQU0plLXenUeoBS1PnsQXb16dfHfcamkRo6sdwsAGl7Ugubm5no3g/5Y69V5gFLU+gGVzJelW1tb0yuvvJKGDx+eBgwYsMlpe9y4cWnZsmVpxIgRm62Njcw2s83sZ+XUX/42o+REYRozZkxqajI7pFGp9fXVX44nm5NtZpvZz/LX+uw9otGYsWPHbtbvGQdZB1rbrLfZz2yzHPrDfqYntPGp9eXQH44nm5ttZpvZz/LVepejAQAAyEoQBQAAIKs+HUSHDBmSzjvvvOK/2Gb2s/Lwt2mbgeOJY3Bfom7ZZvaz/LIvVgQAAED/1qd7RAEAAOh7BFEAAACyEkQBAADIShAFAAAgqz4bRK+++uq08847p6FDh6YDDjggPf744/VuUmnNnTs37b///mn48OFp9OjR6bjjjkvPP/98vZvVp1x88cVpwIABafbs2fVuSqm9/PLL6aSTTkqjRo1Kw4YNS5MnT06LFi2qd7NKa+3atemcc85JEyZMKLbXLrvskubMmZOsIQf/R73vPvV+06j13afe94x630BB9Pbbb09nnHFGceuWxYsXp7322isdeeSRafny5fVuWik99NBDacaMGWnhwoXp/vvvT++++2464ogj0ltvvVXvpvUJTzzxRLruuuvSnnvuWe+mlNobb7yRDj744LTFFluke++9N/37v/97uuyyy9LWW29d76aV1iWXXJKuueaadNVVV6Wf//znxddf+cpX0pVXXlnvpkEpqPc9o95vPLW++9T7nlPvG+j2LdEDGj18cfIWWltb07hx49LMmTPTWWedVe/mld6KFSuKntEoWIcccki9m1Nqb775Zvqd3/md9PWvfz1dcMEFae+9905XXHFFvZtVSvG396Mf/Sj98Ic/rHdT+oyjjz46bb/99unGG29se+7jH/940Tt6880317VtUAbq/aZR77tHre8Z9b7n1PsG6RF955130pNPPpkOP/zwtueampqKrx977LG6tq2vWLVqVfHfbbbZpt5NKb3oSZ46dWq7/Y3O3X333Wm//fZLJ5xwQnGhY5999kk33HCDzbUeBx10UHrggQfSkiVLiq+ffvrp9Mgjj6SjjjrKdqPfU+83nXrfPWp9z6j3Pafed25Q6mNef/31Ypx19CLUiq+fe+65urWrr4je45jnGEMoJ02aVO/mlNptt91WDP2O4Tps2IsvvlgMM41h81/84heL7XbaaaelwYMHp5NPPtkm7OKqcktLS5o4cWIaOHBgcWy78MIL07Rp02wv+j31ftOo992j1vecet9z6n2DBFE2/arfs88+W/S60LVly5alWbNmFXNqY0EsunfSEz2iF110UfF19IjGvnbttdcKol2444470i233JLmz5+f9thjj/STn/ykuFA0ZswY2wzYJOr9hqn1G0e97zn1vkGC6Lbbblv0HLz22mvtno+vd9hhh7q1qy849dRT0z333JMefvjhNHbs2Ho3p9Ri+HcsfhXzQ6uityq2XcxNXrNmTbEf8n923HHHtPvuu7fbJLvttlv69re/bTN14fOf/3xxlfRTn/pU8XWsMvzSSy8VK1/qRaa/U+83nnrfPWr9xlHve069b5A5ojHMb9999y3mVdVemYmvDzzwwLq2raxiPaooSgsWLEjf//73i1tFsH6HHXZYeuaZZ4oequojevtiyGT8fyF0XTHcu+NtgWLu40477WR368Lbb79dzHGvFftWHNOgv1Pve0697xm1fuOo9z2n3jdIj2iIOWjRWxDBYMqUKcUqpnErkunTp9e7aaUdnhND/+66667iXqKvvvpq8Xxzc3OxOifriu3UcQ7tVlttVdwf09zazp1++unFZPwYmvuJT3yiuLfv9ddfXzzo3DHHHFPMCR0/fnwxNPepp55Kl19+eTrllFNsMlDv1fteptZvHPW+59T7LlT6qCuvvLIyfvz4yuDBgytTpkypLFy4sN5NKq34NXf2mDdvXr2b1qcceuihlVmzZtW7GaX2ne98pzJp0qTKkCFDKhMnTqxcf/319W5SqbW0tBT7VBzLhg4dWnnf+95X+dKXvlRZs2ZNvZsGpaHed596v+nU+u5R73tGve9cn7yPKAAAAH1Xn5sjCgAAQN8miAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAACmn/wcwgb/L2zJMMQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1200x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1, 2, figsize=(12, 5))\n",
    "axs[0].imshow(abs(gt_graph)>0.001, cmap='bwr', vmin=-0.5, vmax=0.5)\n",
    "axs[0].set_title(\"True Graph\")\n",
    "adjacency_matrix = model.model.return_adjacency().detach().cpu().numpy()\n",
    "axs[1].imshow(adjacency_matrix>0.5, cmap='bwr', vmin=-1, vmax=1)\n",
    "axs[1].set_title(\"SCOUT Estimated Graph\")\n",
    "shd = compute_shd(abs(gt_graph)>0.001, adjacency_matrix > 0.5)\n",
    "print(f\"SHD between true and estimated graph: {shd[0]}\")\n",
    "auprc = compute_auprc(abs(gt_graph)>0.001, adjacency_matrix)\n",
    "print(f\"AUPRC between true and estimated graph: {auprc[1]}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "87fedfae",
   "metadata": {},
   "source": [
    "Plot the ground truth and learned intervention targets as well as the SHD and AUPRC score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "384a90db",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SHD between true and estimated graph: 0.0\n",
      "AUPRC between true and estimated graph: 1.0\n"
     ]
    },
    {
     "data": {
      "image/png": "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9mTttdcuikMM7T7kkEOW+dndddddxXuJNjzppJOKI41z5swpCmHs+ERhX9bnF4UidgI23XTToi1iwx47ZPUbf4BcXnvtteJAXPWAXmyrbr311mK7G6NCYkc0xP//0z/9UzrwwAPT5z//+WInNUaU7L777unhhx9e6nSL2DZGz15s72NbF0GyKmpEHKibPXt2sVMbrxs7uXGgt9n6E+sQNTpqSaxrnC8YtSOWFwcxe2vevHnFe4zXjraJA6uxfY/Xj16ruD9ON+nu1KAQv4/AECE7euwiKF1wwQXFusc2v7bn69lnny3aNZ4TbRsHKD/96U8XoerVV18tgkttrYvlRl3vzbKi5kSIjc83al4ccIjwE3Utgmy0b7xG1NAITdXTnHo63SmGfUboideN7098rj/4wQ+K14yD+TH/QjPt2qw4mBzq63yE6fXXXz+dfvrpnQev43sUATnefxzkjjAW38Gf//zn6frrr+/y/F/84hfFZ/CFL3yhaKf4PsdrxgHuCGMh1jkOgMf98b7jbykOIsS+YwTh+qHC8Z2O9xz7RhHeYz9y1113LebN6EsPeLzO4YcfXoThr3/968V9y9rnbWRfJsR7j325+FwjiP/6178uvn/RXltuuWUakSpQZ+bMmbGF6XLfzjvvXNx3ySWXLNVecf9JJ5201P1rr7125ZBDDun8+ZRTTqmsuOKKleeee67L42bNmlUZPXp05aWXXlrmZxHrsNFGGy217LFjx1aef/75zvuefPLJ4v7zzz+/876zzz67uO+Xv/xll+f/6le/KpZ92mmndbn/qaeeqowZM6bL/T21QXt7e2XcuHGVL3/5y13uP+ussyotLS2VF198sdfL+v73v99536JFiyqrr756Zd999+2875FHHikeN2fOnKXaK9o+PoOqG264oXjsqaee2uVxn/rUp4r1rG3DRtu1O6+++mpl1VVXLR47ffr0yhe+8IXKvHnzKr/97W+7PG7JkiWV9ddfv7L77rsX/1/17rvvVqZNm1b52Mc+ttzP79vf/nZx/+uvv77MdQLoD7GtjW1ObHt78tnPfrayxhprVN54440u9x9wwAGV1tbWYhsXfv/73xfb9VpvvvlmZbXVVqsceuihnffFdi+WOWnSpMrChQu7PD5qb/yu9vFhn332qUyePLnz50brz3vvvVeZMmVKZfPNN++ybpdddlmx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n7No0aLiVnuUFAAoJ7UegGExa+7s2bOL4TnVWwztAQCGD7UegAENoqusskoaPXp0eu2117rcHz+vvvrq3T7n+OOPL8YHV28LFixoeiUBgDzUegBKF0THjh2bttpqq3TnnXd23hcTGMTP22+/fbfPGTduXHGSau0NACgntR6A0p0jGuLSLYccckjaeuut07bbbpvOO++89M4776QZM2YMzBoCAFmp9QCULoh++tOfTq+//no68cQT06uvvpo233zzdNttty01gREAMDSp9QCU7jqifVXma4sF1xcDGEiuIzoSlLnWq/MAQ/A6ogAAANBXgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJDVmDRIWlN7SmlSKptKakll1JIqg70KADDka31Z63xQ64GRRI8oAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZDUm7+LKryVVUhlVUksqq7K2GQAMpZpV1lpf5jYDhi49ogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAFDeIDp79uy0zTbbpIkTJ6YpU6akvffeOz377LMDt3YAQFZqPQClC6L33HNPmjlzZnrooYfSHXfckd5///202267pXfeeWfg1hAAyEatByCHlkqlUuntk19//fWiZzSK1k477dTQczo6OlJra2tKqT2lNKm3ix5xKqkllVVL6vVXCBhxOlJKram9vT1NmqQGDAVqfT5lrfXqPDAQtb5P54jGi4eVV165Ly8DAJSUWg/AQBjT2ycuWbIkHXXUUWnHHXdMG2+8cY+PW7RoUXGr7REFAMpPrQdgoPS6RzTOFX366afT1VdfvdxJD2IobvXW1tbW20UCABmp9QCU6hzRww47LN14443p3nvvTdOmTVvmY7vrEf1DGHWO6HA4byQ4dwRonHNEhwq1Pr+y1np1HhiIWt/U0NzIrIcffni6/vrr0913373cEBrGjRtX3ACA8lPrAchhTLNDdObNm1f0hsa1RF999dXi/hhyO2HChIFaRwAgE7UegNINzW1p6X7IyJw5c9JnPvOZhl7D5VuG13CdYMgO0DhDc8tOrR88Za316jxQiqG5AMDwpdYDkEOfriMKAAAAzRJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArMbkXRy91ZIqpW28SmpJZVTmNgOAoVK3ylrny9xmwPLpEQUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsxuRdHMNRS6qkMqqkllRWZW0zABhKNaustb7MbQZloUcUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAhk4QPeOMM1JLS0s66qij+m+NAIDSUOsBKFUQfeSRR9Kll16aNt100/5dIwCgFNR6AEoVRN9+++100EEHpcsvvzyttNJK/b9WAMCgUusBKF0QnTlzZtpzzz3Trrvu2v9rBAAMOrUegIE0ptknXH311Wn+/PnFcJ1GLFq0qLhVdXR0NLtIACAjtR6AUvWILliwIB155JFp7ty5afz48Q09Z/bs2am1tbXz1tbW1tt1BQAGmFoPQA4tlUql0uiDb7jhhrTPPvuk0aNHd963ePHiYubcUaNGFT2ftb/rqUf0D2G0PaU0qb/eByylklpK2yotqeE/OxhmYlRMa2pvb0+TJqkBZaTWM5SUtdar84xsHQ3V+qaG5u6yyy7pqaee6nLfjBkz0vTp09Nxxx23VAgN48aNK24AQPmp9QDk0FQQnThxYtp444273LfiiiumyZMnL3U/ADD0qPUAlPo6ogAAAJBl1tx6d999d19fAgAoMbUegP6mRxQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACCrMXkXB/m0pEppm7uSWlJZlbndAGAo1Cx1HpZPjygAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkNSbv4oDQkiqlbYhKakllVOY2A4ChUrPUecpCjygAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAACUO4i+/PLL6eCDD06TJ09OEyZMSJtsskl69NFHB2btAIDs1HoABtqYZh785ptvph133DF99KMfTbfeemtaddVV0y9+8Yu00korDdwaAgDZqPUAlC6InnnmmamtrS3NmTOn875p06YNxHoBAINArQegdENzb7rpprT11lun/fbbL02ZMiVtscUW6fLLLx+4tQMAslLrAShdEH3hhRfSxRdfnNZff/10++23py9+8YvpiCOOSFdccUWPz1m0aFHq6OjocgMAykmtByCHlkqlUmn0wWPHji16RB944IHO+yKIPvLII+nBBx/s9jnf+MY30sknn9zNb9pTSpN6t9bAgKmkllK2bktqeFNFqcXByNbU3t6eJk1SA8pIrYfhTZ2n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xo8fn7bbbrv08MMPD/Yqldbs2bPTNttskyZOnJimTJmS9t577/Tss88O9moNKWeccUZqaWlJRx111GCvSqm9/PLL6eCDD06TJ09OEyZMSJtsskl69NFHB3u1Smvx4sXphBNOSNOmTSvaa7311kunnHJKMocc/B/1vnHqfd+o9Y1T75uj3g+jIHrNNdekY445prh0y/z589Nmm22Wdt9997Rw4cLBXrVSuueee9LMmTPTQw89lO644470/vvvp9122y298847g71qQ8IjjzySLr300rTpppsO9qqU2ptvvpl23HHHtMIKK6Rbb701/exnP0vf+ta30korrTTYq1ZaZ555Zrr44ovTBRdckH7+858XP5911lnp/PPPH+xVg1JQ75uj3veeWt849b556v0wunxL9IBGD1/svIUlS5aktra2dPjhh6dZs2YN9uqV3uuvv170jEbB2mmnnQZ7dUrt7bffTltuuWW66KKL0qmnnpo233zzdN555w32apVS/O395Cc/Sffdd99gr8qQ8fGPfzytttpq6bvf/W7nffvuu2/RO3rllVcO6rpBGaj3faPeN0atb4563zz1fpj0iL733nvpscceS7vuumvnfaNGjSp+fvDBBwd13YaK9vb24t+VV155sFel9KInec899+zyfaN7N910U9p6663TfvvtVxzo2GKLLdLll1+uuZZhhx12SHfeeWd67rnnip+ffPLJdP/996c99thDuzHiqfd9p943Rq1vjnrfPPW+e2PSEPPGG28U46yjF6FW/PzMM88M2noNFdF7HOc5xhDKjTfeeLBXp9SuvvrqYuh3DNdh+V544YVimGkMm//a175WtNsRRxyRxo4dmw455BBN2MNR5Y6OjjR9+vQ0evToYtt22mmnpYMOOkh7MeKp932j3jdGrW+eet889X6YBFH6ftTv6aefLnpd6NmCBQvSkUceWZxTGxNi0dhOT/SInn766cXP0SMa37VLLrlEEO3Btddem+bOnZvmzZuXNtpoo/TEE08UB4qmTp2qzYA+Ue+XT63vHfW+eer9MAmiq6yyStFz8Nprr3W5P35effXVB229hoLDDjss3XLLLenee+9Na6655mCvTqnF8O+Y/CrOD62K3qpouzg3edGiRcX3kP+zxhprpA033LBLk2ywwQbpuuuu00w9OPbYY4ujpAcccEDxc8wy/OKLLxYzX+pFZqRT73tPvW+MWt876n3z1Pthco5oDPPbaqutivOqao/MxM/bb7/9oK5bWcV8VFGUrr/++nTXXXcVl4pg2XbZZZf01FNPFT1U1Vv09sWQyfh/IXRpMdy7/rJAce7j2muv7evWg3fffbc4x71WfLdimwYjnXrfPPW+OWp976j3zVPvh0mPaIhz0KK3IILBtttuW8xiGpcimTFjxmCvWmmH58TQvxtvvLG4luirr75a3N/a2lrMzsnSop3qz6FdccUVi+tjOre2e0cffXRxMn4Mzd1///2La/tedtllxY3u7bXXXsU5oWuttVYxNPfxxx9P5557bjr00EM1Gaj36v0AU+t7R71vnnrfg8oQdf7551fWWmutytixYyvbbrtt5aGHHhrsVSqt+Ji7u82ZM2ewV21I2XnnnStHHnnkYK9Gqd18882VjTfeuDJu3LjK9OnTK5dddtlgr1KpdXR0FN+p2JaNHz++su6661a+/vWvVxYtWjTYqwalod43Tr3vO7W+Mep9c9T77g3J64gCAAAwdA25c0QBAAAY2gRRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAg5fT/ANui6pxTW04EAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1200x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1, 2, figsize=(12, 5))\n",
    "intervention_sets_array = np.zeros((n_experiments, n_nodes))\n",
    "for i, interv in enumerate(intervention_sets):\n",
    "    intervention_sets_array[i, interv] = 1\n",
    "axs[0].imshow(intervention_sets_array, cmap='bwr', vmin=0, vmax=1)\n",
    "axs[0].set_title(\"True Intervention Sets\") \n",
    "proba = model.model.trained_interv.get_proba()\n",
    "axs[1].imshow(proba.detach().cpu().numpy()>0.5, cmap='bwr', vmin=0, vmax=1)\n",
    "axs[1].set_title(\"Learned Intervention Probabilities\")\n",
    "shd = compute_shd(intervention_sets_array>0.001, proba.detach().cpu().numpy() > 0.5)\n",
    "print(f\"SHD between true and estimated graph: {shd[0]}\")\n",
    "auprc = compute_auprc(intervention_sets_array>0.001, proba.detach().cpu().numpy())\n",
    "print(f\"AUPRC between true and estimated graph: {auprc[1]}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d2083572",
   "metadata": {},
   "source": [
    "Define NODAGS model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "6fed9af3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initializing the model\n",
      "Number of Parameters : 212\n"
     ]
    }
   ],
   "source": [
    "from models.resblock_trainer_nodags import resflow_train_test_wrapper as nodags_trainer\n",
    "if sem_type == \"lin\":\n",
    "    act_fun = 'none'\n",
    "elif sem_type == \"nnl\":\n",
    "    act_fun = 'tanh'\n",
    "model = nodags_trainer(\n",
    "    n_nodes=10,\n",
    "    batch_size=512,\n",
    "    l1_reg=True, \n",
    "    lambda_c=1e-3,\n",
    "    fun_type='gst-mlp', # Gumble-softmax masking function\n",
    "    act_fun=act_fun,\n",
    "    lr=1e-2,\n",
    "    epochs=200, # change to a higher number for better accuracy,\n",
    "    v=False, \n",
    "    inline=True, \n",
    "    n_hidden=0,\n",
    "    optim='adam',\n",
    "    dag_input= False,\n",
    ")\n",
    "if unknown_target:\n",
    "    intervention_sets_nodags = [[None] for _ in range(n_experiments)]\n",
    "else:\n",
    "    intervention_sets_nodags = intervention_sets"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8c3cd13f",
   "metadata": {},
   "source": [
    "Training NODAGS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "7d2d30f8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting Training\n",
      "Exp: 10/10, Epoch: 200/200, Batch: 0/2, Loss: 13.812449455261233\r"
     ]
    }
   ],
   "source": [
    "model.train(training_data, intervention_sets_nodags, batch_size=512)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "381fa63f",
   "metadata": {},
   "source": [
    "Plot the ground truth and learned adjacencies as well as the SHD and AUPRC score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "de3c9051",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SHD between true and estimated graph: 36.0\n",
      "AUPRC between true and estimated graph: 0.21844338895633764\n"
     ]
    },
    {
     "data": {
      "image/png": "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75GBYWgude9///d/i6IWhfGwww4rvoz7I8LYHnvsUXyZRwGJL8YYnnPqqacWw4MuuuiiXh8bBSiKzd/+7d+m4cOH9+t1Y1jTzTffXOxArLXWWkWRC9///vfTZz/72eILO4rZjTfeWHxhx7CYGILVUQzHuummm4oCEF+6l19+efqzP/uz9Mgjj3Q7l+gLX/hCUVynTp1aDHmKnZMoRhGkASiH+J6OABPDZE855ZRix7snd955ZxFYY9nexO9+9rOfFQc6//qv/3qZrx07/TGcNgLus88+W4SaqjjoGcE2zt+Mehtti7kRoj5Vxc8hanFfRQD9j//4j6ImRqheXr/97W97DEjVIbaxPqNWxhDXGLYcITrOa4zzYv/iL/4i/fmf/3l64YUX0g9/+MP0ve99r6jLIQLm0hx77LHFOokhvQ8//HARhOI1Yz8i9idiWG0MSY6D1VGXO35efan3cXAgPruddtqpOI83RNAKb7zxRvrjP/7j9gPT0dbYLuJ0oThPNw6whwh4e+65Z3r11VeLdRDbVDxvrPO+iPbEAfqdd9459cfvf//7IkB+/OMfL0J3HACoHrCIfa+jjz66COGxzxIHCSIsx+86im089mvifUYgjm05zh2O545A2lEcVIih5rEvF+sklo/PNYLsKqus0q+2s5LUuksWBnJobgxVivuuvPLKbsvH/TFkp6sYltRxiMtZZ51VDDl54YUXOi13yimnVIYPH77UoSYxFCVe55Zbbul0/+9///timFDHW8dhu/GYhoaGyn/913/1ODyqow8++KAY6vSpT32q2/uL22OPPdZ+3yuvvFIZPXp05aCDDuo2bOnII4/s9PhYZuzYsb2+NwDyD8199NFHK7/+9a+L4apTpkzpdWju8ccfXyz/xBNP9Pqcs2fPLpY58cQTlzk0t+p73/te8Zhbb7210xDZaM8111zTft+uu+5aOeCAAzo9NobsNjc39zgks2M9XLhwYfvvnnnmmcqYMWPahyUfd9xxRU3t62k21RrX0+1jH/tY+3LR1q5Dm/szNLfrvkP189pnn3061fdddtmlMmzYsE5DomOfYNy4ccVnuDz1vrehuV/+8pcr66+/fuWtt97qdP8hhxxSaWpqan/+iy66qGjrzTff3L5MrN+PfvSjyxyaG59VLBPDtrt6++23O32uHd9PtDceF/tSXXV939XTnGK9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ZEDVgLoy9afeR7vigEMsH5deifNmY1hsnD8cl+eJ/z/qqKOKYB0HEmL9xfLVS9rE7+K9Rg9krOsYahvbVPVyKssSQ7JjuHBMUBUHBuJyM1tvvXURCl9++eXidzEirC8HPGIobhxgicvexTYRc1REmO7tPM7Yd4ptO4Yfx/uMCbJ+/OMfF9fbNfJrEBjgWXmh5pdv6W069iVLllROPvnkylprrVVZddVViynWX3zxxW5TsId33nmncuqppxZTmceU4PGYmJr+ggsuKKZT74uZM2dWPv3pT1fWXnvtYpr7mML+4x//eDEd/IIFCzotG+8j3k9Prr322sqmm25aGTVqVGXChAnFFPHV6el7eo7rr7++ffmYOr/rNOzVx1anOe869XxP09QDULvLt3RVvYxFT/Vu0aJFxSVXtt9+++IyH1Hvtttuu+KSHT3Vr6iB1cubxOUyGhsbi+c96qijKr/85S87LRuXzYjl4nIyvTnzzDOLZZ566qn2+6Lmffvb3y5q0oc+9KGirra0tFQ+//nPd7uUxi9+8YuilsVlS+KSI6usskpl/PjxlSOOOGKpr9uXy7d0vDTJVVddVdl9992LS3xEvdxkk00qJ510UqdLyVQv6fbhD3+4uMRaxxrZ2+Vbun5evdXceGx8PstT7+fMmVO0vXqZm47tiEvrxPqL9Rvrbr311qvsueeelauvvrrTc8RlUT772c8W20fs48Rlcu66665lXr6lo9iHOvroo4t9pbhUXLQn2h2XqnnyySeX+X6rnn322cpee+1VbBvRltj2YvuJtsQ66PocsR3svffeRdvXXXfdYh3FPl5V9fItsb/V10v5kcew+E+twzCw8sWQnsmTJ3casgIAUA9ilFr0dPc0Yy+Dg3NEAQAAyEoQBQAAICtBFAAAgKycIwoAAEBWekQBAADIShAFAAAgqxF5Xy6ltra29PrrrxcXB47LSwAwdMQVw955553ioutxgXPqk1oPMHRV+ljrswfRCKEtLS25XxaAEpk7d24aN25crZvBAFHrAZi7jFqfPYhGT2iY++qrqbGxMZVOc3MqpQULat0CqK2y/m2WWQm/N1pbW1PL+PHttYD6VPpaX1a+5+rie4463P5tZwNS67MH0epw3ChMilM/KORAHX1vODWjvqn1ZFPi7znqiO1sQGq9E3QAAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAADKH0Qvu+yytNFGG6XRo0ennXfeOT3yyCMrv2UAQM2o9QCUKojedNNN6cQTT0xnnHFGmj17dtp6663TPvvsk958882BaSEAkJVaD0Dpgui0adPSUUcdlSZNmpQ233zzdOWVV6ZVV101/eAHPxiYFgIAWan1AJQqiH7wwQfp8ccfT3vttdcfnqChofh51qxZA9E+ACAjtR6AHEb0Z+G33norLVmyJK277rqd7o+f58yZ0+NjFi1aVNyqWltbl7etAMAAU+sBqItZc6dOnZqampraby0tLQP9kgBARmo9AAMaRNdaa600fPjw9MYbb3S6P35eb731enzMqaeemhYuXNh+mzt3br8bCQDkodYDULogOnLkyLT99tune++9t/2+tra24udddtmlx8eMGjUqNTY2droBAOWk1gNQunNEQ1y65fDDD0877LBD2mmnndJFF12U3nvvvWIWXQBg8FPrAShdEP3iF7+Y5s+fn04//fQ0b968tM0226S77rqr2wRGAMDgpNYDMNCGVSqVSsooZs2NSYsWLlhQzmG6DQM+f9PyaWurdQugtsr6t1lmJfzeKGpAc3MxZ0ApawBDo9aXle+5uvieow63f9vZgNT6En/iAAAA1CNBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyGpE3pcbBNraat0CVpYGx1mWi78B6wyojbJ+/6qn9bXOyrqdlbVdDJgS/5UAAABQjwRRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshqR9+UGgYaSZvO2tlq3YPAp8zor63ZWZmX+PMvKdgaD6++irN9zZW0X9fc3wJBiSwQAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAIDyBtGpU6emHXfcMa2++uppnXXWSQceeGB6/vnnB651AEBWaj0ApQui999/f5o8eXJ6+OGH0z333JMWL16c9t577/Tee+8NXAsBgGzUegByGFapVCrL++D58+cXPaNRtHbfffc+Paa1tTU1NTWlhQsWpMbGxlQ6DSUdrdzWVusWMBS2s2Bbqx8l3M5aU0pNKaWFCxeWswZQ/7W+hH8X7Xz/1o8yb2dQklq/Qn8l8eRhzTXXXJGnAQBKSq0HYCCMWN4HtrW1peOPPz7ttttuaeLEib0ut2jRouLW8SgpAFB+aj0AA2W5e0TjXNFnnnkm3Xjjjcuc9CCG51RvLS0ty/uSAEBGaj0ApTpH9Jhjjkm33npreuCBB9LGG2+81GV76hGNMFrK80bKPKbfeSP1pazbWbCt1Y8SbmfOER086rbWl/Dvop3v3/pR5u0MSlLr+zU0NzLrsccem2bOnJnuu+++ZRamMGrUqOIGAJSfWg9ADiP6O0RnxowZxRHSuJbovHnzivtjyO2YMWMGqo0AQCZqPQClG5o7bNiwHu+fPn16OuKIIwb/lO5lHkphuE59Ket2Fmxr9aOE25mhueVX97W+hH8X7Xz/1o8yb2cwWIfmAgD1S60HIAeHawAAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALIakfflWG4NJT5m0NZW6xYMPmVeZ2Xd1sq8zsqqjOustTWl5uZatwLKyfcvQ7U2lHn7Z8D4xAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACCrEXlfbhBoa0ul1OCYAQDUbZ0vc60va7vK/nnCUN3+W1tTam5e5mIl/mYBAACgHgmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAADJ4get5556Vhw4al448/fuW1CAAoDbUegFIF0UcffTRdddVVaauttlq5LQIASkGtB6BUQfTdd99Nhx56aLrmmmvSGmussfJbBQDUlFoPQOmC6OTJk9N+++2X9tprr5XfIgCg5tR6AAbSiP4+4MYbb0yzZ88uhuv0xaJFi4pbVWtra39fEgDISK0HoFQ9onPnzk3HHXdcuuGGG9Lo0aP79JipU6empqam9ltLS8vythUAGGBqPQA5DKtUKpW+LnzLLbekgw46KA0fPrz9viVLlhQz5zY0NBQ9nx1/11uPaITRhQsWpMbGxpX1PupfQ4mvtNPWVusWMBS2NdtZXYga0NTcnBYuXKgGlJRaX0Nl/f4ts7LWhjJ/ltZZ/WhrG9S1vl9Dc/fcc8/09NNPd7pv0qRJacKECenkk0/uFkLDqFGjihsAUH5qPQA59CuIrr766mnixImd7ltttdXS2LFju90PAAw+aj0AOZR43AAAAAD1qN+z5nZ13333rZyWAAClpNYDsLLpEQUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhqRKqV5uZUSm1tqZTK2q7QUNLjGWVeZ2VmvQH1XuvLqqzfv2Wt82VW1s+yzKyzIfe3ObhbDwAAwKAjiAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJDViFQrCxak1NiYSqehpNm8rS2VVpnbBgAdqVn9Z50xlPfBGTA+cQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAACh3EH3ttdfSYYcdlsaOHZvGjBmTttxyy/TYY48NTOsAgOzUegAG2oj+LPz222+n3XbbLX3yk59Md955Z1p77bXTr371q7TGGmsMXAsBgGzUegBKF0TPP//81NLSkqZPn95+38YbbzwQ7QIAakCtB6B0Q3Nvu+22tMMOO6SDDz44rbPOOmnbbbdN11xzzcC1DgDISq0HoHRB9KWXXkpXXHFF2nTTTdPdd9+djj766DRlypR03XXX9fqYRYsWpdbW1k43AKCc1HoAchhWqVQqfV145MiRRY/oQw891H5fBNFHH300zZo1q8fHnHnmmelb3/pWt/sXLliQGhsbU+k0lHQi4ba2WrcAYIXFwcim5ua0cOHCctYAVm6tTymV7lNWT6GcyroPTr9Ft2NT1IBl1Pp+feLrr79+2nzzzTvdt9lmm6VXX32118eceuqpRSOqt7lz5/bnJQGAjNR6AEo3WVHMmPv88893uu+FF15IG264Ya+PGTVqVHEDAMpPrQcgh371iJ5wwgnp4YcfTueee2568cUX04wZM9LVV1+dJk+ePHAtBACyUesBKN05ouGOO+4ohtvG9UPj0i0nnnhiOuqoo/p3flBTk3NE+8s5LUAdcI7o4LDSar1zRIG+co7okDtHtN9BdIUbJoguH0EUqAOC6NAgiAL9JojWjQGZrAgAAABWlCAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkNSLvyw0CbW21bgEAMFAaSnwM3j5I/bCd1df2X9bPs62k66y1NaXm5mUuVtK1CgAAQL0SRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAA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",
      "text/plain": [
       "<Figure size 1200x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1, 2, figsize=(12, 5))\n",
    "axs[0].imshow(gt_graph>0.001, cmap='bwr', vmin=-0.5, vmax=0.5)\n",
    "axs[0].set_title(\"True Graph\")\n",
    "adjacency_matrix = model.model.f.get_w_adj().detach().cpu().numpy()\n",
    "axs[1].imshow(adjacency_matrix>0.5, cmap='bwr', vmin=-1, vmax=1)\n",
    "axs[1].set_title(\"NODAGS Estimated Graph\")\n",
    "shd = compute_shd(gt_graph>0.001, adjacency_matrix > 0.5)\n",
    "print(f\"SHD between true and estimated graph: {shd[0]}\")\n",
    "auprc = compute_auprc(gt_graph>0.001, adjacency_matrix)\n",
    "print(f\"AUPRC between true and estimated graph: {auprc[1]}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d11851b3",
   "metadata": {},
   "source": [
    "Define and train LLC model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "73246ce9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parsing experiments\n",
      "Estimating the adjacency matrix\n",
      "Estimating latent variances\n"
     ]
    }
   ],
   "source": [
    "llc_wrapper = LLCClassWrapper()\n",
    "B_est = llc_wrapper.train(datasets, dataset_gen.targets, return_weights=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1f8469e0",
   "metadata": {},
   "source": [
    "Plot the ground truth and learned adjacencies as well as the SHD and AUPRC score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "459dce7d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SHD between true and estimated graph: 47.0\n",
      "AUPRC between true and estimated graph: 0.132190197795752\n"
     ]
    },
    {
     "data": {
      "image/png": "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4I1zOupEBerEjBkzKl0/0gcffHCx7brrrlvr+bH9ggsuWGv7DjvsUDnxxBPbv77ooosqm222WWXJkiWdnnf22WdXhg8fXnn55Zd7bNM3vvGN4nXuvPPOTtt/85vfVFasWNHp0dbW1qltDQ0NlZ///Odr/cx33nmn09fvvfdeZfLkyZXf/d3fXev3i8eiRYvat7300kuV0aNHV44++uj2bbEP4nknnXRSp++P54wbN67H3w2AwW/OnDlFDXj88cd7fM6vfvWr4jlf+9rXenzOGWecUTznySefXO+2VF+np8eCBQuK591xxx29tjnqak91vlr3OoqvR40aVbSh6vrrry+2b7PNNpXW1tb27eecc06xveNzu9bmMGvWrMqwYcOK2ruuc5Xw8MMPF9vnzp3baft9993Xafvy5csrI0eOrEybNq3TecO5555bPK/j+Ut3orbH81auXNlp+69//etO5yRvvPFG+9/95Cc/Kb5np512Wuv3fPfddytr1qzptC32S+zLr3zlK2v9jA9+8IOd9uXtt99ebI/zpa7nbt/97nfbt61evbp4H4455ph1/n4MLobmUveiJzCuLq6vuJL58Y9/vFhVLq7QVh9xBS9WletpqGuoroYbw1U6iqE+ccW24yN6bjuKq4kxPKirrlcMV61aVbQvroh2FcOKYjhuVfTmfvrTny6G5XRdEe+v//qvO30dPzPaZEVfAHpTrRVjx47d4J0Vw0aj17Dro1oTowc0xEig999/f6O9OYccckj76KOw//77F38ec8wxnX6v6vYXX3yx29r89ttvF+cJMY0mMm70aPblXCOmxcTQ5o7nGlHD4xziJz/5SfG8WEwoej5PPfXUTsN6uxsO3Z/zkuuuu67TOUmsptvViSee2On3rJ5jVeeJxnlFnDfEz44pQd2dl/zZn/1Zp335R3/0R8UUpVjEqaP4GR17baP3db/99uu0zxn8DM2l7sW8gjiAra9f/vKX6d///d/b55t0FUNLelI92L711ludtsc8kyiqIRYq6m6ITgxx6U4U3hiSE8NYYmhMVXfzT3fZZZe1tv3Wb/1WMXwoVs2LORodQ2pHEbyrYTfmfABAT6p1IlaE31BRu+Jib0/iQm2Ew5j/GQsgxZzNo446qljtNYLR+upaByMYhpjv2d32jnM3YzXgGDIbQ3u7zumMC8Z9OdeI58WUmHWd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ZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAACUP4hec801accdd0yjR49O+++/f3rsscc2fssAgJpR6wEoVRC97bbb0plnnpkuuOCCtHjx4vThD384HXbYYWn58uUD00IAICu1HoDSBdErr7wynXzyyWn69Olpt912S9ddd13adNNN03e+852BaSEAkJVaD0Cpguh7772XnnjiiTR16tT/+wENDcXXCxYsGIj2AQAZqfUA5DCiP09+/fXX05o1a9LWW2/daXt8/dxzz3X7PatXry4eVa2trevbVgBggKn1ANTFqrmzZs1KTU1N7Y+WlpaBfkkAICO1HoABDaJbbrllGj58eHrttdc6bY+vt9lmm26/55xzzkmrVq1qfyxdurTfjQQA8lDrAShdEB05cmTaZ5990vz589u3tbW1FV8fcMAB3X7PqFGjUmNjY6cHAFBOaj0ApZsjGuLWLSeeeGLad99903777Zeuuuqq9Pbbbxer6AIAg59aD0Dpgugf//EfpxUrVqTzzz8/LVu2LO21117pvvvuW2sBIwBgcFLrARhowyqVSiVlFKvmxqJFq1auLOcw3YYBX79p/bS11boFUFtl/bdZZiU8bhQ1oLm5WDOglDWAoVHry6qsx7kSHkuow89ZmZX130BDOd/LuEdKU0q91vpyth4AAIC6JYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZjcj7coNAW1utW8DG0uA6y3rxb8A+Axgs9VTNqp99VubPWVm1lfS9bG1Nqbm516d5xwEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACCrEXlfbhBoKGk2b2urdQsG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gigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZDUi1crKlSk1NqbSaShpNm9rS6VV5rYBUDvNzeXb+2WuWc5BgCGkpKkLAACAeiWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAUO4g+sorr6QTTjghjRs3Lo0ZMybtscceadGiRQPTOgAgO7UegIE2oj9PfuONN9KUKVPSJz/5yXTvvfemrbbaKv3yl79Mm2+++cC1EADIRq0HoHRB9PLLL08tLS1pzpw57dsmTpw4EO0CAGpArQegdENz77777rTvvvumY489No0fPz7tvffe6YYbbhi41gEAWan1AJQuiL744ovp2muvTbvsskv60Y9+lD7/+c+n0047Ld100009fs/q1atTa2trpwcAUE5qPQA5DKtUKpW+PnnkyJFFj+ijjz7avi2C6OOPP54WLFjQ7fd8+ctfThdeeOFa21etXJkaGxtT6TSUdCHhtrZatwBgg8XFyKbm5rRq1apy1gA2bq1PKZXuXS5zPXUOAgyhWt+v1LXtttum3XbbrdO2XXfdNb388ss9fs8555xTNKL6WLp0aX9eEgDISK0HoHSLFcWKuc8//3ynbUuWLEk77LBDj98zatSo4gEAlJ9aD0AO/eoRPeOMM9LChQvTpZdeml544YU0b968NHv27DRjxoyBayEAkI1aD0Dp5oiGe+65pxhuG/cPjVu3nHnmmenkk0/u35jhpiZzROtpTgtAH5kjOjhstFpvjmj/mCMKDKFa3+8gulEaJoj2nyAK1AFBdGgQRNeTIArUgQFZrAgAAAA2lCAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkNSLvyw0CbW21bgEAMFAaXIOvq31W1vM2+wx6VeIjCwAAAPVIEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACCrEalWmptTKbW11boFAFAfVq5MqbExlUqDa/D95tzIPqOcGgb38Wxwtx4AAIBBRxAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAACgvEF0zZo16bzzzksTJ05MY8aMSTvvvHO66KKLUqVSGbgWAgDZqPUA5DCiP0++/PLL07XXXptuuummtPvuu6dFixal6dOnp6ampnTaaacNXCsBgCzUegBKF0QfffTR9OlPfzpNmzat+HrHHXdMt9xyS3rssccGqn0AQEZqPQClG5p74IEHpvnz56clS5YUXz/11FPpkUceSYcffvhAtQ8AyEitB6B0PaJnn312am1tTZMmTUrDhw8v5pFccskl6fjjj+/xe1avXl08quL7AYByUusBKF2P6O23357mzp2b5s2blxYvXlzMFb3iiiuKP3sya9asYg5p9dHS0rIx2g0ADAC1HoAchlX6seRthMi4Ujpjxoz2bRdffHG6+eab03PPPdfnHtH4OatSSo2phNraat0CgLoVNaCpuTmtWrUqNTaWsgoMeRu11q9cWb73ucGd6/rNuRGUU0M5j2cx/rUppV5rfb+G5r7zzjupocsvHEN029ZxgBo1alTxAADKT60HIId+BdEjjzyymBM6YcKE4vYtTz75ZLryyivTSSedNHAtBACyUesBKN3Q3DfffDOdd9556Y477kjLly9P2223XTruuOPS+eefn0aOHNn3YVlNTYbmAgxBhuaW30at9Ybm1gdDc6GcGgb30Nx+BdGN0jBBFGDIEkSHBkG0zgiiUE4NgzuIlrP1AAAA1C1BFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyGpE3pcDAKihtja7n6GtoaT9UP5t1s8+a21Nqbm516eV9JMIAABAvRJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshqR9+VSqlQqxZ+tqaRaS9sygEGv9f8/xlZrAfWpvdarqUBfOV4MuVqfPYi++eabxZ8tqaSam2vdAoC6F7Wgqamp1s1goGv9hAn2MdA3zsGHXK0fVsl8WbqtrS29+uqraezYsWnYsGEbnLZbWlrS0qVLU2Nj40ZrYz2zz+wzn7NyGir/NqPkRGHabrvtUkOD2SH1Sq2vraFyPNmY7DP7zOcsf63P3iMajdl+++036s+Mg6wDrX020HzO7LMchsLnTE9o/VPry2EoHE82NvvMPvM5y1frXY4GAAAgK0EUAACArAZ1EB01alS64IILij+xz3zOysO/TfsMHE8cgwcTdcs+8znLL/tiRQAAAAxtg7pHFAAAgMFHEAUAACArQRQAAICsBFEAAACyGrRB9Jprrkk77rhjGj16dNp///3TY489VusmldasWbPSRz/60TR27Ng0fvz4dNRRR6Xnn3++1s0aVC677LI0bNiwdPrpp9e6KaX2yiuvpBNOOCGNGzcujRkzJu2xxx5p0aJFtW5Waa1Zsyadd955aeLEicX+2nnnndNFF12UrCEH/0e97zv1fsOo9X2n3vePel9HQfS2225LZ555ZnHrlsWLF6cPf/jD6bDDDkvLly+vddNK6cEHH0wzZsxICxcuTPfff396//3306GHHprefvvtWjdtUHj88cfT9ddfn/bcc89aN6XU3njjjTRlypS0ySabpHvvvTc9++yz6etf/3rafPPNa9200rr88svTtddem775zW+mX/ziF8XXX/3qV9PVV19d66ZBKaj3/aPerz+1vu/U+/5T7+vo9i3RAxo9fHHyFtra2lJLS0s69dRT09lnn13r5pXeihUrip7RKFgHHXRQrZtTam+99Vb6yEc+kr71rW+liy++OO21117pqquuqnWzSin+7f30pz9NDz/8cK2bMmgcccQRaeutt0433nhj+7Zjjjmm6B29+eaba9o2KAP1fsOo932j1vePet9/6n2d9Ii+99576YknnkhTp05t39bQ0FB8vWDBgpq2bbBYtWpV8ecWW2xR66aUXvQkT5s2rdPnje7dfffdad99903HHntscaFj7733TjfccIPdtQ4HHnhgmj9/flqyZEnx9VNPPZUeeeSRdPjhh9tvDHnq/YZT7/tGre8f9b7/1PvujUiDzOuvv16Ms45ehI7i6+eee65m7Rosovc45jnGEMrJkyfXujmlduuttxZDv2O4Dr178cUXi2GmMWz+3HPPLfbbaaedlkaOHJlOPPFEu7CHq8qtra1p0qRJafjw4cWx7ZJLLknHH3+8/cWQp95vGPW+b9T6/lPv+0+9r5MgyoZf9XvmmWeKXhd6tnTp0jRz5sxiTm0siEXfTnqiR/TSSy8tvo4e0fisXXfddYJoD26//fY0d+7cNG/evLT77runn/3sZ8WFou22284+AzaIet87tX79qPf9p97XSRDdcssti56D1157rdP2+HqbbbapWbsGg1NOOSXdc8896aGHHkrbb799rZtTajH8Oxa/ivmhVdFbFfsu5iavXr26+Bzyf7bddtu02267ddolu+66a/rBD35gN/Xgi1/8YnGV9LOf/Wzxdawy/NJLLxUrX+pFZqhT79efet83av36Ue/7T72vkzmiMcxvn332KeZVdbwyE18fcMABNW1bWcV6VFGU7rjjjvTjH/+4uFUE63bIIYekp59+uuihqj6ity+GTMb/C6Fri+HeXW8LFHMfd9hhBx+3HrzzzjvFHPeO4rMVxzQY6tT7/lPv+0etXz/qff+p93XSIxpiDlr0FkQw2G+//YpVTONWJNOnT69100o7PCeG/t11113FvUSXLVtWbG9qaipW52RtsZ+6zqHdbLPNivtjmlvbvTPOOKOYjB9Dcz/zmc8U9/adPXt28aB7Rx55ZDEndMKECcXQ3CeffDJdeeWV6aSTTrLLQL1X7weYWr9+1Pv+U+97UBmkrr766sqECRMqI0eOrOy3336VhQsX1rpJpRVvc3ePOXPm1Lppg8rBBx9cmTlzZq2bUWo//OEPK5MnT66MGjWqMmnSpMrs2bNr3aRSa21tLT5TcSwbPXp0Zaeddqr83d/9XWX16tW1bhqUhnrfd+r9hlPr+0a97x/1vnuD8j6iAAAADF6Dbo4oAAAAg5sgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAApJz+P59sFCkwoNNEAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1200x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1, 2, figsize=(12, 5))\n",
    "axs[0].imshow(gt_graph>0.001, cmap='bwr', vmin=-0.5, vmax=0.5)\n",
    "axs[0].set_title(\"True Graph\")\n",
    "axs[1].imshow(B_est>0.01, cmap='bwr', vmin=-1, vmax=1)\n",
    "axs[1].set_title(\"LLC Estimated Graph\")\n",
    "shd = compute_shd(gt_graph>0.001, B_est > 0.0)\n",
    "print(f\"SHD between true and estimated graph: {shd[0]}\")\n",
    "auprc = compute_auprc(gt_graph>0.001, B_est)\n",
    "print(f\"AUPRC between true and estimated graph: {auprc[1]}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d6371891",
   "metadata": {},
   "source": [
    "Define and train BACKSHIFT model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "62c34e67",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "R callback write-console: \n",
      "Attaching package: ‘igraph’\n",
      "\n",
      "  \n",
      "R callback write-console: The following objects are masked from ‘package:stats’:\n",
      "\n",
      "    decompose, spectrum\n",
      "\n",
      "  \n",
      "R callback write-console: The following object is masked from ‘package:base’:\n",
      "\n",
      "    union\n",
      "\n",
      "  \n"
     ]
    }
   ],
   "source": [
    "X_list = []\n",
    "ExpInd = []\n",
    "for exp_idx, dataset in enumerate(datasets):\n",
    "    X_list.append(dataset)\n",
    "    ExpInd.extend([exp_idx + 1] * dataset.shape[0])\n",
    "X = np.vstack(X_list)\n",
    "ExpInd = np.array(ExpInd)\n",
    "with (robjects.default_converter + numpy2ri.converter).context():\n",
    "    robjects.r('library(igraph)')\n",
    "    robjects.r('library(clue)')    \n",
    "    bsdir = \"./baselines/backShift-master/R\"\n",
    "    source_order = [\n",
    "        \"ffdiag.R\", \"computeVarEnv.R\", \"computeDelta.R\", \"hasCycles.R\", \n",
    "        \"generateA.R\", \"edgeSelection.R\", \"addCycle.R\", \"permuteAndScale.R\",\n",
    "        \"checkDiagonalization.R\", \"bootstrap.R\", \"metrics.R\", \"plotting_helpers.R\",\n",
    "        \"plotGraph.R\", \"plotInterventionVar.R\", \"simulate.R\", \"backShift.R\"\n",
    "    ]\n",
    "    for r_file in source_order:\n",
    "        file_path = os.path.join(bsdir, r_file)\n",
    "        robjects.r(f'source(\"{file_path}\")')    \n",
    "    so_path = \"./baselines/backShift-master/src/backShift.so\"\n",
    "    robjects.r(f'dyn.load(\"{so_path}\")')\n",
    "    robjects.globalenv['X_data'] = X\n",
    "    robjects.globalenv['ExpInd_vec'] = robjects.IntVector(ExpInd)\n",
    "    robjects.r('''\n",
    "    result <- backShift(X_data, ExpInd_vec, covariance=TRUE, verbose=FALSE)\n",
    "    ''')\n",
    "    Ahat = np.array(robjects.r('result$Ahat'))\n",
    "    Learned_interv = np.array(robjects.r('result$varianceEnv'))\n",
    "    robjects.r('''\n",
    "    result_verify <- backShift(X_data, ExpInd_vec, covariance=TRUE, verbose=FALSE, baseSettingEnv=2)\n",
    "    ''')\n",
    "    Learned_inter_verify = np.array(robjects.r('result_verify$varianceEnv'))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "54fb8c31",
   "metadata": {},
   "source": [
    "Plot the ground truth and learned adjacencies as well as the SHD and AUPRC score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "9c141665",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SHD between true and estimated graph: 31.0\n",
      "AUPRC between true and estimated graph: 0.16091118243706914\n"
     ]
    },
    {
     "data": {
      "image/png": "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//nP09ixY4uplAEYOuKKYWvXrk3jx49PDQ2OhdYrtR5g6Kr0stZnD6IRQidMmJD7bQEokRUrVqQdd9yx1s1ggKj1AKzYQK3PHkSjJzSsePnl1NjYmEqnuTmV0urVtW4B1FZZ/zbLrITbjZaWljRhp53aagH1qfS1vqzKup0r4bakjXVWP+uMutGSUopuxw3V+uxBtDocNwqT4tQHCjlQR9sNp2bUN7W+zpR4W1Ja1hmkDdV6J+gAAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAACUP4hed911aZdddkmjR49OBx10UHriiSf6v2UAQM2o9QCUKojefvvt6fzzz0+XXnppWrp0adp7773TMccck1577bWBaSEAkJVaD0DpgujVV1+dzjjjjDR9+vQ0efLkdP3116fNN988/f3f//3AtBAAyEqtB6BUQfSdd95JTz75ZDrqqKN++QINDcX9hQsXDkT7AICM1HoAchjRlwe//vrraf369Wm77bbrsDzuL1u2rNvnrFu3rrhVtbS0bGxbAYABptYDUBez5s6ePTs1NTW13SZMmDDQbwkAZKTWAzCgQXTrrbdOw4cPT6+++mqH5XF/++237/Y5F110UVqzZk3bbcWKFX1uJACQh1oPQOmC6MiRI9N+++2XHnzwwbZlra2txf2DDz642+eMGjUqNTY2drgBAOWk1gNQunNEQ1y65dRTT037779/OvDAA9M111yT3nrrrWIWXQBg8FPrAShdEP3kJz+ZVq1alT7zmc+klStXpn322Sd997vf7TKBEQAwOKn1AAy0YZVKpZIyillzY9KiNatXl3OYbsOAz9+0cVpba90CqK2y/m2WWQm3G0UNaG4u5gwoZQ1gaNT6sirrdq6E25I21ln9rDPqRlwjpSmlDdZ630QAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsRuR9u0GgtbXWLaC/NDjOslH8DVhn0F+am8u3Lm3j6ktZP0/7IPWlrN+zsmpp6dX23546AAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigA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AEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWY3I+3aDQGtrrVsAAAyUBsfgGeLK+jdQ5n3wsq6zQc5aBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKxGpFppbk6l1Npa6xYAQH1YvTqlxsZUKg2OwUMplflvs6z5oKHE66wXBnfrAQAAGHQEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAAMobRNevX59mzpyZJk6cmMaMGZN22223NGvWrFSpVAauhQBANmo9ADmM6MuDr7zyyjRnzpx00003pT333DMtWbIkTZ8+PTU1NaWzzz574FoJAGSh1gNQuiD6+OOPp4997GNp6tSpxf1ddtkl3XrrremJJ54YqPYBABmp9QCUbmjuIYcckh588MG0fPny4v7TTz+dHnvssXTssccOVPsAgIzUegBK1yN64YUXppaWljRp0qQ0fPjw4jySz3/+82natGk9PmfdunXFrSqeDwCUk1oPQOl6RO+44450yy23pPnz56elS5cW54peddVVxc+ezJ49uziHtHqbMGFCf7QbABgAaj0AOQyr9GHK2wiRcaR0xowZbcsuu+yydPPNN6dly5b1ukc0XmdNSqkxlVBra61bAFC3ogY0NTenNWvWpMbGUlaBIa9fa/3q1eX7nBtcua6u9o18ngzlv4GGcm7PYvxrU0obrPV9Gpr79ttvp4ZOv3AM0W19jw9n1KhRxQ0AKD+1HoAc+hREjz/++OKc0J122qm4fMtTTz2Vrr766nT66acPXAsBgGzUegBKNzR37dq1aebMmWnBggXptddeS+PHj0+f+tSn0mc+85k0cuTI3g/LamoyNBdgCDI0t/z6tdYbmlsfyjosscRDE6kzZf0baBjcQ3P7FET7pWGCKMCQJYgODYJonSnrTniJd8SpM2X9G2gY3EG0nK0HAACgbgmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAViPyvh0AMGQ0N9e6BQD1q7U1lVJLS6+2/3pEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyGpE3rdLqVKpFD9bUkm1lLZlAINey//fxlZrAfWp9LWevrFvxFDnb2BAan32ILp27dri54RUUs3NtW4BQN2LWtDU1FTrZjBUaz19Y9+Ioc7fwIDU+mGVzIelW1tb089//vM0duzYNGzYsE1O2xMmTEgrVqxIjY2N/dbGemadWWe+Z+U0VP42o+REYRo/fnxqaHB2SL1S62trqGxP+pN1Zp35nuWv9dl7RKMxO+64Y7++ZmxkbWits4Hme2ad5TAUvmd6QuufWl8OQ2F70t+sM+vM9yxfrXc4GgAAgKwEUQAAALIa1EF01KhR6dJLLy1+Yp35npWHv03rDGxPbIMHE3XLOvM9yy/7ZEUAAAAMbYO6RxQAAIDBRxAFAAAgK0EUAACArARRAAAAshq0QfS6665Lu+yySxo9enQ66KCD0hNPPFHrJpXW7Nmz0wEHHJDGjh2btt1223TCCSek559/vtbNGlSuuOKKNGzYsHTuuefWuiml9sorr6RTTjkljRs3Lo0ZMybttddeacmSJbVuVmmtX78+zZw5M02cOLFYX7vttluaNWtWMocc/JJ633vq/aZR63tPve8b9b6Ogujtt9+ezj///OLSLUuXLk177713OuaYY9Jrr71W66aV0sMPP5xmzJiRFi1alB544IH07rvvpqOPPjq99dZbtW7aoLB48eJ0ww03pA984AO1bkqpvfHGG+nQQw9Nm222WbrvvvvST37yk/SlL30pbbnllrVuWmldeeWVac6cOekrX/lKeu6554r7X/jCF9K1115b66ZBKaj3faPebzy1vvfU+75T7+vo8i3RAxo9fLHzFlpbW9OECRPSWWedlS688MJaN6/0Vq1aVfSMRsE67LDDat2cUnvzzTfTBz/4wfTVr341XXbZZWmfffZJ11xzTa2bVUrxt/fDH/4wPfroo7VuyqBx3HHHpe222y59/etfb1v28Y9/vOgdvfnmm2vaNigD9X7TqPe9o9b3jXrfd+p9nfSIvvPOO+nJJ59MRx11VNuyhoaG4v7ChQtr2rbBYs2aNcXPrbbaqtZNKb3oSZ46dWqH7xvdu/fee9P++++fTjrppOJAx7777pvmzp1rdb2HQw45JD344INp+fLlxf2nn346PfbYY+nYY4+13hjy1PtNp973jlrfN+p936n33RuRBpnXX3+9GGcdvQjtxf1ly5bVrF2DRfQex3mOMYRyypQptW5Oqd12223F0O8YrsOGvfjii8Uw0xg2f/HFFxfr7eyzz04jR45Mp556qlXYw1HllpaWNGnSpDR8+PBi2/b5z38+TZs2zfpiyFPvN4163ztqfd+p932n3tdJEGXTj/o9++yzRa8LPVuxYkU655xzinNqY0IserfTEz2il19+eXE/ekTju3b99dcLoj2444470i233JLmz5+f9txzz/SjH/2oOFA0fvx46wzYJOr9hqn1G0e97zv1vk6C6NZbb130HLz66qsdlsf97bffvmbtGgzOPPPM9J3vfCc98sgjaccdd6x1c0othn/H5FdxfmhV9FbFuotzk9etW1d8D/mlHXbYIU2ePLnDKtljjz3SnXfeaTX14NOf/nRxlPTkk08u7scswy+99FIx86VeZIY69X7jqfe9o9ZvHPW+79T7OjlHNIb57bfffsV5Ve2PzMT9gw8+uKZtK6uYjyqK0oIFC9L3v//94lIRvLcjjzwyPfPMM0UPVfUWvX0xZDL+LYR2FcO9O18WKM593HnnnX3devD2228X57i3F9+t2KbBUKfe95163zdq/cZR7/tOva+THtEQ56BFb0EEgwMPPLCYxTQuRTJ9+vRaN620w3Ni6N8999xTXEt05cqVxfKmpqZidk66ivXU+RzaLbbYorg+pnNru3feeecVJ+PH0NxPfOITxbV9b7zxxuJG944//vjinNCddtqpGJr71FNPpauvvjqdfvrpVhmo9+r9AFPrN45633fqfQ8qg9S1115b2WmnnSojR46sHHjggZVFixbVukmlFR9zd7d58+bVummDyuGHH14555xzat2MUvv2t79dmTJlSmXUqFGVSZMmVW688cZaN6nUWlpaiu9UbMtGjx5d2XXXXSuXXHJJZd26dbVuGpSGet976v2mU+t7R73vG/W+e4PyOqIAAAAMXoPuHFEAAAAGN0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAABIOf0/lsrmmVekdTsAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1200x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1, 2, figsize=(12, 5))\n",
    "axs[0].imshow(gt_graph>0.001, cmap='bwr', vmin=-0.5, vmax=0.5)\n",
    "axs[0].set_title(\"True Graph\")\n",
    "axs[1].imshow(Ahat>0.01, cmap='bwr', vmin=-1, vmax=1)\n",
    "axs[1].set_title(\"BACKSHIFT Estimated Graph\")\n",
    "shd = compute_shd(gt_graph>0.001, Ahat > 0.1)\n",
    "print(f\"SHD between true and estimated graph: {shd[0]}\")\n",
    "auprc = compute_auprc(gt_graph>0.001, Ahat)\n",
    "print(f\"AUPRC between true and estimated graph: {auprc[1]}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "48b06168",
   "metadata": {},
   "source": [
    "Plot the ground truth and learned intervention targets as well as the SHD and AUPRC score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "37dd2b43",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SHD between true and estimated graph: 9.0\n",
      "AUPRC between true and estimated graph: 0.9759615384615383\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA6IAAAHDCAYAAAA+z6dRAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAMMRJREFUeJzt3QucneOdB/BnksgFmVlEkAoJtRsEQbDosl1KrdpSpSy7Gq3dtnFvFe0HVZe4FV1131Jd4tK1rl1UqVtJXeK6LWq15MNGpDRDtEHm7Of/7p7pzMlMMmcuz7wz+X4/nyPmzJnzPuc557z/9/c+z/u+DZVKpZIAAAAgkyG5FgQAAABBEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQhUHq85//fJowYUJ/NwOAQeCv//qvixv6tV6xLfKpT32q1zruvvvuSw0NDenf//3fu7UtFH/7rW99q/XnH/zgB8V9v/3tb7u87PiXnhNEKb5QXbn195cuCuDkyZO79bcPP/xwsdL5/e9/nwaT119/vXhdTz31VCqTN998Mx1xxBFp0qRJadSoUWns2LFp6623Tscee2x69913636+wfr+AQNLdYP18ccf7++mDMrQ8Z//+Z/tAsJg8ctf/rJ4XV0JOrlUA1X1tsIKK6T11lsv/eM//mN6+eWX0/LuoosuKr7v9K1hffz8DAD/9m//1u7nH/7wh+nuu+9e4v4NN9wwDVQRZE4++eRiz9if/dmfpcEURON1ReGfMmVKu99dfvnlqaWlJXub3nrrrTR16tTU3NycDj744CKM/u53v0vPPPNMuvjii9OXv/zltPLKK9f1nIP1/QOgfRC98MILB10YjSAaNSx2qNeOzv3kJz9J/enwww9PW221Vfrggw/S7Nmz02WXXZZ+/OMfp2effTaNGzcuDXRd2Rb6h3/4h7TffvulESNGtAuiY8aMKbY72tphhx3SH/7whzR8+PA+a/PyRBAlHXjgge16YdasWUUQrb2/1nvvvZdWXHHF5boHy9wHsXezP3z/+99Pr776avr5z3+etttuu3a/i3Bq5Q3QMx9++GGxcW19umyVSiX98Y9/LGbnlFF/v4d/9Vd/lT772c8W/z9t2rT053/+50U4veqqq9Lxxx/f4d8sXLgwrbTSSmkg6Mq20NChQ4tbVwwZMiSNHDmyF1pG0Z+6gXqmxT7xxBPF3qAIX9/4xjc6nGtfFXv9avckxdTKI488Mo0fP77Y8/TRj340nXnmmd0euYtlH3rooenmm28u2hfPufHGG6c777yz9THRtmOOOab4/4kTJ7ZOQ2k7Rebqq69OW265ZVGoVl111WLP2Jw5c7rUBzEFKaazdGTbbbctRgfbqmdZsRf14x//eLGsj3zkI+mss85qN60m9mJWi0f1dVWnknR0XEQUj69+9aut/f8Xf/EX6ZxzzikKdb392pn//u//Llbof/mXf7nE7xobG5dYgf/iF79In/zkJ1NTU1PxOnfccccixHb1/YudJh/72MeKkdIYaY3XVP1sAvSH1157rZgRssYaa7SuP6+44op2j3n//ffTiSeeWNSDWP/Fhn2Egp/97GftHhfruljnxbr6/PPPT+uvv37xnNXpnvG7l156qXXGSDxX1ITYUVqrK/UnxKhYLCceF4dVPPjgg93ui7btrz5vtD/q12OPPdb6uGh/jIaGtlNGq2I7IV5/9GXUkejbf/7nf05vv/12h1OD77rrrqL+xmu49NJLi1oW9bRWPG/U12oY686yHnrooaKf4rGxPRAzy6qiJu+zzz7F/8fyaw936ujY23nz5qUvfOELxXLjOTfbbLMiGHanX+v1N3/zN8W/v/nNb4p/q5+x+Lz9/d//fVpllVWKmlvdIXLKKae0Ljv6I+rvokWLOnzuGP2N2VvxmjbaaKP0H//xH0vMqPra176WNtlkk6KexzbDbrvtlp5++ukOn2/x4sXF8tZcc83i+/N3f/d3S3yeu3K+jNpjROPx//Vf/5Xuv//+1ver+h51dozosrZlwjvvvFNsA8fzR3+NHTs2feITnyhGopdXRkTpspheGSuEKFwxWhoryHpEUYwvZhToWKGvs846xZTL2OP2P//zP8VKvzuiAMTK7Ctf+UoaPXp0+pd/+Ze09957F6Nyq622WvrMZz6TXnzxxXTttdem8847r5hqEVZfffXi39NOOy2dcMIJad99901f/OIXi+MbL7jggiJsPvnkk+2mgnbUB1HU45iKWPFXg2F45ZVXitHls88+u/W+epYVBS9WatH+eHwclB/HWMYKOtoQU6W//e1vFxsy//RP/1RswITaUciqCJuxko6NnChwUQyiUEfIi/ck+qaefu3MuuuuWxSH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bJIef/zxvmkdAJCdWg9AXxtWz4PffvvttP3226ePf/zj6Y477kirr756+vWvf51WWWWVvmshAJCNWg9A6YLomWeemcaPH5+uvPLK1vsmTpzYF+0CAPqBWg9A6abm3nrrrWnq1Klpn332SWPHjk2bb755uvzyy/uudQBAVmo9AKULoi+//HK6+OKL0wYbbJDuuuuu9OUvfzkdfvjh6aqrrur0bxYtWpSam5vb3QCAclLrAcihoVKpVLr64OHDhxcjog8//HDrfRFEH3vssfTII490+Dff+ta30sknn9zBbxaklBq712qgz1RSQyl7tyF1eVVFqcXOyKa0YMGC1NioBpSRWg+D24cfplIaVtcBg3lNmJBK6be/TQO61tc1IrrWWmuljTbaqN19G264YXr11Vc7/Zvjjz++aET1NmfOnHoWCQBkpNYDkENd+x7ijLkvvPBCu/tefPHFtO6663b6NyNGjChuAED5qfUA5FDXiOhRRx2VZs2alU4//fT00ksvpZkzZ6bLLrssTZ8+ve9aCABko9YDULpjRMPtt99eTLeN64fGpVuOPvrodMghh3T57+NkRU1NTY4RhZJyjCh9yzGiA4FaD4OXY0Tr5xjRvqn1dQfRnhJEodwEUfqWILo8UOuhvATR+gmiJThZEQAAAPSUIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQ1LO/igLJrSJVURpXUkMqqrH0G0Bs++cny9uNPf5pK6cMPU2kNK+nW/8MPp9Lac8/+bsHgZEQUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyEkQBAADIShAFAAAgK0EUAACArARRAAAAshqWd3EA3dOQKqXtukpqSGVU5j4DBo5HH02l9eGH/d2CgWf48FRK222XSqulJZXSkAE+pDjAmw8AAMBAI4gCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAABQ3iC6ePHidMIJJ6SJEyemUaNGpfXXXz+dcsopqVKp9F0LAYBs1HoAchhWz4PPPPPMdPHFF6errroqbbzxxunxxx9P06ZNS01NTenwww/vu1YCAFmo9QCULog+/PDD6dOf/nTafffdi58nTJiQrr322vToo4/2VfsAgIzUegBKNzV3u+22S/fcc0968cUXi5+ffvrp9NBDD6Xddtutr9oHAGSk1gNQuhHR4447LjU3N6dJkyaloUOHFseRnHbaaemAAw7o9G8WLVpU3Kri7wGAclLrASjdiOgNN9yQrrnmmjRz5sw0e/bs4ljRc845p/i3MzNmzCiOIa3exo8f3xvtBgD6gFoPQA4NlTpOeRshMvaUTp8+vfW+U089NV199dXp+eef7/KI6P+F0QUppcaeth+g31VSQyqjhlTGM5rHrJimtGDBgtTYqAaUkVpPrVVXLW+fvPVWf7dg4Bk+PJXS+++n0mppSaU0pLQX4uxara9rau57772XhtS84pii27KUd2fEiBHFDQAoP7UegBzqCqJ77LFHcUzoOuusU1y+5cknn0znnntuOvjgg/uuhQBANmo9AKWbmvvOO++kE044Id10001p3rx5ady4cWn//fdPJ554YhrexXH+mJobx4qamgsMFqbm1sPU3LJT66llau7gYmpu/UzN7ZtaX1cQ7Q2CKDDYCKL1EESXB2r94CKIDi6CaP0E0b6p9aU9xBUAAIDBSRAFAAAgK0EUAACArARRAAAAshJEAQAAyEoQBQAAICtBFAAAgKwEUQAAALISRAEAAMhKEAUAACArQRQAAICsBFEAAACyGpZ3cQCDT0OqpDKqpIZUNs0ppab+bgRQl7feKm+HDSnpkEpLSyqt99/v7xYMPI2NqZRmzUqltHBhSjvttOzHlfTrCwAAwGAliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAABZCaIAAABkJYgCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQ1LO/iUqpUKv//f825Fw2wXGkucZv+VAsYjNR68n3W9DXL7+ds4cJUSgsXNnep1mcPou+8887//9/43IsGWK40pfKKWtDUVOYW0hNqPct7QGBwKWvg22mnVGrLqvUNlcy7pVtaWtLrr7+eRo8enRoaGnr0XM3NzWn8+PFpzpw5qbGxsdfaOJjpM33mc1ZOy8t3M0pOFKZx48alIUMcHTJYqfX9a3lZn/QmfabPfM7y1/rsI6LRmLXXXrtXnzNWsla0+qyv+ZzpsxyWh8+ZkdDBT60vh+VhfdLb9Jk+8znLV+vtjgYAACArQRQAAICsBnQQHTFiRDrppJOKf9FnPmfl4bupz8D6xDp4IFG39JnPWX7ZT1YEAADA8m1Aj4gCAAAw8AiiAAAAZCWIAgAAkJUgCgAAQFYDNoheeOGFacKECWnkyJFpm222SY8++mh/N6m0ZsyYkbbaaqs0evToNHbs2LTnnnumF154ob+bNaCcccYZqaGhIR155JH93ZRSe+2119KBBx6YVltttTRq1Ki0ySabpMcff7y/m1VaixcvTieccEKaOHFi0V/rr79+OuWUU5JzyMGfqPddp973jFrfdep9fdT7QRREr7/++nT00UcXl26ZPXt22myzzdKuu+6a5s2b199NK6X7778/TZ8+Pc2aNSvdfffd6YMPPki77LJLWrhwYX83bUB47LHH0qWXXpo23XTT/m5Kqb399ttp++23TyussEK644470i9/+cv0ne98J62yyir93bTSOvPMM9PFF1+cvve976Vf/epXxc9nnXVWuuCCC/q7aVAK6n191PvuU+u7Tr2vn3o/iC7fEiOgMcIXG2+hpaUljR8/Ph122GHpuOOO6+/mld6bb75ZjIxGwdphhx36uzml9u6776YtttgiXXTRRenUU09NU6ZMSeeff35/N6uU4rv385//PD344IP93ZQB41Of+lRaY4010ve///3W+/bee+9idPTqq6/u17ZBGaj3PaPed41aXx/1vn7q/SAZEX3//ffTE088kXbeeefW+4YMGVL8/Mgjj/Rr2waKBQsWFP+uuuqq/d2U0ouR5N13373d542O3XrrrWnq1Klpn332KXZ0bL755unyyy/XXUux3XbbpXvuuSe9+OKLxc9PP/10euihh9Juu+2m31juqfc9p953jVpfH/W+fup9x4alAWb+/PnFPOsYRWgrfn7++ef7rV0DRYwex3GOMYVy8uTJ/d2cUrvuuuuKqd8xXYdle/nll4tppjFt/hvf+EbRb4cffngaPnx4Ouigg3RhJ3uVm5ub06RJk9LQoUOLddtpp52WDjjgAP3Fck+97xn1vmvU+vqp9/VT7wdJEKXne/2ee+65YtSFzs2ZMycdccQRxTG1cUIsurbREyOip59+evFzjIjGZ+2SSy4RRDtxww03pGuuuSbNnDkzbbzxxumpp54qdhSNGzdOnwE9ot4vm1rfPep9/dT7QRJEx4wZU4wcvPHGG+3uj5/XXHPNfmvXQHDooYem22+/PT3wwANp7bXX7u/mlFpM/46TX8XxoVUxWhV9F8cmL1q0qPgc8idrrbVW2mijjdp1yYYbbphuvPFG3dSJY445pthLut9++xU/x1mGX3nlleLMl0aRWd6p992n3neNWt896n391PtBcoxoTPPbcssti+Oq2u6ZiZ+33Xbbfm1bWcX5qKIo3XTTTenee+8tLhXB0u20007p2WefLUaoqrcY7Yspk/H/QuiSYrp37WWB4tjHdddd18etE++9915xjHtb8dmKdRos79T7+qn39VHru0e9r596P0hGREMcgxajBREMtt566+IspnEpkmnTpvV300o7PSem/t1yyy3FtUTnzp1b3N/U1FScnZMlRT/VHkO70korFdfHdGxtx4466qjiYPyYmrvvvvsW1/a97LLLihsd22OPPYpjQtdZZ51iau6TTz6Zzj333HTwwQfrMlDv1fs+ptZ3j3pfP/W+E5UB6oILLqiss846leHDh1e23nrryqxZs/q7SaUVb3NHtyuvvLK/mzag7LjjjpUjjjiiv5tRarfddltl8uTJlREjRlQmTZpUueyyy/q7SaXW3NxcfKZiXTZy5MjKeuutV/nmN79ZWbRoUX83DUpDve869b7n1PquUe/ro953bEBeRxQAAICBa8AdIwoAAMDAJogCAACQlSAKAABAVoIoAAAAWQmiAAAAZCWIAgAAkJUgCgAAQFaCKAAAAFkJogAAAGQliAIAAJCVIAoAAEBWgigAAAApp/8Fd8UZd3r/48gAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1200x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "Learned_interv[0, :] = Learned_interv[0, :] + Learned_inter_verify[0, :]\n",
    "fig, axs = plt.subplots(1, 2, figsize=(12, 5))\n",
    "axs[0].imshow(intervention_sets_array, cmap='bwr', vmin=0, vmax=1)\n",
    "axs[0].set_title(\"True Intervention Sets\") \n",
    "axs[1].imshow(Learned_interv, cmap='bwr', vmin=0, vmax=1)\n",
    "axs[1].set_title(\"Learned Intervention Probabilities\")\n",
    "shd = compute_shd(intervention_sets_array>0.001, Learned_interv > 0.5)\n",
    "print(f\"SHD between true and estimated graph: {shd[0]}\")\n",
    "auprc = compute_auprc(intervention_sets_array>0.001, Learned_interv)\n",
    "print(f\"AUPRC between true and estimated graph: {auprc[1]}\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "test_scout",
   "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.11.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
