{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "97a4ef07-c12f-479b-a079-8f96df77bb5d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import utils\n",
    "import models\n",
    "\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "\n",
    "import networkx as nx\n",
    "from scipy.spatial import distance\n",
    "\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "from tqdm import tqdm\n",
    "\n",
    "from concurrent.futures import ThreadPoolExecutor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ff215fb5-7b92-423f-bed6-27815256e3cb",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.manual_seed(0)\n",
    "np.random.seed(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "9287f480-9dba-43f9-82fb-292445f0c76d",
   "metadata": {},
   "outputs": [],
   "source": [
    "lr = 0.00002\n",
    "latent_dim = 200\n",
    "dev = 'cpu'\n",
    "eps = 0.2\n",
    "alpha_kl = 0.01\n",
    "dim_X = 50"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "2d743919-4bba-4b36-b57b-5d7d15ec4ed1",
   "metadata": {},
   "outputs": [],
   "source": [
    "nodes = np.array([\n",
    "    [1, 16.47, 96.10],\n",
    "    [2, 16.47, 94.44],\n",
    "    [3, 20.09, 92.54],\n",
    "    [4, 22.39, 93.37],\n",
    "    [5, 25.23, 97.24],\n",
    "    [6, 22.00, 96.05],\n",
    "    [7, 20.47, 97.02],\n",
    "    [8, 17.20, 96.29],\n",
    "    [9, 16.30, 97.38],\n",
    "    [10, 14.05, 98.12],\n",
    "    [11, 16.53, 97.38],\n",
    "    [12, 21.52, 95.59],\n",
    "    [13, 19.41, 97.13],\n",
    "    [14, 20.09, 94.55]\n",
    "])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0bd05048-fbff-4c11-a6fb-866605fb5ed0",
   "metadata": {},
   "outputs": [],
   "source": [
    "N = len(nodes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "597e0942-f0ea-4a27-85c0-9013aacca76d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def fill_G_weights(N, G, dists):\n",
    "    for i in range(1,N):\n",
    "        for j in range(0,i):\n",
    "            G[i][j]['weight'] = dists[i,j]\n",
    "    return G\n",
    "\n",
    "\n",
    "def edges_matrix_to_vector(N, edges):\n",
    "    upper_triangle_indices = np.triu_indices(N, k=1)\n",
    "    edge_to_index = {(i, j): idx for idx, (i, j) in enumerate(zip(*upper_triangle_indices))}\n",
    "    binary_vector = np.zeros(len(upper_triangle_indices[0]), dtype=int)\n",
    "    \n",
    "    for edge in edges:\n",
    "        i, j = sorted(edge)\n",
    "        if (i, j) in edge_to_index:\n",
    "            binary_vector[edge_to_index[(i, j)]] = 1\n",
    "            \n",
    "    return binary_vector"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3e7a0675-6c49-4b21-8b64-cc6919b20c9d",
   "metadata": {},
   "outputs": [],
   "source": [
    "positions = nodes[:,1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f579cb48-da9b-4a66-b82b-2cd377a1e3bd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f12771b1bb0>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(positions[:,0], positions[:,1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "eade4449-81a2-4b06-ba69-73c00962cf49",
   "metadata": {},
   "outputs": [],
   "source": [
    "euc_dists = distance.cdist(positions, positions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "37f828a3-c684-416b-a01f-504e4098e6b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "G = nx.complete_graph(N)\n",
    "G = fill_G_weights(N, G, euc_dists)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "e5a3327a-d17c-4686-8658-a938ecfe197b",
   "metadata": {},
   "outputs": [],
   "source": [
    "tsp = nx.approximation.traveling_salesman_problem"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "77e6fdb0-f956-4a78-919f-ad839c71c800",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0, 1, 2, 13, 11, 5, 4, 3, 6, 12, 7, 9, 8, 10, 0]"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tsp(G)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "760a4881-91e7-4471-9c84-03cc5b6a7d18",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_samples = 800\n",
    "N_train = 500\n",
    "\n",
    "def nonlinear_relationship_vectorized(X):\n",
    "    # X has shape (num_samples, N, dim_X)\n",
    "    # Compute pairwise differences, dot products, and norms in a vectorized way\n",
    "    X1 = X[:, :, None, :]  # Shape: (num_samples, N, 1, dim_X)\n",
    "    X2 = X[:, None, :, :]  # Shape: (num_samples, 1, N, dim_X)\n",
    "    \n",
    "    diff = np.abs(X1 - X2)  # Shape: (num_samples, N, N, dim_X)\n",
    "    dot_product = np.sum(X1 * X2, axis=-1)  # Shape: (num_samples, N, N)\n",
    "    norm_sum = np.linalg.norm(X1, axis=-1) + np.linalg.norm(X2, axis=-1)  # Shape: (num_samples, N, N)\n",
    "    \n",
    "    return np.tanh(dot_product / norm_sum) + np.sin(np.sum(diff, axis=-1)**2)  # Shape: (num_samples, N, N)\n",
    "\n",
    "def solver_tsp(G, weights, n_edges):\n",
    "    n_samples = weights.shape[0]\n",
    "    edges_used = np.zeros((n_samples, n_edges))\n",
    "    for k in range(n_samples):\n",
    "        G = nx.complete_graph(N)\n",
    "        G = fill_G_weights(N, G, weights[k])\n",
    "        nodes_approx = tsp(G)\n",
    "        edges_approx = np.array([[nodes_approx[i], nodes_approx[i + 1]] for i in range(len(nodes_approx) - 1)])\n",
    "        edges_used[k] = edges_matrix_to_vector(N, edges_approx)\n",
    "    return edges_used, nodes_approx\n",
    "\n",
    "\n",
    "def solve_tsp_parallel(G, weights, n_edges):\n",
    "    def process_sample(k):\n",
    "        G = nx.complete_graph(N)\n",
    "        G = fill_G_weights(N, G, weights[k])\n",
    "        nodes_approx = tsp(G)\n",
    "        edges_approx = np.array([[nodes_approx[i], nodes_approx[i + 1]] for i in range(len(nodes_approx) - 1)])\n",
    "        edges_vector = edges_matrix_to_vector(N, edges_approx)\n",
    "        return edges_vector, nodes_approx\n",
    "\n",
    "    n_samples = weights.shape[0]\n",
    "    edges_used = np.zeros((n_samples, n_edges))\n",
    "    nodes_approx_all = [None] * n_samples\n",
    "\n",
    "    with ThreadPoolExecutor() as executor:\n",
    "        results = list(executor.map(process_sample, range(n_samples)))\n",
    "\n",
    "    for k, (edges_vector, nodes_approx) in enumerate(results):\n",
    "        edges_used[k] = edges_vector\n",
    "        nodes_approx_all[k] = nodes_approx\n",
    "\n",
    "    return edges_used, nodes_approx_all\n",
    "\n",
    "\n",
    "X_all = np.random.rand(num_samples, N, dim_X)  # Shape: (num_samples, N, dim_X)\n",
    "\n",
    "adj_matrices = nonlinear_relationship_vectorized(X_all)  # Shape: (num_samples, N, N)\n",
    "\n",
    "Y = np.zeros((num_samples, N, N))\n",
    "for i in range(num_samples):\n",
    "    np.fill_diagonal(adj_matrices[i], 0)\n",
    "    Y[i] = adj_matrices[i] + np.expand_dims(euc_dists, 0) \n",
    "    Y[i] = Y[i] - Y[i].min() + 0.1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "87570c94-82fc-416d-b9d5-68ca18306756",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_edges = N*(N-1)//2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "09ac2ceb-da2b-4985-b8fb-6473b12e6d9e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████| 400/400 [00:00<00:00, 405.12it/s]\n"
     ]
    }
   ],
   "source": [
    "paths_cost = np.zeros((num_samples,))\n",
    "edges_used = np.zeros((num_samples,n_edges))\n",
    "for k in tqdm(range(num_samples)):\n",
    "    G = fill_G_weights(N, G, Y[k])\n",
    "    nodes_approx = tsp(G)\n",
    "    edges_approx = np.array([[nodes_approx[i], nodes_approx[i + 1]] for i in range(len(nodes_approx) - 1)])\n",
    "    edges_used[k] = edges_matrix_to_vector(N, edges_approx)\n",
    "    costs = Y[k][edges_approx[:,0], edges_approx[:,1]]\n",
    "    paths_cost[k] = costs.sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "5acbfc0c-3cd3-49b6-a6bf-2fbecf7e75d2",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([15., 15., 14., 14., 15., 15., 14., 14., 14., 14., 15., 15., 15.,\n",
       "       14., 15., 14., 16., 14., 15., 14., 14., 14., 14., 14., 14., 14.,\n",
       "       14., 16., 14., 14., 14., 14., 14., 15., 15., 16., 14., 14., 15.,\n",
       "       14., 16., 14., 15., 15., 15., 14., 15., 14., 15., 14., 15., 14.,\n",
       "       15., 14., 15., 15., 15., 14., 14., 15., 14., 14., 14., 14., 14.,\n",
       "       15., 14., 14., 15., 15., 15., 14., 14., 14., 14., 14., 14., 14.,\n",
       "       15., 14., 14., 14., 15., 14., 14., 14., 15., 14., 14., 14., 15.,\n",
       "       14., 14., 15., 14., 14., 14., 15., 15., 15., 14., 17., 14., 14.,\n",
       "       14., 15., 15., 14., 14., 14., 14., 14., 14., 14., 14., 15., 14.,\n",
       "       14., 14., 14., 14., 15., 14., 15., 14., 14., 15., 14., 14., 14.,\n",
       "       16., 14., 15., 15., 14., 14., 14., 14., 14., 14., 15., 15., 14.,\n",
       "       15., 14., 14., 15., 15., 16., 14., 14., 14., 15., 14., 14., 15.,\n",
       "       14., 16., 14., 14., 14., 15., 14., 15., 15., 14., 14., 14., 14.,\n",
       "       16., 14., 14., 14., 14., 14., 14., 14., 14., 15., 14., 15., 15.,\n",
       "       14., 14., 15., 15., 14., 14., 15., 14., 15., 15., 14., 14., 14.,\n",
       "       14., 14., 15., 15., 14., 14., 14., 15., 14., 14., 15., 14., 15.,\n",
       "       15., 14., 14., 14., 14., 14., 16., 15., 15., 14., 15., 16., 14.,\n",
       "       14., 14., 16., 14., 14., 14., 14., 14., 14., 15., 15., 14., 14.,\n",
       "       14., 15., 14., 15., 14., 15., 14., 14., 14., 14., 14., 15., 15.,\n",
       "       15., 14., 15., 14., 14., 14., 15., 14., 14., 15., 14., 14., 15.,\n",
       "       14., 14., 14., 14., 14., 14., 14., 14., 14., 14., 14., 14., 14.,\n",
       "       14., 14., 14., 15., 14., 14., 14., 14., 14., 16., 14., 15., 14.,\n",
       "       14., 14., 15., 14., 15., 14., 14., 15., 14., 14., 14., 14., 14.,\n",
       "       15., 14., 14., 15., 14., 14., 14., 14., 15., 14., 14., 14., 14.,\n",
       "       14., 15., 15., 14., 15., 14., 14., 14., 14., 14., 14., 14., 14.,\n",
       "       14., 14., 15., 15., 15., 15., 15., 15., 14., 15., 14., 15., 14.,\n",
       "       14., 15., 14., 14., 14., 15., 15., 14., 14., 15., 14., 15., 14.,\n",
       "       15., 14., 15., 14., 14., 15., 15., 14., 14., 14., 15., 14., 14.,\n",
       "       14., 14., 14., 14., 14., 16., 14., 14., 14., 15., 14., 15., 14.,\n",
       "       14., 14., 14., 15., 14., 14., 15., 15., 15., 14., 14., 15., 14.,\n",
       "       14., 15., 14., 14., 15., 14., 14., 15., 14., 14.])"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "edges_used.sum(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "0478aeb8-389a-4ca7-abfc-88ad4e8da35a",
   "metadata": {},
   "outputs": [],
   "source": [
    "upper_triangle_indices = np.triu_indices(N, k=1)\n",
    "edge_to_index = {(i, j): idx for idx, (i, j) in enumerate(zip(*upper_triangle_indices))}\n",
    "dict_edg_to_mat_idx = dict(zip(edge_to_index.values(), edge_to_index.keys()))\n",
    "matrix_idx = np.array(list(edge_to_index.keys()))\n",
    "\n",
    "euc_dists_vector = np.zeros((n_edges))\n",
    "for i in range(1,N):\n",
    "    for j in range(i):\n",
    "        euc_dists_vector[edge_to_index[(j,i)]] = euc_dists[j,i]\n",
    "\n",
    "euc_dists_vector_torch = torch.tensor(euc_dists_vector)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "7bb8abfe-5543-4788-896c-0395102062aa",
   "metadata": {},
   "outputs": [],
   "source": [
    "encoder = models.Encoder(input_size=n_edges, output_size=latent_dim, hl_sizes=[1000, 1000])  \n",
    "encoder = encoder.to(dev)\n",
    "\n",
    "decoder = models.ANN(input_size=latent_dim, output_size=n_edges, hl_sizes=[1000, 1000]) \n",
    "decoder = decoder.to(dev)\n",
    "\n",
    "opt = torch.optim.AdamW(encoder.parameters(), lr, weight_decay=1e-5)\n",
    "opt_decoder = torch.optim.AdamW(decoder.parameters(), lr, weight_decay=1e-5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "9a9e16fe-fe0e-488a-842c-69b502369b0f",
   "metadata": {},
   "outputs": [],
   "source": [
    "edges_used_train = edges_used[:N_train]\n",
    "edges_used_val = edges_used[N_train:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "de3c436e-a5ba-46a6-a53e-aea78adc4fac",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "b24c7167-5900-4abf-bb46-cec4ffa4bf29",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_tr = torch.tensor(Y[:N_train, matrix_idx[:,0], matrix_idx[:,1]])\n",
    "y_val = torch.tensor(Y[N_train:, matrix_idx[:,0], matrix_idx[:,1]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "39ec7a8c-c060-4675-90bc-e7bc6804172f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/alan/Desktop/envs/pao_env/lib/python3.8/site-packages/torch/autograd/__init__.py:266: UserWarning: CUDA initialization: The NVIDIA driver on your system is too old (found version 11060). Please update your GPU driver by downloading and installing a new version from the URL: http://www.nvidia.com/Download/index.aspx Alternatively, go to: https://pytorch.org to install a PyTorch version that has been compiled with your version of the CUDA driver. (Triggered internally at ../c10/cuda/CUDAFunctions.cpp:108.)\n",
      "  Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: Cost tr: 27.2796 Cost val: 27.4156 \t Acc tr: 0.7511 Acc val: 0.7497\n",
      "Epoch 1: Cost tr: 21.5137 Cost val: 21.7836 \t Acc tr: 0.791 Acc val: 0.7884\n",
      "Epoch 2: Cost tr: 21.5137 Cost val: 21.7836 \t Acc tr: 0.791 Acc val: 0.7884\n",
      "Epoch 3: Cost tr: 21.5137 Cost val: 21.7836 \t Acc tr: 0.791 Acc val: 0.7884\n",
      "Epoch 4: Cost tr: 21.759 Cost val: 22.0354 \t Acc tr: 0.7923 Acc val: 0.7902\n",
      "Epoch 5: Cost tr: 16.6532 Cost val: 17.0266 \t Acc tr: 0.7958 Acc val: 0.7901\n",
      "Epoch 6: Cost tr: 14.7811 Cost val: 14.9586 \t Acc tr: 0.7959 Acc val: 0.793\n",
      "Epoch 7: Cost tr: 20.18 Cost val: 20.2438 \t Acc tr: 0.7916 Acc val: 0.7876\n",
      "Epoch 8: Cost tr: 8.0853 Cost val: 7.1773 \t Acc tr: 0.8159 Acc val: 0.8184\n",
      "Epoch 9: Cost tr: 5.7488 Cost val: 6.1839 \t Acc tr: 0.8266 Acc val: 0.8251\n",
      "Epoch 10: Cost tr: 4.0401 Cost val: 4.4157 \t Acc tr: 0.8385 Acc val: 0.8365\n",
      "Epoch 11: Cost tr: 3.9364 Cost val: 4.3849 \t Acc tr: 0.8395 Acc val: 0.8363\n",
      "Epoch 12: Cost tr: 2.9438 Cost val: 3.4054 \t Acc tr: 0.8458 Acc val: 0.8436\n",
      "Epoch 13: Cost tr: 2.9234 Cost val: 3.2815 \t Acc tr: 0.8467 Acc val: 0.8457\n",
      "Epoch 14: Cost tr: 2.8238 Cost val: 3.0839 \t Acc tr: 0.843 Acc val: 0.8425\n",
      "Epoch 15: Cost tr: 4.1828 Cost val: 4.603 \t Acc tr: 0.8433 Acc val: 0.8404\n",
      "Epoch 16: Cost tr: 4.1828 Cost val: 4.603 \t Acc tr: 0.8433 Acc val: 0.8404\n",
      "Epoch 17: Cost tr: 2.2986 Cost val: 2.7115 \t Acc tr: 0.8541 Acc val: 0.8507\n",
      "Epoch 18: Cost tr: 2.2986 Cost val: 2.7115 \t Acc tr: 0.8541 Acc val: 0.8507\n",
      "Epoch 19: Cost tr: 1.8814 Cost val: 2.2299 \t Acc tr: 0.856 Acc val: 0.852\n",
      "Epoch 20: Cost tr: 1.54 Cost val: 1.759 \t Acc tr: 0.8525 Acc val: 0.8504\n",
      "Epoch 21: Cost tr: 3.2454 Cost val: 3.4728 \t Acc tr: 0.8397 Acc val: 0.8416\n",
      "Epoch 22: Cost tr: 3.2454 Cost val: 3.4728 \t Acc tr: 0.8397 Acc val: 0.8416\n",
      "Epoch 23: Cost tr: 5.5947 Cost val: 5.983 \t Acc tr: 0.8456 Acc val: 0.8448\n",
      "Epoch 24: Cost tr: 5.5947 Cost val: 5.983 \t Acc tr: 0.8456 Acc val: 0.8448\n",
      "Epoch 25: Cost tr: 5.5947 Cost val: 5.983 \t Acc tr: 0.8456 Acc val: 0.8448\n",
      "Epoch 26: Cost tr: 5.2886 Cost val: 5.8373 \t Acc tr: 0.8462 Acc val: 0.8451\n",
      "Epoch 27: Cost tr: 4.2915 Cost val: 5.0068 \t Acc tr: 0.8491 Acc val: 0.8475\n",
      "Epoch 28: Cost tr: 3.8275 Cost val: 4.0783 \t Acc tr: 0.8488 Acc val: 0.848\n",
      "Epoch 29: Cost tr: 3.5651 Cost val: 3.8866 \t Acc tr: 0.8461 Acc val: 0.8439\n",
      "Epoch 30: Cost tr: 3.6826 Cost val: 4.1587 \t Acc tr: 0.844 Acc val: 0.8416\n",
      "Epoch 31: Cost tr: 4.0326 Cost val: 4.363 \t Acc tr: 0.8413 Acc val: 0.8404\n",
      "Epoch 32: Cost tr: 1.8081 Cost val: 2.0614 \t Acc tr: 0.8532 Acc val: 0.8513\n",
      "Epoch 33: Cost tr: 1.8685 Cost val: 2.097 \t Acc tr: 0.8532 Acc val: 0.8515\n",
      "Epoch 34: Cost tr: 2.0815 Cost val: 2.2298 \t Acc tr: 0.8538 Acc val: 0.8522\n",
      "Epoch 35: Cost tr: 3.4659 Cost val: 3.8076 \t Acc tr: 0.8455 Acc val: 0.8438\n",
      "Epoch 36: Cost tr: 3.4678 Cost val: 3.7561 \t Acc tr: 0.8444 Acc val: 0.8444\n",
      "Epoch 37: Cost tr: 3.4817 Cost val: 3.7528 \t Acc tr: 0.8447 Acc val: 0.8441\n",
      "Epoch 38: Cost tr: 3.5903 Cost val: 3.9974 \t Acc tr: 0.8437 Acc val: 0.8431\n",
      "Epoch 39: Cost tr: 3.5959 Cost val: 4.0106 \t Acc tr: 0.8438 Acc val: 0.8432\n",
      "Epoch 40: Cost tr: 3.5308 Cost val: 3.9114 \t Acc tr: 0.8444 Acc val: 0.8433\n",
      "Epoch 41: Cost tr: 3.5312 Cost val: 3.9095 \t Acc tr: 0.8442 Acc val: 0.8433\n",
      "Epoch 42: Cost tr: 3.657 Cost val: 4.136 \t Acc tr: 0.843 Acc val: 0.8422\n",
      "Epoch 43: Cost tr: 3.9374 Cost val: 4.3677 \t Acc tr: 0.8417 Acc val: 0.8407\n",
      "Epoch 44: Cost tr: 4.1577 Cost val: 4.5823 \t Acc tr: 0.8401 Acc val: 0.8388\n",
      "Epoch 45: Cost tr: 4.2138 Cost val: 4.5965 \t Acc tr: 0.8395 Acc val: 0.8386\n",
      "Epoch 46: Cost tr: 4.0918 Cost val: 4.4886 \t Acc tr: 0.8412 Acc val: 0.8396\n",
      "Epoch 47: Cost tr: 3.9673 Cost val: 4.3744 \t Acc tr: 0.8423 Acc val: 0.8407\n",
      "Epoch 48: Cost tr: 3.7329 Cost val: 4.2191 \t Acc tr: 0.8458 Acc val: 0.8427\n",
      "Epoch 49: Cost tr: 3.6793 Cost val: 4.1253 \t Acc tr: 0.8463 Acc val: 0.8433\n",
      "Epoch 50: Cost tr: 3.7471 Cost val: 4.158 \t Acc tr: 0.8465 Acc val: 0.8437\n",
      "Epoch 51: Cost tr: 3.8976 Cost val: 4.3464 \t Acc tr: 0.8456 Acc val: 0.8426\n",
      "Epoch 52: Cost tr: 3.9902 Cost val: 4.403 \t Acc tr: 0.8437 Acc val: 0.8416\n",
      "Epoch 53: Cost tr: 4.0599 Cost val: 4.4272 \t Acc tr: 0.8443 Acc val: 0.8421\n",
      "Epoch 54: Cost tr: 4.0047 Cost val: 4.4075 \t Acc tr: 0.8456 Acc val: 0.8436\n",
      "Epoch 55: Cost tr: 4.047 Cost val: 4.4047 \t Acc tr: 0.8479 Acc val: 0.8452\n",
      "Epoch 56: Cost tr: 4.0271 Cost val: 4.3134 \t Acc tr: 0.8474 Acc val: 0.8441\n",
      "Epoch 57: Cost tr: 3.3505 Cost val: 3.2706 \t Acc tr: 0.8475 Acc val: 0.8455\n",
      "Epoch 58: Cost tr: 3.8879 Cost val: 4.165 \t Acc tr: 0.8452 Acc val: 0.8424\n",
      "Epoch 59: Cost tr: 4.3244 Cost val: 4.5807 \t Acc tr: 0.8437 Acc val: 0.8427\n",
      "Epoch 60: Cost tr: 4.1524 Cost val: 4.4951 \t Acc tr: 0.8447 Acc val: 0.8434\n",
      "Epoch 61: Cost tr: 4.1359 Cost val: 4.4522 \t Acc tr: 0.8466 Acc val: 0.8442\n",
      "Epoch 62: Cost tr: 4.2551 Cost val: 4.5752 \t Acc tr: 0.844 Acc val: 0.8424\n",
      "Epoch 63: Cost tr: 4.222 Cost val: 4.5477 \t Acc tr: 0.8444 Acc val: 0.8426\n",
      "Epoch 64: Cost tr: 4.1146 Cost val: 4.5082 \t Acc tr: 0.8449 Acc val: 0.8434\n",
      "Epoch 65: Cost tr: 4.1111 Cost val: 4.432 \t Acc tr: 0.846 Acc val: 0.844\n",
      "Epoch 66: Cost tr: 4.02 Cost val: 4.3712 \t Acc tr: 0.8476 Acc val: 0.8446\n",
      "Epoch 67: Cost tr: 3.9978 Cost val: 4.404 \t Acc tr: 0.846 Acc val: 0.8438\n",
      "Epoch 68: Cost tr: 3.983 Cost val: 4.3783 \t Acc tr: 0.846 Acc val: 0.8438\n",
      "Epoch 69: Cost tr: 3.9117 Cost val: 4.2862 \t Acc tr: 0.847 Acc val: 0.8449\n",
      "Epoch 70: Cost tr: 3.8625 Cost val: 4.1316 \t Acc tr: 0.8492 Acc val: 0.847\n",
      "Epoch 71: Cost tr: 3.6607 Cost val: 3.9902 \t Acc tr: 0.8504 Acc val: 0.8471\n",
      "Epoch 72: Cost tr: 3.3207 Cost val: 3.4534 \t Acc tr: 0.8482 Acc val: 0.8462\n",
      "Epoch 73: Cost tr: 3.7793 Cost val: 4.1172 \t Acc tr: 0.8449 Acc val: 0.8428\n",
      "Epoch 74: Cost tr: 4.0411 Cost val: 4.3289 \t Acc tr: 0.8487 Acc val: 0.846\n",
      "Epoch 75: Cost tr: 3.9851 Cost val: 4.2895 \t Acc tr: 0.8513 Acc val: 0.8476\n",
      "Epoch 76: Cost tr: 4.0406 Cost val: 4.3463 \t Acc tr: 0.8475 Acc val: 0.8449\n",
      "Epoch 77: Cost tr: 4.1964 Cost val: 4.5162 \t Acc tr: 0.8451 Acc val: 0.8429\n",
      "Epoch 78: Cost tr: 4.1351 Cost val: 4.513 \t Acc tr: 0.8445 Acc val: 0.8419\n",
      "Epoch 79: Cost tr: 4.0759 Cost val: 4.3552 \t Acc tr: 0.8466 Acc val: 0.8447\n",
      "Epoch 80: Cost tr: 3.9647 Cost val: 4.2447 \t Acc tr: 0.8489 Acc val: 0.8466\n",
      "Epoch 81: Cost tr: 3.8599 Cost val: 4.2173 \t Acc tr: 0.8493 Acc val: 0.8474\n",
      "Epoch 82: Cost tr: 3.9705 Cost val: 4.281 \t Acc tr: 0.8481 Acc val: 0.8458\n",
      "Epoch 83: Cost tr: 4.1487 Cost val: 4.472 \t Acc tr: 0.846 Acc val: 0.8436\n",
      "Epoch 84: Cost tr: 4.1841 Cost val: 4.5087 \t Acc tr: 0.8458 Acc val: 0.843\n",
      "Epoch 85: Cost tr: 4.165 Cost val: 4.4771 \t Acc tr: 0.8472 Acc val: 0.8445\n",
      "Epoch 86: Cost tr: 4.0627 Cost val: 4.4348 \t Acc tr: 0.8492 Acc val: 0.8462\n",
      "Epoch 87: Cost tr: 4.0108 Cost val: 4.4019 \t Acc tr: 0.8498 Acc val: 0.8474\n",
      "Epoch 88: Cost tr: 4.1634 Cost val: 4.475 \t Acc tr: 0.8508 Acc val: 0.8473\n",
      "Epoch 89: Cost tr: 4.0962 Cost val: 4.4903 \t Acc tr: 0.8495 Acc val: 0.8468\n",
      "Epoch 90: Cost tr: 4.0976 Cost val: 4.46 \t Acc tr: 0.8495 Acc val: 0.8466\n",
      "Epoch 91: Cost tr: 4.116 Cost val: 4.5083 \t Acc tr: 0.849 Acc val: 0.846\n",
      "Epoch 92: Cost tr: 4.1936 Cost val: 4.5859 \t Acc tr: 0.8481 Acc val: 0.8453\n",
      "Epoch 93: Cost tr: 4.0921 Cost val: 4.5564 \t Acc tr: 0.8496 Acc val: 0.847\n",
      "Epoch 94: Cost tr: 4.1428 Cost val: 4.6068 \t Acc tr: 0.8499 Acc val: 0.8469\n",
      "Epoch 95: Cost tr: 3.5956 Cost val: 3.7831 \t Acc tr: 0.8499 Acc val: 0.8474\n",
      "Epoch 96: Cost tr: 3.1337 Cost val: 3.1346 \t Acc tr: 0.8498 Acc val: 0.8492\n",
      "Epoch 97: Cost tr: 2.88 Cost val: 3.1471 \t Acc tr: 0.8527 Acc val: 0.8511\n",
      "Epoch 98: Cost tr: 2.8116 Cost val: 3.092 \t Acc tr: 0.8536 Acc val: 0.8526\n",
      "Epoch 99: Cost tr: 2.6811 Cost val: 2.896 \t Acc tr: 0.852 Acc val: 0.8512\n",
      "Epoch 100: Cost tr: 2.6889 Cost val: 2.8556 \t Acc tr: 0.849 Acc val: 0.8487\n",
      "Epoch 101: Cost tr: 2.705 Cost val: 2.9524 \t Acc tr: 0.8509 Acc val: 0.8507\n",
      "Epoch 102: Cost tr: 2.7232 Cost val: 2.8938 \t Acc tr: 0.8523 Acc val: 0.8519\n",
      "Epoch 103: Cost tr: 2.6543 Cost val: 2.872 \t Acc tr: 0.852 Acc val: 0.8514\n",
      "Epoch 104: Cost tr: 2.7033 Cost val: 2.8848 \t Acc tr: 0.8515 Acc val: 0.8515\n",
      "Epoch 105: Cost tr: 2.6787 Cost val: 2.9223 \t Acc tr: 0.8525 Acc val: 0.8519\n",
      "Epoch 106: Cost tr: 2.6112 Cost val: 2.9519 \t Acc tr: 0.8523 Acc val: 0.8517\n",
      "Epoch 107: Cost tr: 2.7828 Cost val: 3.0984 \t Acc tr: 0.8515 Acc val: 0.851\n",
      "Epoch 108: Cost tr: 3.6007 Cost val: 3.7479 \t Acc tr: 0.8498 Acc val: 0.8482\n",
      "Epoch 109: Cost tr: 4.2628 Cost val: 4.5768 \t Acc tr: 0.8496 Acc val: 0.8466\n",
      "Epoch 110: Cost tr: 4.0452 Cost val: 4.455 \t Acc tr: 0.8495 Acc val: 0.8471\n",
      "Epoch 111: Cost tr: 4.0482 Cost val: 4.4538 \t Acc tr: 0.8493 Acc val: 0.8469\n",
      "Epoch 112: Cost tr: 3.7981 Cost val: 4.313 \t Acc tr: 0.8507 Acc val: 0.8487\n",
      "Epoch 113: Cost tr: 3.6527 Cost val: 4.0658 \t Acc tr: 0.8511 Acc val: 0.8495\n",
      "Epoch 114: Cost tr: 3.8982 Cost val: 4.3188 \t Acc tr: 0.8491 Acc val: 0.8469\n",
      "Epoch 115: Cost tr: 3.9499 Cost val: 4.4786 \t Acc tr: 0.8475 Acc val: 0.8443\n",
      "Epoch 116: Cost tr: 3.3553 Cost val: 3.7602 \t Acc tr: 0.8501 Acc val: 0.8489\n",
      "Epoch 117: Cost tr: 2.8025 Cost val: 3.4655 \t Acc tr: 0.8538 Acc val: 0.8512\n",
      "Epoch 118: Cost tr: 3.0704 Cost val: 3.5802 \t Acc tr: 0.8519 Acc val: 0.8504\n",
      "Epoch 119: Cost tr: 3.5447 Cost val: 3.8788 \t Acc tr: 0.8496 Acc val: 0.848\n",
      "Epoch 120: Cost tr: 3.6427 Cost val: 4.0066 \t Acc tr: 0.849 Acc val: 0.8464\n",
      "Epoch 121: Cost tr: 3.5642 Cost val: 3.8818 \t Acc tr: 0.8493 Acc val: 0.8474\n",
      "Epoch 122: Cost tr: 3.3806 Cost val: 3.7583 \t Acc tr: 0.8507 Acc val: 0.8492\n",
      "Epoch 123: Cost tr: 3.4802 Cost val: 3.8455 \t Acc tr: 0.8502 Acc val: 0.849\n",
      "Epoch 124: Cost tr: 3.3638 Cost val: 3.8095 \t Acc tr: 0.851 Acc val: 0.8495\n",
      "Epoch 125: Cost tr: 3.1959 Cost val: 3.6714 \t Acc tr: 0.8518 Acc val: 0.8502\n",
      "Epoch 126: Cost tr: 3.4067 Cost val: 3.8153 \t Acc tr: 0.8508 Acc val: 0.8493\n",
      "Epoch 127: Cost tr: 3.5187 Cost val: 3.9586 \t Acc tr: 0.8501 Acc val: 0.8487\n",
      "Epoch 128: Cost tr: 3.704 Cost val: 4.1012 \t Acc tr: 0.8487 Acc val: 0.8471\n",
      "Epoch 129: Cost tr: 3.4069 Cost val: 3.9678 \t Acc tr: 0.8508 Acc val: 0.8487\n",
      "Epoch 130: Cost tr: 4.2106 Cost val: 4.787 \t Acc tr: 0.8518 Acc val: 0.8492\n",
      "Epoch 131: Cost tr: 3.9353 Cost val: 4.4678 \t Acc tr: 0.8524 Acc val: 0.8496\n",
      "Epoch 132: Cost tr: 3.9821 Cost val: 4.5815 \t Acc tr: 0.8526 Acc val: 0.8495\n",
      "Epoch 133: Cost tr: 3.7087 Cost val: 4.2343 \t Acc tr: 0.8515 Acc val: 0.8499\n",
      "Epoch 134: Cost tr: 3.5439 Cost val: 4.2033 \t Acc tr: 0.8522 Acc val: 0.8494\n",
      "Epoch 135: Cost tr: 3.3725 Cost val: 4.0357 \t Acc tr: 0.8513 Acc val: 0.85\n",
      "Epoch 136: Cost tr: 3.3143 Cost val: 3.7563 \t Acc tr: 0.8513 Acc val: 0.8492\n",
      "Epoch 137: Cost tr: 3.4076 Cost val: 3.7282 \t Acc tr: 0.8503 Acc val: 0.8492\n",
      "Epoch 138: Cost tr: 3.1924 Cost val: 3.3378 \t Acc tr: 0.8497 Acc val: 0.849\n",
      "Epoch 139: Cost tr: 2.6058 Cost val: 2.9683 \t Acc tr: 0.8508 Acc val: 0.8515\n",
      "Epoch 140: Cost tr: 2.4977 Cost val: 2.8019 \t Acc tr: 0.8519 Acc val: 0.8529\n",
      "Epoch 141: Cost tr: 2.4698 Cost val: 2.7826 \t Acc tr: 0.851 Acc val: 0.8514\n",
      "Epoch 142: Cost tr: 2.4608 Cost val: 2.7341 \t Acc tr: 0.8512 Acc val: 0.852\n",
      "Epoch 143: Cost tr: 2.3666 Cost val: 2.796 \t Acc tr: 0.8525 Acc val: 0.8532\n",
      "Epoch 144: Cost tr: 2.299 Cost val: 2.9657 \t Acc tr: 0.8551 Acc val: 0.8552\n",
      "Epoch 145: Cost tr: 3.4777 Cost val: 3.8898 \t Acc tr: 0.8515 Acc val: 0.8502\n",
      "Epoch 146: Cost tr: 4.3388 Cost val: 4.7182 \t Acc tr: 0.8485 Acc val: 0.846\n",
      "Epoch 147: Cost tr: 4.1414 Cost val: 4.6806 \t Acc tr: 0.8496 Acc val: 0.8464\n",
      "Epoch 148: Cost tr: 4.1736 Cost val: 4.6981 \t Acc tr: 0.8497 Acc val: 0.8468\n",
      "Epoch 149: Cost tr: 4.2637 Cost val: 4.6883 \t Acc tr: 0.8492 Acc val: 0.8465\n",
      "Epoch 150: Cost tr: 4.1774 Cost val: 4.621 \t Acc tr: 0.8495 Acc val: 0.8479\n",
      "Epoch 151: Cost tr: 4.2264 Cost val: 4.7154 \t Acc tr: 0.8497 Acc val: 0.8466\n",
      "Epoch 152: Cost tr: 3.7054 Cost val: 4.1286 \t Acc tr: 0.8507 Acc val: 0.8483\n",
      "Epoch 153: Cost tr: 3.1776 Cost val: 3.8231 \t Acc tr: 0.8502 Acc val: 0.8477\n",
      "Epoch 154: Cost tr: 3.188 Cost val: 3.8319 \t Acc tr: 0.8501 Acc val: 0.848\n",
      "Epoch 155: Cost tr: 3.3923 Cost val: 4.0069 \t Acc tr: 0.8483 Acc val: 0.8463\n",
      "Epoch 156: Cost tr: 3.3557 Cost val: 3.868 \t Acc tr: 0.8486 Acc val: 0.8469\n",
      "Epoch 157: Cost tr: 3.2458 Cost val: 3.8131 \t Acc tr: 0.8492 Acc val: 0.8474\n",
      "Epoch 158: Cost tr: 3.3413 Cost val: 3.7579 \t Acc tr: 0.8495 Acc val: 0.8473\n",
      "Epoch 159: Cost tr: 3.7937 Cost val: 4.1957 \t Acc tr: 0.8478 Acc val: 0.8452\n",
      "Epoch 160: Cost tr: 4.1586 Cost val: 4.5152 \t Acc tr: 0.8465 Acc val: 0.844\n",
      "Epoch 161: Cost tr: 3.9833 Cost val: 4.5113 \t Acc tr: 0.849 Acc val: 0.8475\n",
      "Epoch 162: Cost tr: 4.0099 Cost val: 4.6839 \t Acc tr: 0.8526 Acc val: 0.8496\n",
      "Epoch 163: Cost tr: 4.2338 Cost val: 4.6789 \t Acc tr: 0.8485 Acc val: 0.8459\n",
      "Epoch 164: Cost tr: 4.2074 Cost val: 4.692 \t Acc tr: 0.8474 Acc val: 0.8451\n",
      "Epoch 165: Cost tr: 3.8199 Cost val: 4.4927 \t Acc tr: 0.8514 Acc val: 0.8496\n",
      "Epoch 166: Cost tr: 3.8075 Cost val: 4.3748 \t Acc tr: 0.8521 Acc val: 0.8499\n",
      "Epoch 167: Cost tr: 3.998 Cost val: 4.7071 \t Acc tr: 0.8503 Acc val: 0.8475\n",
      "Epoch 168: Cost tr: 4.1344 Cost val: 4.688 \t Acc tr: 0.8497 Acc val: 0.8468\n",
      "Epoch 169: Cost tr: 3.834 Cost val: 4.509 \t Acc tr: 0.8505 Acc val: 0.8481\n",
      "Epoch 170: Cost tr: 3.8215 Cost val: 4.454 \t Acc tr: 0.8505 Acc val: 0.8478\n",
      "Epoch 171: Cost tr: 3.9138 Cost val: 4.5215 \t Acc tr: 0.8488 Acc val: 0.8459\n",
      "Epoch 172: Cost tr: 2.7326 Cost val: 3.2011 \t Acc tr: 0.8501 Acc val: 0.8497\n",
      "Epoch 173: Cost tr: 2.7605 Cost val: 3.1512 \t Acc tr: 0.8508 Acc val: 0.8505\n",
      "Epoch 174: Cost tr: 3.5768 Cost val: 4.0166 \t Acc tr: 0.8504 Acc val: 0.8487\n",
      "Epoch 175: Cost tr: 3.7532 Cost val: 4.2522 \t Acc tr: 0.8504 Acc val: 0.8475\n",
      "Epoch 176: Cost tr: 3.8117 Cost val: 4.3484 \t Acc tr: 0.8495 Acc val: 0.8462\n",
      "Epoch 177: Cost tr: 3.6584 Cost val: 4.1841 \t Acc tr: 0.8512 Acc val: 0.8489\n",
      "Epoch 178: Cost tr: 3.7108 Cost val: 4.1756 \t Acc tr: 0.8517 Acc val: 0.8492\n",
      "Epoch 179: Cost tr: 3.7561 Cost val: 4.3074 \t Acc tr: 0.8518 Acc val: 0.8488\n",
      "Epoch 180: Cost tr: 3.7708 Cost val: 4.4251 \t Acc tr: 0.8515 Acc val: 0.8488\n",
      "Epoch 181: Cost tr: 3.7104 Cost val: 4.3187 \t Acc tr: 0.8528 Acc val: 0.8491\n",
      "Epoch 182: Cost tr: 3.5976 Cost val: 4.1836 \t Acc tr: 0.8534 Acc val: 0.8502\n",
      "Epoch 183: Cost tr: 3.6325 Cost val: 4.2616 \t Acc tr: 0.8525 Acc val: 0.8499\n",
      "Epoch 184: Cost tr: 3.6081 Cost val: 4.2353 \t Acc tr: 0.8521 Acc val: 0.8501\n",
      "Epoch 185: Cost tr: 3.453 Cost val: 4.0679 \t Acc tr: 0.8529 Acc val: 0.8505\n",
      "Epoch 186: Cost tr: 2.9636 Cost val: 3.2158 \t Acc tr: 0.8538 Acc val: 0.8523\n",
      "Epoch 187: Cost tr: 2.8064 Cost val: 3.1906 \t Acc tr: 0.8527 Acc val: 0.8507\n",
      "Epoch 188: Cost tr: 3.0195 Cost val: 3.3302 \t Acc tr: 0.8531 Acc val: 0.8514\n",
      "Epoch 189: Cost tr: 3.2152 Cost val: 3.4146 \t Acc tr: 0.8554 Acc val: 0.8532\n",
      "Epoch 190: Cost tr: 3.5113 Cost val: 3.7682 \t Acc tr: 0.8546 Acc val: 0.8509\n",
      "Epoch 191: Cost tr: 3.664 Cost val: 3.9829 \t Acc tr: 0.8527 Acc val: 0.8488\n",
      "Epoch 192: Cost tr: 3.0078 Cost val: 3.3587 \t Acc tr: 0.8552 Acc val: 0.851\n",
      "Epoch 193: Cost tr: 2.4964 Cost val: 2.6955 \t Acc tr: 0.8558 Acc val: 0.8527\n",
      "Epoch 194: Cost tr: 2.3099 Cost val: 2.5095 \t Acc tr: 0.8574 Acc val: 0.855\n",
      "Epoch 195: Cost tr: 2.1826 Cost val: 2.5108 \t Acc tr: 0.859 Acc val: 0.854\n",
      "Epoch 196: Cost tr: 2.1974 Cost val: 2.532 \t Acc tr: 0.8606 Acc val: 0.8546\n",
      "Epoch 197: Cost tr: 2.1731 Cost val: 2.513 \t Acc tr: 0.8609 Acc val: 0.8553\n",
      "Epoch 198: Cost tr: 2.0885 Cost val: 2.5252 \t Acc tr: 0.8603 Acc val: 0.8538\n",
      "Epoch 199: Cost tr: 2.1333 Cost val: 2.4576 \t Acc tr: 0.8608 Acc val: 0.8549\n",
      "Epoch 200: Cost tr: 2.1611 Cost val: 2.5935 \t Acc tr: 0.8616 Acc val: 0.8549\n",
      "Epoch 201: Cost tr: 2.2794 Cost val: 2.6169 \t Acc tr: 0.8606 Acc val: 0.8553\n",
      "Epoch 202: Cost tr: 2.2382 Cost val: 2.6787 \t Acc tr: 0.8609 Acc val: 0.8546\n",
      "Epoch 203: Cost tr: 2.3876 Cost val: 2.8378 \t Acc tr: 0.8591 Acc val: 0.8555\n",
      "Epoch 204: Cost tr: 2.2254 Cost val: 2.5547 \t Acc tr: 0.8614 Acc val: 0.858\n",
      "Epoch 205: Cost tr: 2.3513 Cost val: 2.6574 \t Acc tr: 0.8616 Acc val: 0.8596\n",
      "Epoch 206: Cost tr: 2.2021 Cost val: 2.6737 \t Acc tr: 0.8613 Acc val: 0.8558\n",
      "Epoch 207: Cost tr: 2.3057 Cost val: 2.5496 \t Acc tr: 0.8624 Acc val: 0.8602\n",
      "Epoch 208: Cost tr: 2.238 Cost val: 2.5086 \t Acc tr: 0.8629 Acc val: 0.8604\n",
      "Epoch 209: Cost tr: 2.2639 Cost val: 2.5049 \t Acc tr: 0.8612 Acc val: 0.8599\n",
      "Epoch 210: Cost tr: 2.181 Cost val: 2.4551 \t Acc tr: 0.8623 Acc val: 0.859\n",
      "Epoch 211: Cost tr: 2.2411 Cost val: 2.4259 \t Acc tr: 0.8623 Acc val: 0.8599\n",
      "Epoch 212: Cost tr: 2.1418 Cost val: 2.4266 \t Acc tr: 0.8626 Acc val: 0.8587\n",
      "Epoch 213: Cost tr: 2.288 Cost val: 2.8298 \t Acc tr: 0.8638 Acc val: 0.8571\n",
      "Epoch 214: Cost tr: 2.6121 Cost val: 3.3469 \t Acc tr: 0.8621 Acc val: 0.8573\n",
      "Epoch 215: Cost tr: 2.793 Cost val: 3.3091 \t Acc tr: 0.8599 Acc val: 0.8542\n",
      "Epoch 216: Cost tr: 2.7022 Cost val: 3.2923 \t Acc tr: 0.8626 Acc val: 0.8571\n",
      "Epoch 217: Cost tr: 2.7845 Cost val: 3.2561 \t Acc tr: 0.8611 Acc val: 0.8582\n",
      "Epoch 218: Cost tr: 3.2062 Cost val: 3.6158 \t Acc tr: 0.8602 Acc val: 0.853\n",
      "Epoch 219: Cost tr: 3.1593 Cost val: 3.4835 \t Acc tr: 0.8597 Acc val: 0.8518\n",
      "Epoch 220: Cost tr: 3.1157 Cost val: 3.2962 \t Acc tr: 0.8599 Acc val: 0.8548\n",
      "Epoch 221: Cost tr: 3.3046 Cost val: 3.5309 \t Acc tr: 0.8609 Acc val: 0.8546\n",
      "Epoch 222: Cost tr: 3.4004 Cost val: 3.672 \t Acc tr: 0.861 Acc val: 0.8538\n",
      "Epoch 223: Cost tr: 3.0053 Cost val: 3.2295 \t Acc tr: 0.8624 Acc val: 0.8558\n",
      "Epoch 224: Cost tr: 3.1234 Cost val: 3.4822 \t Acc tr: 0.8627 Acc val: 0.8573\n",
      "Epoch 225: Cost tr: 3.6157 Cost val: 3.9315 \t Acc tr: 0.8606 Acc val: 0.8545\n",
      "Epoch 226: Cost tr: 3.2596 Cost val: 3.6178 \t Acc tr: 0.8621 Acc val: 0.8571\n",
      "Epoch 227: Cost tr: 2.7282 Cost val: 3.1361 \t Acc tr: 0.8648 Acc val: 0.8592\n",
      "Epoch 228: Cost tr: 2.4167 Cost val: 2.9819 \t Acc tr: 0.8665 Acc val: 0.8567\n",
      "Epoch 229: Cost tr: 2.4424 Cost val: 2.7059 \t Acc tr: 0.8676 Acc val: 0.8585\n",
      "Epoch 230: Cost tr: 1.911 Cost val: 2.5599 \t Acc tr: 0.8659 Acc val: 0.8606\n",
      "Epoch 231: Cost tr: 1.811 Cost val: 2.3615 \t Acc tr: 0.8666 Acc val: 0.8602\n",
      "Epoch 232: Cost tr: 1.8731 Cost val: 2.3023 \t Acc tr: 0.8677 Acc val: 0.8605\n",
      "Epoch 233: Cost tr: 1.8387 Cost val: 2.1986 \t Acc tr: 0.8676 Acc val: 0.8618\n",
      "Epoch 234: Cost tr: 1.6916 Cost val: 2.1218 \t Acc tr: 0.8695 Acc val: 0.8647\n",
      "Epoch 235: Cost tr: 1.8455 Cost val: 2.4195 \t Acc tr: 0.8677 Acc val: 0.8614\n",
      "Epoch 236: Cost tr: 2.1732 Cost val: 2.7313 \t Acc tr: 0.8682 Acc val: 0.8601\n",
      "Epoch 237: Cost tr: 2.4621 Cost val: 3.0125 \t Acc tr: 0.8653 Acc val: 0.8575\n",
      "Epoch 238: Cost tr: 2.4925 Cost val: 3.0867 \t Acc tr: 0.8685 Acc val: 0.8568\n",
      "Epoch 239: Cost tr: 2.585 Cost val: 3.2611 \t Acc tr: 0.8682 Acc val: 0.8576\n",
      "Epoch 240: Cost tr: 2.3441 Cost val: 3.1043 \t Acc tr: 0.8673 Acc val: 0.8576\n",
      "Epoch 241: Cost tr: 2.1562 Cost val: 2.9106 \t Acc tr: 0.8697 Acc val: 0.8596\n",
      "Epoch 242: Cost tr: 2.3084 Cost val: 2.9749 \t Acc tr: 0.8685 Acc val: 0.8589\n",
      "Epoch 243: Cost tr: 2.1992 Cost val: 2.8538 \t Acc tr: 0.8671 Acc val: 0.8609\n",
      "Epoch 244: Cost tr: 2.191 Cost val: 2.9181 \t Acc tr: 0.8686 Acc val: 0.8585\n",
      "Epoch 245: Cost tr: 1.8985 Cost val: 2.9562 \t Acc tr: 0.8686 Acc val: 0.8573\n",
      "Epoch 246: Cost tr: 2.0661 Cost val: 2.8987 \t Acc tr: 0.8671 Acc val: 0.8545\n",
      "Epoch 247: Cost tr: 2.7819 Cost val: 3.5502 \t Acc tr: 0.8673 Acc val: 0.8559\n",
      "Epoch 248: Cost tr: 2.5239 Cost val: 3.2699 \t Acc tr: 0.869 Acc val: 0.8574\n",
      "Epoch 249: Cost tr: 2.0139 Cost val: 3.0985 \t Acc tr: 0.8699 Acc val: 0.8588\n",
      "Epoch 250: Cost tr: 2.509 Cost val: 3.353 \t Acc tr: 0.872 Acc val: 0.8582\n",
      "Epoch 251: Cost tr: 2.5799 Cost val: 3.2837 \t Acc tr: 0.8694 Acc val: 0.8581\n",
      "Epoch 252: Cost tr: 2.2319 Cost val: 3.0276 \t Acc tr: 0.8698 Acc val: 0.8597\n",
      "Epoch 253: Cost tr: 2.3773 Cost val: 3.2675 \t Acc tr: 0.8698 Acc val: 0.8577\n",
      "Epoch 254: Cost tr: 2.3192 Cost val: 3.3603 \t Acc tr: 0.8699 Acc val: 0.8578\n",
      "Epoch 255: Cost tr: 2.2216 Cost val: 2.9664 \t Acc tr: 0.8695 Acc val: 0.859\n",
      "Epoch 256: Cost tr: 2.0666 Cost val: 2.8033 \t Acc tr: 0.8702 Acc val: 0.8602\n",
      "Epoch 257: Cost tr: 1.6996 Cost val: 2.4709 \t Acc tr: 0.8702 Acc val: 0.8602\n",
      "Epoch 258: Cost tr: 1.8199 Cost val: 2.5468 \t Acc tr: 0.8697 Acc val: 0.8599\n",
      "Epoch 259: Cost tr: 1.997 Cost val: 2.695 \t Acc tr: 0.871 Acc val: 0.8593\n",
      "Epoch 260: Cost tr: 1.8085 Cost val: 2.5333 \t Acc tr: 0.8731 Acc val: 0.8602\n",
      "Epoch 261: Cost tr: 1.8954 Cost val: 2.6447 \t Acc tr: 0.872 Acc val: 0.8608\n",
      "Epoch 262: Cost tr: 1.9029 Cost val: 2.7357 \t Acc tr: 0.8721 Acc val: 0.8602\n",
      "Epoch 263: Cost tr: 1.8336 Cost val: 2.5708 \t Acc tr: 0.8719 Acc val: 0.8608\n",
      "Epoch 264: Cost tr: 1.9112 Cost val: 2.4294 \t Acc tr: 0.8722 Acc val: 0.8615\n",
      "Epoch 265: Cost tr: 1.6946 Cost val: 2.3574 \t Acc tr: 0.873 Acc val: 0.8608\n",
      "Epoch 266: Cost tr: 1.7059 Cost val: 2.4706 \t Acc tr: 0.8746 Acc val: 0.8618\n",
      "Epoch 267: Cost tr: 2.2817 Cost val: 2.8149 \t Acc tr: 0.8725 Acc val: 0.8601\n",
      "Epoch 268: Cost tr: 1.9856 Cost val: 2.9998 \t Acc tr: 0.873 Acc val: 0.8596\n",
      "Epoch 269: Cost tr: 1.9763 Cost val: 3.118 \t Acc tr: 0.8724 Acc val: 0.8586\n",
      "Epoch 270: Cost tr: 1.8034 Cost val: 3.0742 \t Acc tr: 0.8733 Acc val: 0.8593\n",
      "Epoch 271: Cost tr: 1.9186 Cost val: 3.0239 \t Acc tr: 0.8735 Acc val: 0.8592\n",
      "Epoch 272: Cost tr: 1.9604 Cost val: 2.8599 \t Acc tr: 0.8749 Acc val: 0.8601\n",
      "Epoch 273: Cost tr: 1.7519 Cost val: 2.5721 \t Acc tr: 0.8754 Acc val: 0.8609\n",
      "Epoch 274: Cost tr: 1.7208 Cost val: 2.5287 \t Acc tr: 0.8764 Acc val: 0.8624\n",
      "Epoch 275: Cost tr: 1.7206 Cost val: 2.2313 \t Acc tr: 0.876 Acc val: 0.863\n",
      "Epoch 276: Cost tr: 1.4828 Cost val: 2.2319 \t Acc tr: 0.8755 Acc val: 0.8629\n",
      "Epoch 277: Cost tr: 1.5044 Cost val: 2.0617 \t Acc tr: 0.8751 Acc val: 0.8634\n",
      "Epoch 278: Cost tr: 1.6871 Cost val: 2.4551 \t Acc tr: 0.8741 Acc val: 0.8626\n",
      "Epoch 279: Cost tr: 1.5949 Cost val: 2.4775 \t Acc tr: 0.8743 Acc val: 0.8632\n",
      "Epoch 280: Cost tr: 1.6469 Cost val: 2.6221 \t Acc tr: 0.874 Acc val: 0.863\n",
      "Epoch 281: Cost tr: 1.6184 Cost val: 2.3586 \t Acc tr: 0.8731 Acc val: 0.863\n",
      "Epoch 282: Cost tr: 1.6832 Cost val: 2.5706 \t Acc tr: 0.8737 Acc val: 0.8635\n",
      "Epoch 283: Cost tr: 1.7616 Cost val: 2.5341 \t Acc tr: 0.873 Acc val: 0.8636\n",
      "Epoch 284: Cost tr: 1.367 Cost val: 2.3676 \t Acc tr: 0.8749 Acc val: 0.8635\n",
      "Epoch 285: Cost tr: 1.0726 Cost val: 1.9728 \t Acc tr: 0.8767 Acc val: 0.8669\n",
      "Epoch 286: Cost tr: 1.3348 Cost val: 2.1393 \t Acc tr: 0.8754 Acc val: 0.8664\n",
      "Epoch 287: Cost tr: 1.4741 Cost val: 2.5262 \t Acc tr: 0.8746 Acc val: 0.8627\n",
      "Epoch 288: Cost tr: 1.2747 Cost val: 2.6535 \t Acc tr: 0.8744 Acc val: 0.8631\n",
      "Epoch 289: Cost tr: 1.479 Cost val: 2.5353 \t Acc tr: 0.8738 Acc val: 0.8633\n",
      "Epoch 290: Cost tr: 1.3641 Cost val: 2.7711 \t Acc tr: 0.8751 Acc val: 0.861\n",
      "Epoch 291: Cost tr: 1.4848 Cost val: 2.9035 \t Acc tr: 0.8742 Acc val: 0.8608\n",
      "Epoch 292: Cost tr: 1.773 Cost val: 2.4269 \t Acc tr: 0.8716 Acc val: 0.8614\n",
      "Epoch 293: Cost tr: 1.2307 Cost val: 1.8998 \t Acc tr: 0.8737 Acc val: 0.8631\n",
      "Epoch 294: Cost tr: 0.8591 Cost val: 1.7762 \t Acc tr: 0.8727 Acc val: 0.8644\n",
      "Epoch 295: Cost tr: 0.8591 Cost val: 1.5971 \t Acc tr: 0.873 Acc val: 0.8624\n",
      "Epoch 296: Cost tr: 1.0385 Cost val: 2.12 \t Acc tr: 0.8752 Acc val: 0.8619\n",
      "Epoch 297: Cost tr: 1.2003 Cost val: 2.1362 \t Acc tr: 0.8738 Acc val: 0.8634\n",
      "Epoch 298: Cost tr: 1.4606 Cost val: 2.3587 \t Acc tr: 0.8747 Acc val: 0.8623\n",
      "Epoch 299: Cost tr: 1.5771 Cost val: 2.2387 \t Acc tr: 0.8737 Acc val: 0.8623\n",
      "Epoch 300: Cost tr: 1.4635 Cost val: 2.2927 \t Acc tr: 0.8736 Acc val: 0.8615\n",
      "Epoch 301: Cost tr: 1.5325 Cost val: 2.3285 \t Acc tr: 0.8735 Acc val: 0.863\n",
      "Epoch 302: Cost tr: 1.3144 Cost val: 2.1209 \t Acc tr: 0.8761 Acc val: 0.8647\n",
      "Epoch 303: Cost tr: 1.2453 Cost val: 2.1302 \t Acc tr: 0.8769 Acc val: 0.8661\n",
      "Epoch 304: Cost tr: 1.3044 Cost val: 2.2642 \t Acc tr: 0.8756 Acc val: 0.8651\n",
      "Epoch 305: Cost tr: 1.2197 Cost val: 2.4949 \t Acc tr: 0.877 Acc val: 0.864\n",
      "Epoch 306: Cost tr: 1.2244 Cost val: 2.3317 \t Acc tr: 0.875 Acc val: 0.8638\n",
      "Epoch 307: Cost tr: 0.7938 Cost val: 1.9968 \t Acc tr: 0.8757 Acc val: 0.8649\n",
      "Epoch 308: Cost tr: 1.0572 Cost val: 1.9826 \t Acc tr: 0.8744 Acc val: 0.8649\n",
      "Epoch 309: Cost tr: 1.1838 Cost val: 2.1325 \t Acc tr: 0.8781 Acc val: 0.8651\n",
      "Epoch 310: Cost tr: 0.9845 Cost val: 2.1512 \t Acc tr: 0.8771 Acc val: 0.866\n",
      "Epoch 311: Cost tr: 1.1542 Cost val: 2.1175 \t Acc tr: 0.8752 Acc val: 0.8643\n",
      "Epoch 312: Cost tr: 1.285 Cost val: 2.2004 \t Acc tr: 0.8756 Acc val: 0.8651\n",
      "Epoch 313: Cost tr: 1.234 Cost val: 2.0142 \t Acc tr: 0.876 Acc val: 0.8661\n",
      "Epoch 314: Cost tr: 0.7555 Cost val: 1.6235 \t Acc tr: 0.8766 Acc val: 0.8657\n",
      "Epoch 315: Cost tr: 0.7209 Cost val: 1.3855 \t Acc tr: 0.8766 Acc val: 0.867\n",
      "Epoch 316: Cost tr: 0.9343 Cost val: 1.824 \t Acc tr: 0.8778 Acc val: 0.8675\n",
      "Epoch 317: Cost tr: 0.9649 Cost val: 1.904 \t Acc tr: 0.8792 Acc val: 0.8676\n",
      "Epoch 318: Cost tr: 0.8871 Cost val: 1.8937 \t Acc tr: 0.8788 Acc val: 0.8666\n",
      "Epoch 319: Cost tr: 0.9823 Cost val: 1.9791 \t Acc tr: 0.8785 Acc val: 0.8667\n",
      "Epoch 320: Cost tr: 1.0782 Cost val: 2.1336 \t Acc tr: 0.8781 Acc val: 0.8654\n",
      "Epoch 321: Cost tr: 0.8566 Cost val: 2.0063 \t Acc tr: 0.8763 Acc val: 0.8665\n",
      "Epoch 322: Cost tr: 1.0603 Cost val: 1.7761 \t Acc tr: 0.8755 Acc val: 0.8656\n",
      "Epoch 323: Cost tr: 1.0142 Cost val: 2.1001 \t Acc tr: 0.877 Acc val: 0.8657\n",
      "Epoch 324: Cost tr: 0.865 Cost val: 1.8187 \t Acc tr: 0.8774 Acc val: 0.868\n",
      "Epoch 325: Cost tr: 1.0265 Cost val: 1.6493 \t Acc tr: 0.879 Acc val: 0.8671\n",
      "Epoch 326: Cost tr: 0.706 Cost val: 1.6355 \t Acc tr: 0.8791 Acc val: 0.8688\n",
      "Epoch 327: Cost tr: 0.8282 Cost val: 1.6447 \t Acc tr: 0.8787 Acc val: 0.868\n",
      "Epoch 328: Cost tr: 1.0064 Cost val: 1.8683 \t Acc tr: 0.8782 Acc val: 0.8663\n",
      "Epoch 329: Cost tr: 1.0588 Cost val: 2.1202 \t Acc tr: 0.8779 Acc val: 0.8649\n",
      "Epoch 330: Cost tr: 0.8855 Cost val: 1.8534 \t Acc tr: 0.8786 Acc val: 0.867\n",
      "Epoch 331: Cost tr: 0.9709 Cost val: 1.7933 \t Acc tr: 0.8778 Acc val: 0.8663\n",
      "Epoch 332: Cost tr: 0.7798 Cost val: 1.791 \t Acc tr: 0.879 Acc val: 0.8672\n",
      "Epoch 333: Cost tr: 1.1572 Cost val: 2.062 \t Acc tr: 0.877 Acc val: 0.8659\n",
      "Epoch 334: Cost tr: 0.9103 Cost val: 1.8285 \t Acc tr: 0.8759 Acc val: 0.8676\n",
      "Epoch 335: Cost tr: 0.8609 Cost val: 1.8788 \t Acc tr: 0.8766 Acc val: 0.8665\n",
      "Epoch 336: Cost tr: 0.8345 Cost val: 1.8577 \t Acc tr: 0.8771 Acc val: 0.8639\n",
      "Epoch 337: Cost tr: 0.9452 Cost val: 2.0591 \t Acc tr: 0.8763 Acc val: 0.8649\n",
      "Epoch 338: Cost tr: 0.9113 Cost val: 1.9573 \t Acc tr: 0.8784 Acc val: 0.8658\n",
      "Epoch 339: Cost tr: 1.0266 Cost val: 2.0902 \t Acc tr: 0.8785 Acc val: 0.8655\n",
      "Epoch 340: Cost tr: 1.3876 Cost val: 2.3211 \t Acc tr: 0.8757 Acc val: 0.8633\n",
      "Epoch 341: Cost tr: 1.2745 Cost val: 2.2168 \t Acc tr: 0.8773 Acc val: 0.8637\n",
      "Epoch 342: Cost tr: 1.236 Cost val: 2.2439 \t Acc tr: 0.8764 Acc val: 0.862\n",
      "Epoch 343: Cost tr: 1.1378 Cost val: 2.0917 \t Acc tr: 0.876 Acc val: 0.8644\n",
      "Epoch 344: Cost tr: 1.0767 Cost val: 2.0413 \t Acc tr: 0.8769 Acc val: 0.8653\n",
      "Epoch 345: Cost tr: 0.7178 Cost val: 1.9056 \t Acc tr: 0.8808 Acc val: 0.866\n",
      "Epoch 346: Cost tr: 0.949 Cost val: 1.7629 \t Acc tr: 0.879 Acc val: 0.8665\n",
      "Epoch 347: Cost tr: 1.0405 Cost val: 1.9032 \t Acc tr: 0.8801 Acc val: 0.8662\n",
      "Epoch 348: Cost tr: 0.973 Cost val: 1.9591 \t Acc tr: 0.8782 Acc val: 0.8654\n",
      "Epoch 349: Cost tr: 0.8061 Cost val: 1.97 \t Acc tr: 0.8786 Acc val: 0.8641\n",
      "Epoch 350: Cost tr: 0.9567 Cost val: 2.0323 \t Acc tr: 0.8782 Acc val: 0.8639\n",
      "Epoch 351: Cost tr: 0.9569 Cost val: 2.0751 \t Acc tr: 0.8791 Acc val: 0.8637\n",
      "Epoch 352: Cost tr: 0.8236 Cost val: 1.9521 \t Acc tr: 0.879 Acc val: 0.8647\n",
      "Epoch 353: Cost tr: 1.0266 Cost val: 1.9587 \t Acc tr: 0.8797 Acc val: 0.8671\n",
      "Epoch 354: Cost tr: 0.9993 Cost val: 1.7917 \t Acc tr: 0.8789 Acc val: 0.8662\n",
      "Epoch 355: Cost tr: 0.8578 Cost val: 1.7985 \t Acc tr: 0.8793 Acc val: 0.8652\n",
      "Epoch 356: Cost tr: 0.6884 Cost val: 1.7298 \t Acc tr: 0.8788 Acc val: 0.8641\n",
      "Epoch 357: Cost tr: 0.9598 Cost val: 1.755 \t Acc tr: 0.8775 Acc val: 0.8662\n",
      "Epoch 358: Cost tr: 0.8797 Cost val: 1.859 \t Acc tr: 0.8791 Acc val: 0.8646\n",
      "Epoch 359: Cost tr: 0.4207 Cost val: 1.544 \t Acc tr: 0.8797 Acc val: 0.865\n",
      "Epoch 360: Cost tr: 0.1877 Cost val: 1.3237 \t Acc tr: 0.8799 Acc val: 0.8645\n",
      "Epoch 361: Cost tr: 0.4568 Cost val: 1.5736 \t Acc tr: 0.8791 Acc val: 0.8647\n",
      "Epoch 362: Cost tr: 0.4783 Cost val: 1.5995 \t Acc tr: 0.8777 Acc val: 0.8641\n",
      "Epoch 363: Cost tr: 0.2311 Cost val: 1.5305 \t Acc tr: 0.8785 Acc val: 0.8649\n",
      "Epoch 364: Cost tr: 0.3872 Cost val: 1.3449 \t Acc tr: 0.8791 Acc val: 0.8653\n",
      "Epoch 365: Cost tr: 0.4466 Cost val: 1.4864 \t Acc tr: 0.8782 Acc val: 0.865\n",
      "Epoch 366: Cost tr: 0.465 Cost val: 1.7425 \t Acc tr: 0.8786 Acc val: 0.8649\n",
      "Epoch 367: Cost tr: 0.4571 Cost val: 1.6908 \t Acc tr: 0.8771 Acc val: 0.8634\n",
      "Epoch 368: Cost tr: 0.8096 Cost val: 1.8189 \t Acc tr: 0.8778 Acc val: 0.8642\n",
      "Epoch 369: Cost tr: 0.5955 Cost val: 1.609 \t Acc tr: 0.8786 Acc val: 0.8651\n",
      "Epoch 370: Cost tr: 0.7874 Cost val: 1.6083 \t Acc tr: 0.8777 Acc val: 0.868\n",
      "Epoch 371: Cost tr: 0.5069 Cost val: 1.6714 \t Acc tr: 0.8795 Acc val: 0.8666\n",
      "Epoch 372: Cost tr: 0.5739 Cost val: 1.6447 \t Acc tr: 0.8792 Acc val: 0.8671\n",
      "Epoch 373: Cost tr: 0.848 Cost val: 1.8458 \t Acc tr: 0.8801 Acc val: 0.8662\n",
      "Epoch 374: Cost tr: 0.7709 Cost val: 1.8661 \t Acc tr: 0.8804 Acc val: 0.8666\n",
      "Epoch 375: Cost tr: 0.6131 Cost val: 1.7858 \t Acc tr: 0.8809 Acc val: 0.8678\n",
      "Epoch 376: Cost tr: 0.8913 Cost val: 1.9973 \t Acc tr: 0.8791 Acc val: 0.867\n",
      "Epoch 377: Cost tr: 0.8733 Cost val: 1.9457 \t Acc tr: 0.8805 Acc val: 0.8673\n",
      "Epoch 378: Cost tr: 0.5951 Cost val: 1.7852 \t Acc tr: 0.8815 Acc val: 0.8663\n",
      "Epoch 379: Cost tr: 0.7 Cost val: 1.7959 \t Acc tr: 0.8799 Acc val: 0.8661\n",
      "Epoch 380: Cost tr: 0.6539 Cost val: 1.7829 \t Acc tr: 0.8811 Acc val: 0.8649\n",
      "Epoch 381: Cost tr: 0.4773 Cost val: 1.6315 \t Acc tr: 0.8812 Acc val: 0.8649\n",
      "Epoch 382: Cost tr: 0.6805 Cost val: 1.7707 \t Acc tr: 0.8794 Acc val: 0.8634\n",
      "Epoch 383: Cost tr: 0.7744 Cost val: 1.8549 \t Acc tr: 0.8779 Acc val: 0.8645\n",
      "Epoch 384: Cost tr: 0.34 Cost val: 1.5891 \t Acc tr: 0.8806 Acc val: 0.8648\n",
      "Epoch 385: Cost tr: 0.0714 Cost val: 1.5051 \t Acc tr: 0.8808 Acc val: 0.8647\n",
      "Epoch 386: Cost tr: 0.3668 Cost val: 1.7993 \t Acc tr: 0.8798 Acc val: 0.8657\n",
      "Epoch 387: Cost tr: 0.2681 Cost val: 1.9204 \t Acc tr: 0.8808 Acc val: 0.8642\n",
      "Epoch 388: Cost tr: 0.1045 Cost val: 1.5275 \t Acc tr: 0.883 Acc val: 0.8649\n",
      "Epoch 389: Cost tr: 0.1864 Cost val: 1.4854 \t Acc tr: 0.8815 Acc val: 0.8651\n",
      "Epoch 390: Cost tr: 0.3848 Cost val: 1.6342 \t Acc tr: 0.8789 Acc val: 0.8659\n",
      "Epoch 391: Cost tr: 0.1764 Cost val: 1.6085 \t Acc tr: 0.8813 Acc val: 0.8648\n",
      "Epoch 392: Cost tr: 0.187 Cost val: 1.5286 \t Acc tr: 0.8809 Acc val: 0.8643\n",
      "Epoch 393: Cost tr: 0.1405 Cost val: 1.5444 \t Acc tr: 0.8815 Acc val: 0.8636\n",
      "Epoch 394: Cost tr: 0.5926 Cost val: 1.8807 \t Acc tr: 0.882 Acc val: 0.8647\n",
      "Epoch 395: Cost tr: 0.5443 Cost val: 1.7014 \t Acc tr: 0.8801 Acc val: 0.8655\n",
      "Epoch 396: Cost tr: 0.4246 Cost val: 1.69 \t Acc tr: 0.8798 Acc val: 0.8649\n",
      "Epoch 397: Cost tr: 0.4312 Cost val: 1.7535 \t Acc tr: 0.8798 Acc val: 0.8658\n",
      "Epoch 398: Cost tr: 0.7167 Cost val: 1.8909 \t Acc tr: 0.8788 Acc val: 0.8648\n",
      "Epoch 399: Cost tr: 0.3968 Cost val: 1.8039 \t Acc tr: 0.8805 Acc val: 0.8641\n",
      "Epoch 400: Cost tr: 0.6657 Cost val: 1.7194 \t Acc tr: 0.8809 Acc val: 0.8653\n",
      "Epoch 401: Cost tr: 0.0517 Cost val: 1.5832 \t Acc tr: 0.8817 Acc val: 0.8657\n",
      "Epoch 402: Cost tr: 0.0509 Cost val: 1.4947 \t Acc tr: 0.8828 Acc val: 0.8661\n",
      "Epoch 403: Cost tr: -0.1088 Cost val: 1.1305 \t Acc tr: 0.8822 Acc val: 0.8691\n",
      "Epoch 404: Cost tr: -0.1941 Cost val: 1.2782 \t Acc tr: 0.8835 Acc val: 0.866\n",
      "Epoch 405: Cost tr: 0.3605 Cost val: 1.5069 \t Acc tr: 0.8816 Acc val: 0.8663\n",
      "Epoch 406: Cost tr: 0.5955 Cost val: 1.6461 \t Acc tr: 0.8819 Acc val: 0.8652\n",
      "Epoch 407: Cost tr: 0.3572 Cost val: 1.6498 \t Acc tr: 0.8821 Acc val: 0.8643\n",
      "Epoch 408: Cost tr: 0.2562 Cost val: 1.6054 \t Acc tr: 0.8825 Acc val: 0.8634\n",
      "Epoch 409: Cost tr: 0.0097 Cost val: 1.342 \t Acc tr: 0.885 Acc val: 0.8661\n",
      "Epoch 410: Cost tr: 0.0245 Cost val: 1.4531 \t Acc tr: 0.8842 Acc val: 0.8643\n",
      "Epoch 411: Cost tr: 0.0772 Cost val: 1.389 \t Acc tr: 0.883 Acc val: 0.8651\n",
      "Epoch 412: Cost tr: 0.0938 Cost val: 1.4589 \t Acc tr: 0.8845 Acc val: 0.8654\n",
      "Epoch 413: Cost tr: 0.4728 Cost val: 1.6467 \t Acc tr: 0.8835 Acc val: 0.8655\n",
      "Epoch 414: Cost tr: 0.5533 Cost val: 1.6601 \t Acc tr: 0.8822 Acc val: 0.8663\n",
      "Epoch 415: Cost tr: 0.7283 Cost val: 1.7993 \t Acc tr: 0.8822 Acc val: 0.8636\n",
      "Epoch 416: Cost tr: 0.3585 Cost val: 1.3787 \t Acc tr: 0.8826 Acc val: 0.8668\n",
      "Epoch 417: Cost tr: 0.175 Cost val: 1.6178 \t Acc tr: 0.8843 Acc val: 0.8663\n",
      "Epoch 418: Cost tr: 0.2162 Cost val: 1.5756 \t Acc tr: 0.8827 Acc val: 0.8632\n",
      "Epoch 419: Cost tr: 0.42 Cost val: 1.4204 \t Acc tr: 0.8805 Acc val: 0.8654\n",
      "Epoch 420: Cost tr: 0.2945 Cost val: 1.5045 \t Acc tr: 0.8833 Acc val: 0.8666\n",
      "Epoch 421: Cost tr: 0.3602 Cost val: 1.6095 \t Acc tr: 0.8823 Acc val: 0.8659\n",
      "Epoch 422: Cost tr: 0.5715 Cost val: 1.5251 \t Acc tr: 0.8791 Acc val: 0.8666\n",
      "Epoch 423: Cost tr: 0.1355 Cost val: 1.3092 \t Acc tr: 0.8808 Acc val: 0.866\n",
      "Epoch 424: Cost tr: -0.089 Cost val: 0.9875 \t Acc tr: 0.8804 Acc val: 0.8672\n",
      "Epoch 425: Cost tr: 0.0759 Cost val: 1.3013 \t Acc tr: 0.8806 Acc val: 0.8654\n",
      "Epoch 426: Cost tr: 0.093 Cost val: 1.253 \t Acc tr: 0.8817 Acc val: 0.8669\n",
      "Epoch 427: Cost tr: 0.0176 Cost val: 1.1019 \t Acc tr: 0.8845 Acc val: 0.8689\n",
      "Epoch 428: Cost tr: 0.2267 Cost val: 1.4608 \t Acc tr: 0.8833 Acc val: 0.8659\n",
      "Epoch 429: Cost tr: 0.4653 Cost val: 1.5427 \t Acc tr: 0.8817 Acc val: 0.8657\n",
      "Epoch 430: Cost tr: 0.2908 Cost val: 1.3992 \t Acc tr: 0.8842 Acc val: 0.8669\n",
      "Epoch 431: Cost tr: 0.2466 Cost val: 1.4484 \t Acc tr: 0.884 Acc val: 0.8654\n",
      "Epoch 432: Cost tr: 0.0997 Cost val: 1.402 \t Acc tr: 0.8844 Acc val: 0.8656\n",
      "Epoch 433: Cost tr: 0.1409 Cost val: 1.172 \t Acc tr: 0.8838 Acc val: 0.8669\n",
      "Epoch 434: Cost tr: 0.0771 Cost val: 1.2025 \t Acc tr: 0.8863 Acc val: 0.8666\n",
      "Epoch 435: Cost tr: 0.2646 Cost val: 1.4493 \t Acc tr: 0.8841 Acc val: 0.8654\n",
      "Epoch 436: Cost tr: 0.4842 Cost val: 1.6304 \t Acc tr: 0.8833 Acc val: 0.8659\n",
      "Epoch 437: Cost tr: 0.3859 Cost val: 1.5012 \t Acc tr: 0.8853 Acc val: 0.8667\n",
      "Epoch 438: Cost tr: 0.4707 Cost val: 1.3547 \t Acc tr: 0.8849 Acc val: 0.8677\n",
      "Epoch 439: Cost tr: 0.517 Cost val: 1.5266 \t Acc tr: 0.8835 Acc val: 0.8669\n",
      "Epoch 440: Cost tr: 0.4055 Cost val: 1.2434 \t Acc tr: 0.8852 Acc val: 0.8676\n",
      "Epoch 441: Cost tr: 0.3674 Cost val: 1.5446 \t Acc tr: 0.8842 Acc val: 0.8665\n",
      "Epoch 442: Cost tr: 0.3191 Cost val: 1.311 \t Acc tr: 0.8853 Acc val: 0.8671\n",
      "Epoch 443: Cost tr: 0.4359 Cost val: 1.4381 \t Acc tr: 0.8846 Acc val: 0.8662\n",
      "Epoch 444: Cost tr: 0.5012 Cost val: 1.6205 \t Acc tr: 0.8832 Acc val: 0.8658\n",
      "Epoch 445: Cost tr: 0.0898 Cost val: 1.241 \t Acc tr: 0.8847 Acc val: 0.867\n",
      "Epoch 446: Cost tr: 0.0918 Cost val: 1.243 \t Acc tr: 0.8836 Acc val: 0.865\n",
      "Epoch 447: Cost tr: 0.5321 Cost val: 1.5583 \t Acc tr: 0.8837 Acc val: 0.8658\n",
      "Epoch 448: Cost tr: -0.0428 Cost val: 1.3495 \t Acc tr: 0.8851 Acc val: 0.8642\n",
      "Epoch 449: Cost tr: -0.1277 Cost val: 1.0477 \t Acc tr: 0.8842 Acc val: 0.8673\n",
      "Epoch 450: Cost tr: 0.3768 Cost val: 1.3224 \t Acc tr: 0.8826 Acc val: 0.8658\n",
      "Epoch 451: Cost tr: 0.4208 Cost val: 1.3546 \t Acc tr: 0.8835 Acc val: 0.8676\n",
      "Epoch 452: Cost tr: 0.465 Cost val: 1.3878 \t Acc tr: 0.8843 Acc val: 0.8674\n",
      "Epoch 453: Cost tr: 0.2326 Cost val: 1.2779 \t Acc tr: 0.886 Acc val: 0.8691\n",
      "Epoch 454: Cost tr: 0.0185 Cost val: 1.0934 \t Acc tr: 0.8876 Acc val: 0.8686\n",
      "Epoch 455: Cost tr: 0.2885 Cost val: 1.4984 \t Acc tr: 0.8866 Acc val: 0.8677\n",
      "Epoch 456: Cost tr: 0.182 Cost val: 1.4824 \t Acc tr: 0.8886 Acc val: 0.8673\n",
      "Epoch 457: Cost tr: 0.3876 Cost val: 1.6563 \t Acc tr: 0.8874 Acc val: 0.8663\n",
      "Epoch 458: Cost tr: 0.5541 Cost val: 1.7114 \t Acc tr: 0.8866 Acc val: 0.8684\n",
      "Epoch 459: Cost tr: 0.4183 Cost val: 1.5136 \t Acc tr: 0.8877 Acc val: 0.8688\n",
      "Epoch 460: Cost tr: 0.3209 Cost val: 1.3818 \t Acc tr: 0.8864 Acc val: 0.869\n",
      "Epoch 461: Cost tr: 0.167 Cost val: 1.1035 \t Acc tr: 0.8885 Acc val: 0.8715\n",
      "Epoch 462: Cost tr: -0.0502 Cost val: 0.904 \t Acc tr: 0.8875 Acc val: 0.8705\n",
      "Epoch 463: Cost tr: 0.1463 Cost val: 1.1132 \t Acc tr: 0.8893 Acc val: 0.8693\n",
      "Epoch 464: Cost tr: 0.1835 Cost val: 0.9703 \t Acc tr: 0.8875 Acc val: 0.8732\n",
      "Epoch 465: Cost tr: -0.0159 Cost val: 1.0267 \t Acc tr: 0.8876 Acc val: 0.87\n",
      "Epoch 466: Cost tr: 0.1549 Cost val: 1.08 \t Acc tr: 0.8874 Acc val: 0.8695\n",
      "Epoch 467: Cost tr: 0.1572 Cost val: 0.9824 \t Acc tr: 0.8866 Acc val: 0.8719\n",
      "Epoch 468: Cost tr: 0.188 Cost val: 0.8677 \t Acc tr: 0.8872 Acc val: 0.872\n",
      "Epoch 469: Cost tr: -0.0224 Cost val: 0.9363 \t Acc tr: 0.8876 Acc val: 0.8693\n",
      "Epoch 470: Cost tr: -0.0445 Cost val: 0.8555 \t Acc tr: 0.8891 Acc val: 0.8726\n",
      "Epoch 471: Cost tr: 0.0557 Cost val: 0.9197 \t Acc tr: 0.8886 Acc val: 0.8728\n",
      "Epoch 472: Cost tr: -0.006 Cost val: 0.7924 \t Acc tr: 0.8891 Acc val: 0.8698\n",
      "Epoch 473: Cost tr: 0.0728 Cost val: 0.6531 \t Acc tr: 0.8871 Acc val: 0.8731\n",
      "Epoch 474: Cost tr: 0.3269 Cost val: 1.0107 \t Acc tr: 0.8887 Acc val: 0.8696\n",
      "Epoch 475: Cost tr: 0.0213 Cost val: 0.8106 \t Acc tr: 0.8884 Acc val: 0.8723\n",
      "Epoch 476: Cost tr: -0.1268 Cost val: 0.7367 \t Acc tr: 0.8911 Acc val: 0.8735\n",
      "Epoch 477: Cost tr: 0.432 Cost val: 0.999 \t Acc tr: 0.8876 Acc val: 0.8713\n",
      "Epoch 478: Cost tr: 0.2278 Cost val: 1.1091 \t Acc tr: 0.8885 Acc val: 0.8698\n",
      "Epoch 479: Cost tr: 0.1513 Cost val: 0.8507 \t Acc tr: 0.8897 Acc val: 0.873\n",
      "Epoch 480: Cost tr: -0.0147 Cost val: 0.8385 \t Acc tr: 0.889 Acc val: 0.8746\n",
      "Epoch 481: Cost tr: 0.1305 Cost val: 0.9905 \t Acc tr: 0.8892 Acc val: 0.8737\n",
      "Epoch 482: Cost tr: 0.0097 Cost val: 0.7667 \t Acc tr: 0.8899 Acc val: 0.8737\n",
      "Epoch 483: Cost tr: -0.1168 Cost val: 0.7558 \t Acc tr: 0.8916 Acc val: 0.8734\n",
      "Epoch 484: Cost tr: 0.1442 Cost val: 1.0259 \t Acc tr: 0.8913 Acc val: 0.871\n",
      "Epoch 485: Cost tr: -0.2112 Cost val: 0.3673 \t Acc tr: 0.8912 Acc val: 0.8746\n",
      "Epoch 486: Cost tr: -0.0696 Cost val: 0.856 \t Acc tr: 0.893 Acc val: 0.8718\n",
      "Epoch 487: Cost tr: 0.0572 Cost val: 1.2241 \t Acc tr: 0.8919 Acc val: 0.8693\n",
      "Epoch 488: Cost tr: -0.0937 Cost val: 1.0877 \t Acc tr: 0.8926 Acc val: 0.8716\n",
      "Epoch 489: Cost tr: 0.0852 Cost val: 0.8827 \t Acc tr: 0.8886 Acc val: 0.8751\n",
      "Epoch 490: Cost tr: -0.1262 Cost val: 0.9453 \t Acc tr: 0.8899 Acc val: 0.8745\n",
      "Epoch 491: Cost tr: -0.0779 Cost val: 0.7832 \t Acc tr: 0.8898 Acc val: 0.8738\n",
      "Epoch 492: Cost tr: 0.3474 Cost val: 0.9192 \t Acc tr: 0.8919 Acc val: 0.8735\n",
      "Epoch 493: Cost tr: 0.4118 Cost val: 1.192 \t Acc tr: 0.8908 Acc val: 0.872\n",
      "Epoch 494: Cost tr: 0.5102 Cost val: 1.0621 \t Acc tr: 0.8912 Acc val: 0.873\n",
      "Epoch 495: Cost tr: 0.2718 Cost val: 1.1167 \t Acc tr: 0.8927 Acc val: 0.8729\n",
      "Epoch 496: Cost tr: 0.0872 Cost val: 0.7838 \t Acc tr: 0.891 Acc val: 0.8745\n",
      "Epoch 497: Cost tr: -0.1048 Cost val: 0.6126 \t Acc tr: 0.8931 Acc val: 0.8755\n",
      "Epoch 498: Cost tr: 0.1436 Cost val: 0.8753 \t Acc tr: 0.8935 Acc val: 0.8718\n",
      "Epoch 499: Cost tr: -0.0495 Cost val: 0.6725 \t Acc tr: 0.8926 Acc val: 0.8743\n",
      "Epoch 500: Cost tr: -0.137 Cost val: 0.5902 \t Acc tr: 0.8943 Acc val: 0.8755\n",
      "Epoch 501: Cost tr: 0.2096 Cost val: 0.9862 \t Acc tr: 0.8905 Acc val: 0.8716\n",
      "Epoch 502: Cost tr: 0.3249 Cost val: 1.047 \t Acc tr: 0.8921 Acc val: 0.8731\n",
      "Epoch 503: Cost tr: 0.1355 Cost val: 0.9259 \t Acc tr: 0.8927 Acc val: 0.8725\n",
      "Epoch 504: Cost tr: 0.1323 Cost val: 0.9902 \t Acc tr: 0.894 Acc val: 0.8733\n",
      "Epoch 505: Cost tr: 0.1116 Cost val: 0.8052 \t Acc tr: 0.8954 Acc val: 0.8762\n",
      "Epoch 506: Cost tr: -0.161 Cost val: 0.5658 \t Acc tr: 0.8954 Acc val: 0.8763\n",
      "Epoch 507: Cost tr: 0.1956 Cost val: 1.0091 \t Acc tr: 0.8934 Acc val: 0.8725\n",
      "Epoch 508: Cost tr: 0.0939 Cost val: 0.9922 \t Acc tr: 0.8955 Acc val: 0.875\n",
      "Epoch 509: Cost tr: 0.2746 Cost val: 1.1798 \t Acc tr: 0.8938 Acc val: 0.8716\n",
      "Epoch 510: Cost tr: 0.2083 Cost val: 1.0232 \t Acc tr: 0.893 Acc val: 0.8723\n",
      "Epoch 511: Cost tr: 0.0607 Cost val: 0.7791 \t Acc tr: 0.8955 Acc val: 0.8739\n",
      "Epoch 512: Cost tr: 0.0376 Cost val: 0.8034 \t Acc tr: 0.8955 Acc val: 0.8732\n",
      "Epoch 513: Cost tr: 0.2556 Cost val: 0.927 \t Acc tr: 0.894 Acc val: 0.8719\n",
      "Epoch 514: Cost tr: 0.0805 Cost val: 0.6517 \t Acc tr: 0.8963 Acc val: 0.8735\n",
      "Epoch 515: Cost tr: 0.0457 Cost val: 0.7497 \t Acc tr: 0.8968 Acc val: 0.8742\n",
      "Epoch 516: Cost tr: 0.3716 Cost val: 1.2117 \t Acc tr: 0.8951 Acc val: 0.8718\n",
      "Epoch 517: Cost tr: 0.226 Cost val: 1.0388 \t Acc tr: 0.8929 Acc val: 0.8724\n",
      "Epoch 518: Cost tr: 0.0385 Cost val: 0.8166 \t Acc tr: 0.8943 Acc val: 0.8752\n",
      "Epoch 519: Cost tr: 0.0977 Cost val: 0.89 \t Acc tr: 0.896 Acc val: 0.8759\n",
      "Epoch 520: Cost tr: 0.2599 Cost val: 0.9168 \t Acc tr: 0.8944 Acc val: 0.874\n",
      "Epoch 521: Cost tr: -0.1001 Cost val: 0.8838 \t Acc tr: 0.8962 Acc val: 0.8726\n",
      "Epoch 522: Cost tr: -0.1289 Cost val: 0.5438 \t Acc tr: 0.8965 Acc val: 0.8742\n",
      "Epoch 523: Cost tr: -0.0869 Cost val: 0.6537 \t Acc tr: 0.8979 Acc val: 0.8757\n",
      "Epoch 524: Cost tr: 0.3195 Cost val: 0.7373 \t Acc tr: 0.8964 Acc val: 0.8762\n",
      "Epoch 525: Cost tr: 0.5579 Cost val: 1.197 \t Acc tr: 0.8973 Acc val: 0.8759\n",
      "Epoch 526: Cost tr: 0.5196 Cost val: 1.2503 \t Acc tr: 0.8985 Acc val: 0.8748\n",
      "Epoch 527: Cost tr: 0.2758 Cost val: 0.9779 \t Acc tr: 0.8966 Acc val: 0.8726\n",
      "Epoch 528: Cost tr: 0.2454 Cost val: 0.7929 \t Acc tr: 0.8986 Acc val: 0.877\n",
      "Epoch 529: Cost tr: -0.1084 Cost val: 0.4098 \t Acc tr: 0.8971 Acc val: 0.8766\n",
      "Epoch 530: Cost tr: -0.2685 Cost val: 0.7046 \t Acc tr: 0.9001 Acc val: 0.8745\n",
      "Epoch 531: Cost tr: -0.0078 Cost val: 0.8422 \t Acc tr: 0.8993 Acc val: 0.8754\n",
      "Epoch 532: Cost tr: 0.2944 Cost val: 0.8797 \t Acc tr: 0.8992 Acc val: 0.8764\n",
      "Epoch 533: Cost tr: 0.3496 Cost val: 0.8884 \t Acc tr: 0.8999 Acc val: 0.8769\n",
      "Epoch 534: Cost tr: 0.458 Cost val: 1.165 \t Acc tr: 0.8975 Acc val: 0.8739\n",
      "Epoch 535: Cost tr: 0.0331 Cost val: 0.4172 \t Acc tr: 0.8997 Acc val: 0.8771\n",
      "Epoch 536: Cost tr: 0.2655 Cost val: 0.5218 \t Acc tr: 0.8996 Acc val: 0.8753\n",
      "Epoch 537: Cost tr: 0.1917 Cost val: 0.5749 \t Acc tr: 0.8988 Acc val: 0.8751\n",
      "Epoch 538: Cost tr: 0.0652 Cost val: 0.5327 \t Acc tr: 0.9005 Acc val: 0.8768\n",
      "Epoch 539: Cost tr: 0.1295 Cost val: 0.5929 \t Acc tr: 0.8993 Acc val: 0.8796\n",
      "Epoch 540: Cost tr: -0.071 Cost val: 0.4646 \t Acc tr: 0.8987 Acc val: 0.8788\n",
      "Epoch 541: Cost tr: 0.1551 Cost val: 0.9538 \t Acc tr: 0.8989 Acc val: 0.8773\n",
      "Epoch 542: Cost tr: -0.0431 Cost val: 0.3438 \t Acc tr: 0.903 Acc val: 0.8768\n",
      "Epoch 543: Cost tr: 0.338 Cost val: 0.568 \t Acc tr: 0.9001 Acc val: 0.8787\n",
      "Epoch 544: Cost tr: 0.1703 Cost val: 0.7954 \t Acc tr: 0.9006 Acc val: 0.8771\n",
      "Epoch 545: Cost tr: 0.0339 Cost val: 0.3864 \t Acc tr: 0.9025 Acc val: 0.8747\n",
      "Epoch 546: Cost tr: 0.1887 Cost val: 0.694 \t Acc tr: 0.9023 Acc val: 0.8769\n",
      "Epoch 547: Cost tr: 0.4106 Cost val: 0.6792 \t Acc tr: 0.902 Acc val: 0.8773\n",
      "Epoch 548: Cost tr: 0.1292 Cost val: 0.8169 \t Acc tr: 0.9036 Acc val: 0.8766\n",
      "Epoch 549: Cost tr: 0.2219 Cost val: 0.7729 \t Acc tr: 0.9038 Acc val: 0.8788\n",
      "Epoch 550: Cost tr: 0.2693 Cost val: 0.6909 \t Acc tr: 0.9043 Acc val: 0.8804\n",
      "Epoch 551: Cost tr: -0.1079 Cost val: 0.7689 \t Acc tr: 0.9033 Acc val: 0.8801\n",
      "Epoch 552: Cost tr: 0.0273 Cost val: 0.3832 \t Acc tr: 0.9051 Acc val: 0.8809\n",
      "Epoch 553: Cost tr: 0.2006 Cost val: 0.6686 \t Acc tr: 0.903 Acc val: 0.8786\n",
      "Epoch 554: Cost tr: 0.0753 Cost val: 0.3683 \t Acc tr: 0.9011 Acc val: 0.8799\n",
      "Epoch 555: Cost tr: 0.4053 Cost val: 0.7689 \t Acc tr: 0.9031 Acc val: 0.8806\n",
      "Epoch 556: Cost tr: 0.3098 Cost val: 0.7116 \t Acc tr: 0.905 Acc val: 0.8803\n",
      "Epoch 557: Cost tr: 0.4356 Cost val: 1.1966 \t Acc tr: 0.9046 Acc val: 0.8778\n",
      "Epoch 558: Cost tr: 0.5689 Cost val: 0.8782 \t Acc tr: 0.9026 Acc val: 0.8791\n",
      "Epoch 559: Cost tr: 0.3846 Cost val: 0.3714 \t Acc tr: 0.9046 Acc val: 0.8815\n",
      "Epoch 560: Cost tr: 0.2774 Cost val: 1.034 \t Acc tr: 0.9035 Acc val: 0.88\n",
      "Epoch 561: Cost tr: 0.0885 Cost val: 0.5194 \t Acc tr: 0.9041 Acc val: 0.8792\n",
      "Epoch 562: Cost tr: 0.0702 Cost val: 0.9079 \t Acc tr: 0.9077 Acc val: 0.8796\n",
      "Epoch 563: Cost tr: 0.1142 Cost val: 0.5192 \t Acc tr: 0.9057 Acc val: 0.8809\n",
      "Epoch 564: Cost tr: 0.0336 Cost val: 0.7257 \t Acc tr: 0.9039 Acc val: 0.8816\n",
      "Epoch 565: Cost tr: 0.2889 Cost val: 0.7999 \t Acc tr: 0.9065 Acc val: 0.8811\n",
      "Epoch 566: Cost tr: 0.4057 Cost val: 0.8317 \t Acc tr: 0.906 Acc val: 0.8805\n",
      "Epoch 567: Cost tr: 0.3025 Cost val: 0.6962 \t Acc tr: 0.906 Acc val: 0.8809\n",
      "Epoch 568: Cost tr: 0.2092 Cost val: 0.5284 \t Acc tr: 0.9059 Acc val: 0.8809\n",
      "Epoch 569: Cost tr: 0.1448 Cost val: 0.723 \t Acc tr: 0.9068 Acc val: 0.881\n",
      "Epoch 570: Cost tr: 0.0115 Cost val: 0.2412 \t Acc tr: 0.9058 Acc val: 0.8834\n",
      "Epoch 571: Cost tr: 0.2056 Cost val: 0.5512 \t Acc tr: 0.9065 Acc val: 0.8837\n",
      "Epoch 572: Cost tr: 0.334 Cost val: 0.6881 \t Acc tr: 0.9076 Acc val: 0.8828\n",
      "Epoch 573: Cost tr: 0.4458 Cost val: 0.7351 \t Acc tr: 0.906 Acc val: 0.882\n",
      "Epoch 574: Cost tr: 0.5769 Cost val: 0.8297 \t Acc tr: 0.9068 Acc val: 0.8809\n",
      "Epoch 575: Cost tr: 0.0072 Cost val: 0.6798 \t Acc tr: 0.9069 Acc val: 0.8808\n",
      "Epoch 576: Cost tr: 0.2337 Cost val: 0.5974 \t Acc tr: 0.9084 Acc val: 0.8812\n",
      "Epoch 577: Cost tr: 0.1973 Cost val: 0.7715 \t Acc tr: 0.9098 Acc val: 0.8827\n",
      "Epoch 578: Cost tr: 0.3501 Cost val: 1.0487 \t Acc tr: 0.9098 Acc val: 0.8807\n",
      "Epoch 579: Cost tr: 0.522 Cost val: 1.248 \t Acc tr: 0.9103 Acc val: 0.8804\n",
      "Epoch 580: Cost tr: 0.2082 Cost val: 0.8884 \t Acc tr: 0.9123 Acc val: 0.8811\n",
      "Epoch 581: Cost tr: 0.1894 Cost val: 0.8222 \t Acc tr: 0.911 Acc val: 0.8837\n",
      "Epoch 582: Cost tr: 0.1844 Cost val: 0.6928 \t Acc tr: 0.9086 Acc val: 0.8837\n",
      "Epoch 583: Cost tr: 0.5004 Cost val: 0.8799 \t Acc tr: 0.9065 Acc val: 0.8825\n",
      "Epoch 584: Cost tr: 0.4094 Cost val: 0.8761 \t Acc tr: 0.9071 Acc val: 0.8824\n",
      "Epoch 585: Cost tr: 0.5786 Cost val: 0.9298 \t Acc tr: 0.9086 Acc val: 0.8827\n",
      "Epoch 586: Cost tr: 0.428 Cost val: 0.9655 \t Acc tr: 0.909 Acc val: 0.8808\n",
      "Epoch 587: Cost tr: 0.1398 Cost val: 0.7513 \t Acc tr: 0.9124 Acc val: 0.8815\n",
      "Epoch 588: Cost tr: 0.2793 Cost val: 0.8414 \t Acc tr: 0.9102 Acc val: 0.8816\n",
      "Epoch 589: Cost tr: 0.3454 Cost val: 1.0562 \t Acc tr: 0.9096 Acc val: 0.8804\n",
      "Epoch 590: Cost tr: 0.6801 Cost val: 1.1198 \t Acc tr: 0.9088 Acc val: 0.8796\n",
      "Epoch 591: Cost tr: 0.255 Cost val: 0.5703 \t Acc tr: 0.9107 Acc val: 0.8842\n",
      "Epoch 592: Cost tr: 0.4363 Cost val: 0.7663 \t Acc tr: 0.9127 Acc val: 0.8826\n",
      "Epoch 593: Cost tr: 0.6998 Cost val: 0.9359 \t Acc tr: 0.9092 Acc val: 0.8813\n",
      "Epoch 594: Cost tr: 0.1877 Cost val: 0.7625 \t Acc tr: 0.9123 Acc val: 0.8828\n",
      "Epoch 595: Cost tr: 0.379 Cost val: 1.1754 \t Acc tr: 0.9108 Acc val: 0.8818\n",
      "Epoch 596: Cost tr: 0.3439 Cost val: 0.8218 \t Acc tr: 0.9092 Acc val: 0.8829\n",
      "Epoch 597: Cost tr: 0.3431 Cost val: 0.9624 \t Acc tr: 0.9116 Acc val: 0.8815\n",
      "Epoch 598: Cost tr: 0.0544 Cost val: 0.4308 \t Acc tr: 0.9105 Acc val: 0.8834\n",
      "Epoch 599: Cost tr: 0.2948 Cost val: 0.6565 \t Acc tr: 0.9125 Acc val: 0.8836\n",
      "Epoch 600: Cost tr: 0.24 Cost val: 0.7917 \t Acc tr: 0.9108 Acc val: 0.881\n",
      "Epoch 601: Cost tr: 0.5356 Cost val: 1.0102 \t Acc tr: 0.9109 Acc val: 0.8817\n",
      "Epoch 602: Cost tr: 0.2824 Cost val: 0.8607 \t Acc tr: 0.9116 Acc val: 0.8823\n",
      "Epoch 603: Cost tr: 0.4831 Cost val: 1.0275 \t Acc tr: 0.9104 Acc val: 0.8824\n",
      "Epoch 604: Cost tr: 0.5134 Cost val: 0.832 \t Acc tr: 0.9097 Acc val: 0.8838\n",
      "Epoch 605: Cost tr: 0.6808 Cost val: 1.2228 \t Acc tr: 0.9115 Acc val: 0.8841\n",
      "Epoch 606: Cost tr: 0.6635 Cost val: 1.3419 \t Acc tr: 0.9139 Acc val: 0.8832\n",
      "Epoch 607: Cost tr: 0.3353 Cost val: 1.3332 \t Acc tr: 0.9141 Acc val: 0.8803\n",
      "Epoch 608: Cost tr: 0.3113 Cost val: 1.0384 \t Acc tr: 0.9117 Acc val: 0.883\n",
      "Epoch 609: Cost tr: 0.2225 Cost val: 0.9673 \t Acc tr: 0.9121 Acc val: 0.8812\n",
      "Epoch 610: Cost tr: 0.4012 Cost val: 0.7946 \t Acc tr: 0.9129 Acc val: 0.8814\n",
      "Epoch 611: Cost tr: 0.0242 Cost val: 0.5135 \t Acc tr: 0.9131 Acc val: 0.8826\n",
      "Epoch 612: Cost tr: 0.2112 Cost val: 0.7509 \t Acc tr: 0.9154 Acc val: 0.8846\n",
      "Epoch 613: Cost tr: 0.7281 Cost val: 1.3616 \t Acc tr: 0.9116 Acc val: 0.8798\n",
      "Epoch 614: Cost tr: 0.6041 Cost val: 1.317 \t Acc tr: 0.9127 Acc val: 0.8823\n",
      "Epoch 615: Cost tr: 0.6517 Cost val: 1.0352 \t Acc tr: 0.9125 Acc val: 0.8795\n",
      "Epoch 616: Cost tr: 0.4274 Cost val: 0.7764 \t Acc tr: 0.9146 Acc val: 0.8823\n",
      "Epoch 617: Cost tr: -0.1087 Cost val: 0.5597 \t Acc tr: 0.9145 Acc val: 0.8818\n",
      "Epoch 618: Cost tr: -0.1518 Cost val: 0.4638 \t Acc tr: 0.9152 Acc val: 0.8806\n",
      "Epoch 619: Cost tr: 0.1361 Cost val: 0.7309 \t Acc tr: 0.9147 Acc val: 0.8823\n",
      "Epoch 620: Cost tr: 0.2633 Cost val: 0.7761 \t Acc tr: 0.9134 Acc val: 0.8822\n",
      "Epoch 621: Cost tr: 0.5747 Cost val: 1.3789 \t Acc tr: 0.9161 Acc val: 0.8818\n",
      "Epoch 622: Cost tr: 0.6297 Cost val: 1.0695 \t Acc tr: 0.9146 Acc val: 0.8847\n",
      "Epoch 623: Cost tr: 0.1774 Cost val: 0.9089 \t Acc tr: 0.9151 Acc val: 0.8838\n",
      "Epoch 624: Cost tr: 0.4776 Cost val: 1.1775 \t Acc tr: 0.9148 Acc val: 0.8803\n",
      "Epoch 625: Cost tr: 0.693 Cost val: 1.0046 \t Acc tr: 0.9145 Acc val: 0.8834\n",
      "Epoch 626: Cost tr: 0.3576 Cost val: 0.9447 \t Acc tr: 0.9179 Acc val: 0.881\n",
      "Epoch 627: Cost tr: 0.067 Cost val: 0.619 \t Acc tr: 0.9173 Acc val: 0.8838\n",
      "Epoch 628: Cost tr: 0.2004 Cost val: 0.9309 \t Acc tr: 0.9199 Acc val: 0.8809\n",
      "Epoch 629: Cost tr: 0.1433 Cost val: 0.7883 \t Acc tr: 0.9172 Acc val: 0.8813\n",
      "Epoch 630: Cost tr: 0.1736 Cost val: 0.554 \t Acc tr: 0.9182 Acc val: 0.8853\n",
      "Epoch 631: Cost tr: 0.1189 Cost val: 0.8247 \t Acc tr: 0.9176 Acc val: 0.8837\n",
      "Epoch 632: Cost tr: 0.6039 Cost val: 1.2526 \t Acc tr: 0.9195 Acc val: 0.8814\n",
      "Epoch 633: Cost tr: 0.4318 Cost val: 1.2124 \t Acc tr: 0.919 Acc val: 0.8826\n",
      "Epoch 634: Cost tr: 0.2896 Cost val: 0.9775 \t Acc tr: 0.9205 Acc val: 0.8823\n",
      "Epoch 635: Cost tr: 0.0566 Cost val: 0.6206 \t Acc tr: 0.9188 Acc val: 0.8831\n",
      "Epoch 636: Cost tr: -0.0238 Cost val: 0.8538 \t Acc tr: 0.9182 Acc val: 0.8844\n",
      "Epoch 637: Cost tr: 0.2712 Cost val: 1.2683 \t Acc tr: 0.917 Acc val: 0.8808\n",
      "Epoch 638: Cost tr: 0.3635 Cost val: 1.5027 \t Acc tr: 0.918 Acc val: 0.8816\n",
      "Epoch 639: Cost tr: 0.5814 Cost val: 1.4703 \t Acc tr: 0.9191 Acc val: 0.8831\n",
      "Epoch 640: Cost tr: 0.4341 Cost val: 1.0165 \t Acc tr: 0.9177 Acc val: 0.8854\n",
      "Epoch 641: Cost tr: 0.2812 Cost val: 1.28 \t Acc tr: 0.9188 Acc val: 0.8855\n",
      "Epoch 642: Cost tr: 0.5841 Cost val: 1.3587 \t Acc tr: 0.9187 Acc val: 0.8831\n",
      "Epoch 643: Cost tr: 0.261 Cost val: 1.1909 \t Acc tr: 0.9173 Acc val: 0.8826\n",
      "Epoch 644: Cost tr: 0.2437 Cost val: 1.1368 \t Acc tr: 0.9207 Acc val: 0.882\n",
      "Epoch 645: Cost tr: 0.4877 Cost val: 1.1484 \t Acc tr: 0.9186 Acc val: 0.881\n",
      "Epoch 646: Cost tr: 0.2846 Cost val: 1.0368 \t Acc tr: 0.9222 Acc val: 0.8841\n",
      "Epoch 647: Cost tr: 0.371 Cost val: 1.001 \t Acc tr: 0.9209 Acc val: 0.8826\n",
      "Epoch 648: Cost tr: 0.3749 Cost val: 1.4139 \t Acc tr: 0.9202 Acc val: 0.8841\n",
      "Epoch 649: Cost tr: 0.506 Cost val: 1.3518 \t Acc tr: 0.9209 Acc val: 0.8829\n",
      "Epoch 650: Cost tr: 0.3412 Cost val: 1.0547 \t Acc tr: 0.9215 Acc val: 0.8862\n",
      "Epoch 651: Cost tr: 0.4432 Cost val: 0.7024 \t Acc tr: 0.9206 Acc val: 0.8865\n",
      "Epoch 652: Cost tr: 0.6071 Cost val: 1.4006 \t Acc tr: 0.9238 Acc val: 0.8852\n",
      "Epoch 653: Cost tr: 0.2546 Cost val: 1.3047 \t Acc tr: 0.9219 Acc val: 0.8823\n",
      "Epoch 654: Cost tr: 0.5701 Cost val: 1.6569 \t Acc tr: 0.9222 Acc val: 0.883\n",
      "Epoch 655: Cost tr: 0.2417 Cost val: 1.2314 \t Acc tr: 0.9243 Acc val: 0.8862\n",
      "Epoch 656: Cost tr: 0.3358 Cost val: 1.1554 \t Acc tr: 0.9228 Acc val: 0.8847\n",
      "Epoch 657: Cost tr: 0.4017 Cost val: 1.0624 \t Acc tr: 0.926 Acc val: 0.8851\n",
      "Epoch 658: Cost tr: 0.5845 Cost val: 1.2032 \t Acc tr: 0.9235 Acc val: 0.8849\n",
      "Epoch 659: Cost tr: 0.4903 Cost val: 1.3046 \t Acc tr: 0.9254 Acc val: 0.8853\n",
      "Epoch 660: Cost tr: 0.5923 Cost val: 1.4976 \t Acc tr: 0.9237 Acc val: 0.8847\n",
      "Epoch 661: Cost tr: 0.5195 Cost val: 1.3634 \t Acc tr: 0.9259 Acc val: 0.8842\n",
      "Epoch 662: Cost tr: 0.4017 Cost val: 1.1313 \t Acc tr: 0.9249 Acc val: 0.8859\n",
      "Epoch 663: Cost tr: 0.3042 Cost val: 1.2236 \t Acc tr: 0.9258 Acc val: 0.8866\n",
      "Epoch 664: Cost tr: 0.5245 Cost val: 1.2695 \t Acc tr: 0.9229 Acc val: 0.8862\n",
      "Epoch 665: Cost tr: 0.4465 Cost val: 1.3322 \t Acc tr: 0.9251 Acc val: 0.8862\n",
      "Epoch 666: Cost tr: 0.1881 Cost val: 0.9504 \t Acc tr: 0.9243 Acc val: 0.8858\n",
      "Epoch 667: Cost tr: -0.0011 Cost val: 1.0398 \t Acc tr: 0.9237 Acc val: 0.8852\n",
      "Epoch 668: Cost tr: 0.4649 Cost val: 1.3414 \t Acc tr: 0.9231 Acc val: 0.884\n",
      "Epoch 669: Cost tr: 0.4586 Cost val: 0.9216 \t Acc tr: 0.9248 Acc val: 0.8875\n",
      "Epoch 670: Cost tr: 0.3043 Cost val: 1.0841 \t Acc tr: 0.9264 Acc val: 0.8879\n",
      "Epoch 671: Cost tr: 0.2699 Cost val: 1.0476 \t Acc tr: 0.9255 Acc val: 0.8875\n",
      "Epoch 672: Cost tr: 0.3873 Cost val: 1.4004 \t Acc tr: 0.9282 Acc val: 0.8854\n",
      "Epoch 673: Cost tr: 1.0348 Cost val: 1.8744 \t Acc tr: 0.9259 Acc val: 0.8864\n",
      "Epoch 674: Cost tr: 0.6291 Cost val: 1.5752 \t Acc tr: 0.926 Acc val: 0.8866\n",
      "Epoch 675: Cost tr: 0.6735 Cost val: 1.2982 \t Acc tr: 0.9276 Acc val: 0.8864\n",
      "Epoch 676: Cost tr: 0.493 Cost val: 1.1728 \t Acc tr: 0.9265 Acc val: 0.8875\n",
      "Epoch 677: Cost tr: 0.1888 Cost val: 1.061 \t Acc tr: 0.93 Acc val: 0.8885\n",
      "Epoch 678: Cost tr: 0.1177 Cost val: 1.1033 \t Acc tr: 0.9271 Acc val: 0.8857\n",
      "Epoch 679: Cost tr: 0.1809 Cost val: 1.1339 \t Acc tr: 0.9269 Acc val: 0.8876\n",
      "Epoch 680: Cost tr: 0.1085 Cost val: 1.083 \t Acc tr: 0.9297 Acc val: 0.8871\n",
      "Epoch 681: Cost tr: 0.4191 Cost val: 1.3754 \t Acc tr: 0.928 Acc val: 0.8861\n",
      "Epoch 682: Cost tr: 0.3601 Cost val: 1.5543 \t Acc tr: 0.9287 Acc val: 0.8863\n",
      "Epoch 683: Cost tr: 0.3552 Cost val: 1.051 \t Acc tr: 0.928 Acc val: 0.8873\n",
      "Epoch 684: Cost tr: 0.1842 Cost val: 1.258 \t Acc tr: 0.9277 Acc val: 0.8869\n",
      "Epoch 685: Cost tr: 0.403 Cost val: 1.2823 \t Acc tr: 0.9273 Acc val: 0.8863\n",
      "Epoch 686: Cost tr: 0.7944 Cost val: 1.7038 \t Acc tr: 0.9261 Acc val: 0.8881\n",
      "Epoch 687: Cost tr: 0.6106 Cost val: 2.2807 \t Acc tr: 0.9281 Acc val: 0.8885\n",
      "Epoch 688: Cost tr: 0.8208 Cost val: 2.2273 \t Acc tr: 0.9269 Acc val: 0.8883\n",
      "Epoch 689: Cost tr: 0.2731 Cost val: 1.7645 \t Acc tr: 0.9319 Acc val: 0.8895\n",
      "Epoch 690: Cost tr: -0.186 Cost val: 1.105 \t Acc tr: 0.9277 Acc val: 0.8894\n",
      "Epoch 691: Cost tr: 0.0841 Cost val: 0.9166 \t Acc tr: 0.9303 Acc val: 0.891\n",
      "Epoch 692: Cost tr: 0.0203 Cost val: 0.9924 \t Acc tr: 0.93 Acc val: 0.8891\n",
      "Epoch 693: Cost tr: -0.066 Cost val: 0.8284 \t Acc tr: 0.9307 Acc val: 0.8896\n",
      "Epoch 694: Cost tr: 0.3897 Cost val: 1.3463 \t Acc tr: 0.9297 Acc val: 0.8885\n",
      "Epoch 695: Cost tr: 0.2578 Cost val: 1.2595 \t Acc tr: 0.9282 Acc val: 0.8875\n",
      "Epoch 696: Cost tr: 0.1908 Cost val: 1.2341 \t Acc tr: 0.9336 Acc val: 0.8891\n",
      "Epoch 697: Cost tr: 0.2626 Cost val: 1.2037 \t Acc tr: 0.9327 Acc val: 0.8902\n",
      "Epoch 698: Cost tr: 0.3288 Cost val: 1.2202 \t Acc tr: 0.932 Acc val: 0.8891\n",
      "Epoch 699: Cost tr: 0.1318 Cost val: 1.2404 \t Acc tr: 0.93 Acc val: 0.8877\n",
      "Epoch 700: Cost tr: 0.0917 Cost val: 1.1453 \t Acc tr: 0.9324 Acc val: 0.8861\n",
      "Epoch 701: Cost tr: 0.0461 Cost val: 1.0369 \t Acc tr: 0.9323 Acc val: 0.8891\n",
      "Epoch 702: Cost tr: -0.0896 Cost val: 1.2606 \t Acc tr: 0.9342 Acc val: 0.8899\n",
      "Epoch 703: Cost tr: 0.0265 Cost val: 1.4428 \t Acc tr: 0.9336 Acc val: 0.8897\n",
      "Epoch 704: Cost tr: 0.1721 Cost val: 1.3993 \t Acc tr: 0.9359 Acc val: 0.8885\n",
      "Epoch 705: Cost tr: 0.182 Cost val: 1.6553 \t Acc tr: 0.9342 Acc val: 0.8866\n",
      "Epoch 706: Cost tr: 0.218 Cost val: 1.3461 \t Acc tr: 0.9335 Acc val: 0.889\n",
      "Epoch 707: Cost tr: 0.3571 Cost val: 1.5352 \t Acc tr: 0.9325 Acc val: 0.8881\n",
      "Epoch 708: Cost tr: 0.057 Cost val: 1.0442 \t Acc tr: 0.9328 Acc val: 0.8904\n",
      "Epoch 709: Cost tr: 0.0731 Cost val: 0.9831 \t Acc tr: 0.9338 Acc val: 0.8926\n",
      "Epoch 710: Cost tr: 0.3751 Cost val: 1.5304 \t Acc tr: 0.9336 Acc val: 0.8884\n",
      "Epoch 711: Cost tr: 0.2299 Cost val: 1.4022 \t Acc tr: 0.9359 Acc val: 0.8908\n",
      "Epoch 712: Cost tr: 0.0206 Cost val: 1.4441 \t Acc tr: 0.9354 Acc val: 0.8905\n",
      "Epoch 713: Cost tr: 0.279 Cost val: 1.5071 \t Acc tr: 0.9333 Acc val: 0.8887\n",
      "Epoch 714: Cost tr: 0.2641 Cost val: 1.3119 \t Acc tr: 0.9365 Acc val: 0.8902\n",
      "Epoch 715: Cost tr: 0.1493 Cost val: 1.27 \t Acc tr: 0.9361 Acc val: 0.8881\n",
      "Epoch 716: Cost tr: -0.0766 Cost val: 1.1871 \t Acc tr: 0.9381 Acc val: 0.8881\n",
      "Epoch 717: Cost tr: 0.0554 Cost val: 1.3291 \t Acc tr: 0.9381 Acc val: 0.8901\n",
      "Epoch 718: Cost tr: 0.0041 Cost val: 1.4996 \t Acc tr: 0.9376 Acc val: 0.8896\n",
      "Epoch 719: Cost tr: 0.13 Cost val: 1.3286 \t Acc tr: 0.9372 Acc val: 0.8907\n",
      "Epoch 720: Cost tr: 0.1029 Cost val: 1.3906 \t Acc tr: 0.9368 Acc val: 0.8906\n",
      "Epoch 721: Cost tr: 0.3205 Cost val: 1.5321 \t Acc tr: 0.9371 Acc val: 0.8892\n",
      "Epoch 722: Cost tr: 0.2492 Cost val: 1.6098 \t Acc tr: 0.9354 Acc val: 0.8895\n",
      "Epoch 723: Cost tr: 0.0946 Cost val: 1.3916 \t Acc tr: 0.938 Acc val: 0.8885\n",
      "Epoch 724: Cost tr: 0.1824 Cost val: 1.4857 \t Acc tr: 0.9363 Acc val: 0.8907\n",
      "Epoch 725: Cost tr: 0.5328 Cost val: 1.8014 \t Acc tr: 0.9367 Acc val: 0.8899\n",
      "Epoch 726: Cost tr: 0.1426 Cost val: 1.3863 \t Acc tr: 0.9382 Acc val: 0.8904\n",
      "Epoch 727: Cost tr: 0.2393 Cost val: 1.6528 \t Acc tr: 0.9379 Acc val: 0.8924\n",
      "Epoch 728: Cost tr: 0.2482 Cost val: 1.7862 \t Acc tr: 0.9391 Acc val: 0.8904\n",
      "Epoch 729: Cost tr: 0.1288 Cost val: 1.5582 \t Acc tr: 0.9392 Acc val: 0.8877\n",
      "Epoch 730: Cost tr: -0.1398 Cost val: 1.3188 \t Acc tr: 0.9404 Acc val: 0.8907\n",
      "Epoch 731: Cost tr: 0.1518 Cost val: 1.644 \t Acc tr: 0.9402 Acc val: 0.8887\n",
      "Epoch 732: Cost tr: 0.3609 Cost val: 1.786 \t Acc tr: 0.9406 Acc val: 0.8879\n",
      "Epoch 733: Cost tr: 0.2161 Cost val: 1.589 \t Acc tr: 0.9376 Acc val: 0.8902\n",
      "Epoch 734: Cost tr: 0.2158 Cost val: 1.362 \t Acc tr: 0.9405 Acc val: 0.889\n",
      "Epoch 735: Cost tr: 0.2354 Cost val: 1.5461 \t Acc tr: 0.9407 Acc val: 0.8898\n",
      "Epoch 736: Cost tr: 0.2809 Cost val: 1.5654 \t Acc tr: 0.9408 Acc val: 0.8921\n",
      "Epoch 737: Cost tr: 0.3933 Cost val: 1.7543 \t Acc tr: 0.939 Acc val: 0.8909\n",
      "Epoch 738: Cost tr: 0.2189 Cost val: 1.4029 \t Acc tr: 0.9409 Acc val: 0.8901\n",
      "Epoch 739: Cost tr: 0.3261 Cost val: 1.2113 \t Acc tr: 0.9412 Acc val: 0.8918\n",
      "Epoch 740: Cost tr: -0.0565 Cost val: 1.2079 \t Acc tr: 0.9402 Acc val: 0.8886\n",
      "Epoch 741: Cost tr: 0.0042 Cost val: 1.3515 \t Acc tr: 0.9392 Acc val: 0.8894\n",
      "Epoch 742: Cost tr: 0.4197 Cost val: 1.6064 \t Acc tr: 0.9398 Acc val: 0.8871\n",
      "Epoch 743: Cost tr: 0.3805 Cost val: 1.9097 \t Acc tr: 0.9368 Acc val: 0.8897\n",
      "Epoch 744: Cost tr: -0.0901 Cost val: 1.3499 \t Acc tr: 0.9393 Acc val: 0.891\n",
      "Epoch 745: Cost tr: 0.1964 Cost val: 1.4445 \t Acc tr: 0.9395 Acc val: 0.8905\n",
      "Epoch 746: Cost tr: -0.0421 Cost val: 1.5343 \t Acc tr: 0.9412 Acc val: 0.8896\n",
      "Epoch 747: Cost tr: 0.2187 Cost val: 1.494 \t Acc tr: 0.9384 Acc val: 0.8881\n",
      "Epoch 748: Cost tr: 0.4121 Cost val: 1.3947 \t Acc tr: 0.9372 Acc val: 0.8906\n",
      "Epoch 749: Cost tr: 0.0847 Cost val: 1.6163 \t Acc tr: 0.94 Acc val: 0.8878\n",
      "Epoch 750: Cost tr: 0.1973 Cost val: 1.4934 \t Acc tr: 0.9413 Acc val: 0.891\n",
      "Epoch 751: Cost tr: -0.1665 Cost val: 1.1682 \t Acc tr: 0.9408 Acc val: 0.891\n",
      "Epoch 752: Cost tr: 0.0988 Cost val: 1.3553 \t Acc tr: 0.9416 Acc val: 0.8899\n",
      "Epoch 753: Cost tr: 0.1355 Cost val: 1.614 \t Acc tr: 0.9429 Acc val: 0.8899\n",
      "Epoch 754: Cost tr: 0.3143 Cost val: 1.8971 \t Acc tr: 0.9403 Acc val: 0.8924\n",
      "Epoch 755: Cost tr: 0.2268 Cost val: 1.7408 \t Acc tr: 0.9422 Acc val: 0.8898\n",
      "Epoch 756: Cost tr: 0.1057 Cost val: 1.6736 \t Acc tr: 0.9403 Acc val: 0.8896\n",
      "Epoch 757: Cost tr: -0.0117 Cost val: 1.4064 \t Acc tr: 0.9431 Acc val: 0.8912\n",
      "Epoch 758: Cost tr: -0.0477 Cost val: 1.5688 \t Acc tr: 0.945 Acc val: 0.8913\n",
      "Epoch 759: Cost tr: 0.0803 Cost val: 1.6429 \t Acc tr: 0.9438 Acc val: 0.8905\n",
      "Epoch 760: Cost tr: -0.0479 Cost val: 1.4671 \t Acc tr: 0.9443 Acc val: 0.8914\n",
      "Epoch 761: Cost tr: -0.0578 Cost val: 1.3681 \t Acc tr: 0.9438 Acc val: 0.8923\n",
      "Epoch 762: Cost tr: 0.0256 Cost val: 1.4659 \t Acc tr: 0.9457 Acc val: 0.8931\n",
      "Epoch 763: Cost tr: 0.4342 Cost val: 1.6803 \t Acc tr: 0.9421 Acc val: 0.8911\n",
      "Epoch 764: Cost tr: 0.0834 Cost val: 1.5619 \t Acc tr: 0.9454 Acc val: 0.8916\n",
      "Epoch 765: Cost tr: -0.1188 Cost val: 1.5529 \t Acc tr: 0.9409 Acc val: 0.891\n",
      "Epoch 766: Cost tr: -0.021 Cost val: 1.4539 \t Acc tr: 0.9431 Acc val: 0.8908\n",
      "Epoch 767: Cost tr: -0.4588 Cost val: 1.2691 \t Acc tr: 0.9423 Acc val: 0.8917\n",
      "Epoch 768: Cost tr: 0.0467 Cost val: 1.5686 \t Acc tr: 0.9451 Acc val: 0.8912\n",
      "Epoch 769: Cost tr: 0.3502 Cost val: 2.2996 \t Acc tr: 0.9437 Acc val: 0.8891\n",
      "Epoch 770: Cost tr: 0.2995 Cost val: 2.1294 \t Acc tr: 0.9433 Acc val: 0.8884\n",
      "Epoch 771: Cost tr: 0.2922 Cost val: 1.764 \t Acc tr: 0.9439 Acc val: 0.89\n",
      "Epoch 772: Cost tr: 0.1151 Cost val: 1.6594 \t Acc tr: 0.942 Acc val: 0.8907\n",
      "Epoch 773: Cost tr: 0.1731 Cost val: 1.606 \t Acc tr: 0.9437 Acc val: 0.8924\n",
      "Epoch 774: Cost tr: 0.1671 Cost val: 1.6084 \t Acc tr: 0.9424 Acc val: 0.8928\n",
      "Epoch 775: Cost tr: 0.1512 Cost val: 1.5574 \t Acc tr: 0.9445 Acc val: 0.8895\n",
      "Epoch 776: Cost tr: 0.0104 Cost val: 1.7282 \t Acc tr: 0.9456 Acc val: 0.8904\n",
      "Epoch 777: Cost tr: -0.0555 Cost val: 1.8015 \t Acc tr: 0.9464 Acc val: 0.8901\n",
      "Epoch 778: Cost tr: 0.2986 Cost val: 1.9554 \t Acc tr: 0.9477 Acc val: 0.8903\n",
      "Epoch 779: Cost tr: 0.0887 Cost val: 1.9489 \t Acc tr: 0.9452 Acc val: 0.8911\n",
      "Epoch 780: Cost tr: 0.2394 Cost val: 1.8433 \t Acc tr: 0.9455 Acc val: 0.8907\n",
      "Epoch 781: Cost tr: 0.0001 Cost val: 1.4745 \t Acc tr: 0.9447 Acc val: 0.8913\n",
      "Epoch 782: Cost tr: 0.1482 Cost val: 1.5995 \t Acc tr: 0.9463 Acc val: 0.8905\n",
      "Epoch 783: Cost tr: 0.1871 Cost val: 1.9927 \t Acc tr: 0.9476 Acc val: 0.8884\n",
      "Epoch 784: Cost tr: 0.3372 Cost val: 2.0705 \t Acc tr: 0.9451 Acc val: 0.8898\n",
      "Epoch 785: Cost tr: 0.1203 Cost val: 1.3566 \t Acc tr: 0.9471 Acc val: 0.8921\n",
      "Epoch 786: Cost tr: -0.0359 Cost val: 1.5757 \t Acc tr: 0.9474 Acc val: 0.8902\n",
      "Epoch 787: Cost tr: 0.2883 Cost val: 1.7397 \t Acc tr: 0.9441 Acc val: 0.8919\n",
      "Epoch 788: Cost tr: 0.0089 Cost val: 1.5826 \t Acc tr: 0.9462 Acc val: 0.8916\n",
      "Epoch 789: Cost tr: 0.0281 Cost val: 1.6367 \t Acc tr: 0.9453 Acc val: 0.8905\n",
      "Epoch 790: Cost tr: 0.254 Cost val: 1.9431 \t Acc tr: 0.9435 Acc val: 0.8895\n",
      "Epoch 791: Cost tr: -0.1162 Cost val: 1.6163 \t Acc tr: 0.9464 Acc val: 0.8888\n",
      "Epoch 792: Cost tr: 0.041 Cost val: 1.7789 \t Acc tr: 0.9447 Acc val: 0.8903\n",
      "Epoch 793: Cost tr: 0.1477 Cost val: 1.5616 \t Acc tr: 0.9481 Acc val: 0.8895\n",
      "Epoch 794: Cost tr: 0.2491 Cost val: 1.8705 \t Acc tr: 0.9467 Acc val: 0.8895\n",
      "Epoch 795: Cost tr: 0.2243 Cost val: 1.8175 \t Acc tr: 0.945 Acc val: 0.8902\n",
      "Epoch 796: Cost tr: 0.1406 Cost val: 1.7241 \t Acc tr: 0.946 Acc val: 0.8912\n",
      "Epoch 797: Cost tr: 0.02 Cost val: 1.8425 \t Acc tr: 0.9484 Acc val: 0.8905\n",
      "Epoch 798: Cost tr: 0.2053 Cost val: 2.1839 \t Acc tr: 0.947 Acc val: 0.8891\n",
      "Epoch 799: Cost tr: 0.0228 Cost val: 1.7386 \t Acc tr: 0.9492 Acc val: 0.8909\n",
      "Epoch 800: Cost tr: 0.0393 Cost val: 1.7972 \t Acc tr: 0.9485 Acc val: 0.8876\n",
      "Epoch 801: Cost tr: 0.112 Cost val: 1.6379 \t Acc tr: 0.9484 Acc val: 0.8892\n",
      "Epoch 802: Cost tr: 0.1882 Cost val: 1.9846 \t Acc tr: 0.9477 Acc val: 0.8907\n",
      "Epoch 803: Cost tr: -0.0434 Cost val: 1.9115 \t Acc tr: 0.9485 Acc val: 0.8904\n",
      "Epoch 804: Cost tr: 0.125 Cost val: 2.3104 \t Acc tr: 0.9482 Acc val: 0.8901\n",
      "Epoch 805: Cost tr: 0.2534 Cost val: 1.8813 \t Acc tr: 0.9499 Acc val: 0.8891\n",
      "Epoch 806: Cost tr: 0.0523 Cost val: 1.7921 \t Acc tr: 0.9473 Acc val: 0.8903\n",
      "Epoch 807: Cost tr: 0.2282 Cost val: 1.8166 \t Acc tr: 0.9487 Acc val: 0.891\n",
      "Epoch 808: Cost tr: -0.0214 Cost val: 1.8741 \t Acc tr: 0.951 Acc val: 0.8876\n",
      "Epoch 809: Cost tr: -0.1783 Cost val: 1.2238 \t Acc tr: 0.9478 Acc val: 0.8929\n",
      "Epoch 810: Cost tr: -0.2821 Cost val: 1.6509 \t Acc tr: 0.9504 Acc val: 0.8904\n",
      "Epoch 811: Cost tr: 0.2847 Cost val: 2.0147 \t Acc tr: 0.9476 Acc val: 0.8913\n",
      "Epoch 812: Cost tr: 0.1022 Cost val: 1.8906 \t Acc tr: 0.9527 Acc val: 0.8898\n",
      "Epoch 813: Cost tr: -0.1726 Cost val: 1.6913 \t Acc tr: 0.9529 Acc val: 0.8907\n",
      "Epoch 814: Cost tr: -0.2258 Cost val: 1.5861 \t Acc tr: 0.9524 Acc val: 0.8912\n",
      "Epoch 815: Cost tr: -0.1789 Cost val: 1.7814 \t Acc tr: 0.9514 Acc val: 0.8898\n",
      "Epoch 816: Cost tr: 0.1786 Cost val: 1.7227 \t Acc tr: 0.9498 Acc val: 0.8907\n",
      "Epoch 817: Cost tr: -0.1571 Cost val: 1.8195 \t Acc tr: 0.949 Acc val: 0.8904\n",
      "Epoch 818: Cost tr: 0.1339 Cost val: 1.7634 \t Acc tr: 0.9513 Acc val: 0.891\n",
      "Epoch 819: Cost tr: -0.2567 Cost val: 1.5796 \t Acc tr: 0.9512 Acc val: 0.8902\n",
      "Epoch 820: Cost tr: -0.47 Cost val: 1.5845 \t Acc tr: 0.9502 Acc val: 0.8895\n",
      "Epoch 821: Cost tr: 0.0867 Cost val: 1.6147 \t Acc tr: 0.9515 Acc val: 0.8905\n",
      "Epoch 822: Cost tr: 0.1532 Cost val: 1.7837 \t Acc tr: 0.9527 Acc val: 0.8904\n",
      "Epoch 823: Cost tr: 0.1672 Cost val: 1.9601 \t Acc tr: 0.9524 Acc val: 0.8901\n",
      "Epoch 824: Cost tr: 0.095 Cost val: 1.7041 \t Acc tr: 0.9509 Acc val: 0.8891\n",
      "Epoch 825: Cost tr: -0.1404 Cost val: 1.5769 \t Acc tr: 0.949 Acc val: 0.8904\n",
      "Epoch 826: Cost tr: -0.3029 Cost val: 1.3526 \t Acc tr: 0.9493 Acc val: 0.8919\n",
      "Epoch 827: Cost tr: -0.0975 Cost val: 1.9782 \t Acc tr: 0.9488 Acc val: 0.8906\n",
      "Epoch 828: Cost tr: -0.2386 Cost val: 1.882 \t Acc tr: 0.9536 Acc val: 0.8892\n",
      "Epoch 829: Cost tr: 0.1565 Cost val: 2.1164 \t Acc tr: 0.9522 Acc val: 0.8895\n",
      "Epoch 830: Cost tr: -0.095 Cost val: 1.8338 \t Acc tr: 0.953 Acc val: 0.8914\n",
      "Epoch 831: Cost tr: -0.279 Cost val: 1.6532 \t Acc tr: 0.9526 Acc val: 0.889\n",
      "Epoch 832: Cost tr: -0.3243 Cost val: 1.5097 \t Acc tr: 0.9529 Acc val: 0.8913\n",
      "Epoch 833: Cost tr: -0.4922 Cost val: 1.6965 \t Acc tr: 0.9534 Acc val: 0.8916\n",
      "Epoch 834: Cost tr: -0.4078 Cost val: 1.5134 \t Acc tr: 0.9549 Acc val: 0.8913\n",
      "Epoch 835: Cost tr: -0.0189 Cost val: 1.8911 \t Acc tr: 0.9546 Acc val: 0.8901\n",
      "Epoch 836: Cost tr: 0.0116 Cost val: 1.8043 \t Acc tr: 0.9534 Acc val: 0.89\n",
      "Epoch 837: Cost tr: 0.0385 Cost val: 1.729 \t Acc tr: 0.9528 Acc val: 0.8898\n",
      "Epoch 838: Cost tr: -0.1042 Cost val: 1.7247 \t Acc tr: 0.9545 Acc val: 0.8908\n",
      "Epoch 839: Cost tr: -0.1808 Cost val: 1.8495 \t Acc tr: 0.9534 Acc val: 0.8915\n",
      "Epoch 840: Cost tr: -0.0997 Cost val: 1.7575 \t Acc tr: 0.9552 Acc val: 0.8915\n",
      "Epoch 841: Cost tr: -0.3175 Cost val: 1.55 \t Acc tr: 0.9543 Acc val: 0.8909\n",
      "Epoch 842: Cost tr: -0.4226 Cost val: 1.6981 \t Acc tr: 0.9568 Acc val: 0.891\n",
      "Epoch 843: Cost tr: -0.1744 Cost val: 1.9822 \t Acc tr: 0.9577 Acc val: 0.8896\n",
      "Epoch 844: Cost tr: -0.0171 Cost val: 1.9133 \t Acc tr: 0.953 Acc val: 0.8899\n",
      "Epoch 845: Cost tr: -0.2265 Cost val: 1.7079 \t Acc tr: 0.9547 Acc val: 0.8888\n",
      "Epoch 846: Cost tr: -0.0973 Cost val: 1.6389 \t Acc tr: 0.9542 Acc val: 0.8898\n",
      "Epoch 847: Cost tr: -0.2045 Cost val: 1.6764 \t Acc tr: 0.9522 Acc val: 0.891\n",
      "Epoch 848: Cost tr: -0.2823 Cost val: 1.4732 \t Acc tr: 0.9544 Acc val: 0.8927\n",
      "Epoch 849: Cost tr: -0.2961 Cost val: 1.7503 \t Acc tr: 0.9526 Acc val: 0.8913\n",
      "Epoch 850: Cost tr: -0.0809 Cost val: 1.6425 \t Acc tr: 0.9526 Acc val: 0.8899\n",
      "Epoch 851: Cost tr: -0.2508 Cost val: 1.5074 \t Acc tr: 0.9523 Acc val: 0.8897\n",
      "Epoch 852: Cost tr: 0.0057 Cost val: 1.893 \t Acc tr: 0.9499 Acc val: 0.8891\n",
      "Epoch 853: Cost tr: -0.3567 Cost val: 2.0781 \t Acc tr: 0.9515 Acc val: 0.888\n",
      "Epoch 854: Cost tr: 0.0828 Cost val: 1.9631 \t Acc tr: 0.9534 Acc val: 0.889\n",
      "Epoch 855: Cost tr: -0.2632 Cost val: 1.7303 \t Acc tr: 0.9522 Acc val: 0.8894\n",
      "Epoch 856: Cost tr: -0.4992 Cost val: 1.5205 \t Acc tr: 0.9516 Acc val: 0.8912\n",
      "Epoch 857: Cost tr: -0.2267 Cost val: 1.546 \t Acc tr: 0.9535 Acc val: 0.8901\n",
      "Epoch 858: Cost tr: -0.1662 Cost val: 1.5552 \t Acc tr: 0.9553 Acc val: 0.8918\n",
      "Epoch 859: Cost tr: -0.2705 Cost val: 1.8039 \t Acc tr: 0.9564 Acc val: 0.8904\n",
      "Epoch 860: Cost tr: -0.1604 Cost val: 1.8576 \t Acc tr: 0.9566 Acc val: 0.892\n",
      "Epoch 861: Cost tr: -0.166 Cost val: 1.9495 \t Acc tr: 0.9543 Acc val: 0.8907\n",
      "Epoch 862: Cost tr: -0.064 Cost val: 1.9123 \t Acc tr: 0.9571 Acc val: 0.8915\n",
      "Epoch 863: Cost tr: -0.2124 Cost val: 1.9031 \t Acc tr: 0.9566 Acc val: 0.8913\n",
      "Epoch 864: Cost tr: -0.2623 Cost val: 1.8872 \t Acc tr: 0.956 Acc val: 0.8902\n",
      "Epoch 865: Cost tr: -0.2558 Cost val: 1.8994 \t Acc tr: 0.9541 Acc val: 0.8892\n",
      "Epoch 866: Cost tr: -0.1729 Cost val: 1.7978 \t Acc tr: 0.9529 Acc val: 0.8892\n",
      "Epoch 867: Cost tr: -0.1187 Cost val: 1.8126 \t Acc tr: 0.9534 Acc val: 0.8906\n",
      "Epoch 868: Cost tr: 0.2663 Cost val: 1.8986 \t Acc tr: 0.9517 Acc val: 0.8888\n",
      "Epoch 869: Cost tr: -0.1722 Cost val: 1.7267 \t Acc tr: 0.9512 Acc val: 0.8904\n",
      "Epoch 870: Cost tr: -0.3497 Cost val: 2.018 \t Acc tr: 0.9552 Acc val: 0.8904\n",
      "Epoch 871: Cost tr: 0.0768 Cost val: 2.2451 \t Acc tr: 0.9551 Acc val: 0.8913\n",
      "Epoch 872: Cost tr: -0.1649 Cost val: 1.7794 \t Acc tr: 0.9584 Acc val: 0.8912\n",
      "Epoch 873: Cost tr: -0.3848 Cost val: 1.7027 \t Acc tr: 0.9593 Acc val: 0.8919\n",
      "Epoch 874: Cost tr: -0.3466 Cost val: 1.7801 \t Acc tr: 0.9579 Acc val: 0.8907\n",
      "Epoch 875: Cost tr: -0.1515 Cost val: 2.2593 \t Acc tr: 0.9557 Acc val: 0.89\n",
      "Epoch 876: Cost tr: -0.1498 Cost val: 1.9137 \t Acc tr: 0.9559 Acc val: 0.8936\n",
      "Epoch 877: Cost tr: -0.1599 Cost val: 2.0014 \t Acc tr: 0.9574 Acc val: 0.8909\n",
      "Epoch 878: Cost tr: -0.3335 Cost val: 1.9032 \t Acc tr: 0.9591 Acc val: 0.8902\n",
      "Epoch 879: Cost tr: 0.0284 Cost val: 2.5414 \t Acc tr: 0.9582 Acc val: 0.89\n",
      "Epoch 880: Cost tr: 0.0444 Cost val: 2.0059 \t Acc tr: 0.9556 Acc val: 0.8891\n",
      "Epoch 881: Cost tr: -0.3135 Cost val: 1.6222 \t Acc tr: 0.9582 Acc val: 0.8915\n",
      "Epoch 882: Cost tr: -0.5571 Cost val: 1.3643 \t Acc tr: 0.9564 Acc val: 0.8915\n",
      "Epoch 883: Cost tr: -0.1782 Cost val: 1.7224 \t Acc tr: 0.9582 Acc val: 0.8911\n",
      "Epoch 884: Cost tr: -0.3572 Cost val: 1.5477 \t Acc tr: 0.9574 Acc val: 0.8903\n",
      "Epoch 885: Cost tr: -0.388 Cost val: 1.5884 \t Acc tr: 0.9562 Acc val: 0.8899\n",
      "Epoch 886: Cost tr: -0.3677 Cost val: 1.4677 \t Acc tr: 0.9569 Acc val: 0.8912\n",
      "Epoch 887: Cost tr: -0.4188 Cost val: 1.6463 \t Acc tr: 0.9576 Acc val: 0.8916\n",
      "Epoch 888: Cost tr: -0.096 Cost val: 1.7855 \t Acc tr: 0.9576 Acc val: 0.8914\n",
      "Epoch 889: Cost tr: -0.2069 Cost val: 2.1445 \t Acc tr: 0.9574 Acc val: 0.8919\n",
      "Epoch 890: Cost tr: -0.3514 Cost val: 1.5576 \t Acc tr: 0.9566 Acc val: 0.8926\n",
      "Epoch 891: Cost tr: -0.209 Cost val: 1.6597 \t Acc tr: 0.9585 Acc val: 0.8919\n",
      "Epoch 892: Cost tr: -0.5372 Cost val: 1.6021 \t Acc tr: 0.9595 Acc val: 0.8914\n",
      "Epoch 893: Cost tr: -0.135 Cost val: 1.7768 \t Acc tr: 0.9545 Acc val: 0.89\n",
      "Epoch 894: Cost tr: -0.2626 Cost val: 1.4808 \t Acc tr: 0.9567 Acc val: 0.8924\n",
      "Epoch 895: Cost tr: -0.3212 Cost val: 1.7608 \t Acc tr: 0.9571 Acc val: 0.8913\n",
      "Epoch 896: Cost tr: -0.4839 Cost val: 1.6399 \t Acc tr: 0.9587 Acc val: 0.8922\n",
      "Epoch 897: Cost tr: -0.1833 Cost val: 1.8728 \t Acc tr: 0.9582 Acc val: 0.8893\n",
      "Epoch 898: Cost tr: -0.2535 Cost val: 1.9042 \t Acc tr: 0.9565 Acc val: 0.8898\n",
      "Epoch 899: Cost tr: -0.4553 Cost val: 1.6226 \t Acc tr: 0.958 Acc val: 0.8897\n",
      "Epoch 900: Cost tr: -0.4243 Cost val: 1.2888 \t Acc tr: 0.9545 Acc val: 0.8894\n",
      "Epoch 901: Cost tr: -0.3619 Cost val: 1.3026 \t Acc tr: 0.956 Acc val: 0.8919\n",
      "Epoch 902: Cost tr: -0.4262 Cost val: 1.4616 \t Acc tr: 0.958 Acc val: 0.8909\n",
      "Epoch 903: Cost tr: -0.1719 Cost val: 1.789 \t Acc tr: 0.958 Acc val: 0.8902\n",
      "Epoch 904: Cost tr: -0.2273 Cost val: 1.8936 \t Acc tr: 0.9574 Acc val: 0.8907\n",
      "Epoch 905: Cost tr: -0.1523 Cost val: 2.0626 \t Acc tr: 0.9573 Acc val: 0.8905\n",
      "Epoch 906: Cost tr: -0.3786 Cost val: 2.0029 \t Acc tr: 0.9609 Acc val: 0.8904\n",
      "Epoch 907: Cost tr: -0.4061 Cost val: 1.6524 \t Acc tr: 0.9601 Acc val: 0.8902\n",
      "Epoch 908: Cost tr: -0.5502 Cost val: 1.7706 \t Acc tr: 0.9614 Acc val: 0.8891\n",
      "Epoch 909: Cost tr: -0.3445 Cost val: 1.945 \t Acc tr: 0.9591 Acc val: 0.8892\n",
      "Epoch 910: Cost tr: -0.5485 Cost val: 1.9345 \t Acc tr: 0.9602 Acc val: 0.8905\n",
      "Epoch 911: Cost tr: -0.3306 Cost val: 1.778 \t Acc tr: 0.957 Acc val: 0.8905\n",
      "Epoch 912: Cost tr: -0.2655 Cost val: 1.9873 \t Acc tr: 0.9574 Acc val: 0.8928\n",
      "Epoch 913: Cost tr: -0.3287 Cost val: 1.6786 \t Acc tr: 0.9566 Acc val: 0.8923\n",
      "Epoch 914: Cost tr: -0.1666 Cost val: 1.8004 \t Acc tr: 0.9558 Acc val: 0.8897\n",
      "Epoch 915: Cost tr: -0.517 Cost val: 1.6277 \t Acc tr: 0.9585 Acc val: 0.8902\n",
      "Epoch 916: Cost tr: -0.4668 Cost val: 1.7163 \t Acc tr: 0.9593 Acc val: 0.8912\n",
      "Epoch 917: Cost tr: -0.4691 Cost val: 1.997 \t Acc tr: 0.9574 Acc val: 0.8903\n",
      "Epoch 918: Cost tr: -0.5221 Cost val: 1.6234 \t Acc tr: 0.9569 Acc val: 0.892\n",
      "Epoch 919: Cost tr: -0.2019 Cost val: 1.7953 \t Acc tr: 0.9578 Acc val: 0.8895\n",
      "Epoch 920: Cost tr: -0.1322 Cost val: 1.9002 \t Acc tr: 0.9575 Acc val: 0.8892\n",
      "Epoch 921: Cost tr: -0.1468 Cost val: 1.9718 \t Acc tr: 0.9588 Acc val: 0.8894\n",
      "Epoch 922: Cost tr: -0.287 Cost val: 1.9695 \t Acc tr: 0.9576 Acc val: 0.8892\n",
      "Epoch 923: Cost tr: -0.4973 Cost val: 1.7064 \t Acc tr: 0.9594 Acc val: 0.8901\n",
      "Epoch 924: Cost tr: -0.4586 Cost val: 2.002 \t Acc tr: 0.9583 Acc val: 0.8882\n",
      "Epoch 925: Cost tr: -0.5249 Cost val: 1.8623 \t Acc tr: 0.9566 Acc val: 0.8898\n",
      "Epoch 926: Cost tr: -0.4007 Cost val: 1.6666 \t Acc tr: 0.9569 Acc val: 0.8904\n",
      "Epoch 927: Cost tr: -0.3888 Cost val: 1.959 \t Acc tr: 0.9568 Acc val: 0.8895\n",
      "Epoch 928: Cost tr: -0.2965 Cost val: 1.7079 \t Acc tr: 0.9571 Acc val: 0.8918\n",
      "Epoch 929: Cost tr: -0.329 Cost val: 1.6502 \t Acc tr: 0.9581 Acc val: 0.8901\n",
      "Epoch 930: Cost tr: -0.1123 Cost val: 2.0799 \t Acc tr: 0.9579 Acc val: 0.889\n",
      "Epoch 931: Cost tr: -0.2875 Cost val: 2.1649 \t Acc tr: 0.9584 Acc val: 0.8903\n",
      "Epoch 932: Cost tr: -0.31 Cost val: 1.6624 \t Acc tr: 0.9574 Acc val: 0.8895\n",
      "Epoch 933: Cost tr: -0.1515 Cost val: 1.7129 \t Acc tr: 0.9588 Acc val: 0.8895\n",
      "Epoch 934: Cost tr: -0.2256 Cost val: 2.0213 \t Acc tr: 0.9592 Acc val: 0.8907\n",
      "Epoch 935: Cost tr: -0.5783 Cost val: 2.1598 \t Acc tr: 0.9605 Acc val: 0.8886\n",
      "Epoch 936: Cost tr: -0.7412 Cost val: 1.4663 \t Acc tr: 0.9579 Acc val: 0.8904\n",
      "Epoch 937: Cost tr: -0.8838 Cost val: 1.2419 \t Acc tr: 0.962 Acc val: 0.8915\n",
      "Epoch 938: Cost tr: -0.247 Cost val: 1.9983 \t Acc tr: 0.9608 Acc val: 0.8912\n",
      "Epoch 939: Cost tr: -0.1373 Cost val: 1.8986 \t Acc tr: 0.9589 Acc val: 0.8902\n",
      "Epoch 940: Cost tr: -0.198 Cost val: 1.821 \t Acc tr: 0.9606 Acc val: 0.89\n",
      "Epoch 941: Cost tr: -0.6312 Cost val: 1.7072 \t Acc tr: 0.9638 Acc val: 0.892\n",
      "Epoch 942: Cost tr: -0.5086 Cost val: 1.7305 \t Acc tr: 0.9604 Acc val: 0.8896\n",
      "Epoch 943: Cost tr: -0.3267 Cost val: 2.0953 \t Acc tr: 0.9571 Acc val: 0.8896\n",
      "Epoch 944: Cost tr: -0.5109 Cost val: 1.9339 \t Acc tr: 0.9585 Acc val: 0.89\n",
      "Epoch 945: Cost tr: -0.466 Cost val: 1.9437 \t Acc tr: 0.9615 Acc val: 0.8907\n",
      "Epoch 946: Cost tr: -0.0484 Cost val: 2.4197 \t Acc tr: 0.961 Acc val: 0.889\n",
      "Epoch 947: Cost tr: -0.4055 Cost val: 1.653 \t Acc tr: 0.9591 Acc val: 0.8926\n",
      "Epoch 948: Cost tr: -0.3905 Cost val: 1.9332 \t Acc tr: 0.9605 Acc val: 0.8902\n",
      "Epoch 949: Cost tr: -0.4228 Cost val: 1.694 \t Acc tr: 0.9609 Acc val: 0.8897\n",
      "Epoch 950: Cost tr: -0.2771 Cost val: 1.6125 \t Acc tr: 0.9582 Acc val: 0.8901\n",
      "Epoch 951: Cost tr: -0.3225 Cost val: 2.2236 \t Acc tr: 0.9576 Acc val: 0.8899\n",
      "Epoch 952: Cost tr: -0.3925 Cost val: 1.9376 \t Acc tr: 0.9607 Acc val: 0.891\n",
      "Epoch 953: Cost tr: -0.2293 Cost val: 2.3085 \t Acc tr: 0.9613 Acc val: 0.8891\n",
      "Epoch 954: Cost tr: -0.2632 Cost val: 2.0425 \t Acc tr: 0.961 Acc val: 0.8892\n",
      "Epoch 955: Cost tr: -0.5518 Cost val: 2.0682 \t Acc tr: 0.9627 Acc val: 0.89\n",
      "Epoch 956: Cost tr: -0.4679 Cost val: 2.2445 \t Acc tr: 0.961 Acc val: 0.8907\n",
      "Epoch 957: Cost tr: -0.281 Cost val: 2.2383 \t Acc tr: 0.9618 Acc val: 0.8902\n",
      "Epoch 958: Cost tr: -0.2768 Cost val: 1.6118 \t Acc tr: 0.9607 Acc val: 0.891\n",
      "Epoch 959: Cost tr: -0.1645 Cost val: 1.6498 \t Acc tr: 0.9606 Acc val: 0.89\n",
      "Epoch 960: Cost tr: -0.3229 Cost val: 2.0565 \t Acc tr: 0.961 Acc val: 0.8897\n",
      "Epoch 961: Cost tr: -0.39 Cost val: 1.9148 \t Acc tr: 0.9602 Acc val: 0.8919\n",
      "Epoch 962: Cost tr: -0.5331 Cost val: 1.7073 \t Acc tr: 0.9608 Acc val: 0.8891\n",
      "Epoch 963: Cost tr: -0.3847 Cost val: 1.9876 \t Acc tr: 0.9614 Acc val: 0.8899\n",
      "Epoch 964: Cost tr: -0.5473 Cost val: 1.9004 \t Acc tr: 0.9634 Acc val: 0.8898\n",
      "Epoch 965: Cost tr: -0.4461 Cost val: 1.8685 \t Acc tr: 0.9597 Acc val: 0.8918\n",
      "Epoch 966: Cost tr: -0.5376 Cost val: 2.0688 \t Acc tr: 0.962 Acc val: 0.8903\n",
      "Epoch 967: Cost tr: -0.3736 Cost val: 1.7 \t Acc tr: 0.9605 Acc val: 0.8905\n",
      "Epoch 968: Cost tr: -0.3202 Cost val: 1.722 \t Acc tr: 0.9595 Acc val: 0.8893\n",
      "Epoch 969: Cost tr: -0.3464 Cost val: 1.9055 \t Acc tr: 0.961 Acc val: 0.8895\n",
      "Epoch 970: Cost tr: -0.5521 Cost val: 1.7124 \t Acc tr: 0.9582 Acc val: 0.8911\n",
      "Epoch 971: Cost tr: -0.5638 Cost val: 1.47 \t Acc tr: 0.9576 Acc val: 0.8922\n",
      "Epoch 972: Cost tr: -0.5119 Cost val: 1.6761 \t Acc tr: 0.963 Acc val: 0.8913\n",
      "Epoch 973: Cost tr: -0.4698 Cost val: 1.9344 \t Acc tr: 0.9617 Acc val: 0.8913\n",
      "Epoch 974: Cost tr: -0.581 Cost val: 1.8245 \t Acc tr: 0.9605 Acc val: 0.8904\n",
      "Epoch 975: Cost tr: -0.6126 Cost val: 1.7734 \t Acc tr: 0.9625 Acc val: 0.8919\n",
      "Epoch 976: Cost tr: -0.2813 Cost val: 2.1245 \t Acc tr: 0.9613 Acc val: 0.8903\n",
      "Epoch 977: Cost tr: -0.407 Cost val: 2.005 \t Acc tr: 0.9615 Acc val: 0.8899\n",
      "Epoch 978: Cost tr: -0.6243 Cost val: 1.8059 \t Acc tr: 0.9609 Acc val: 0.8909\n",
      "Epoch 979: Cost tr: -0.3 Cost val: 1.7652 \t Acc tr: 0.9623 Acc val: 0.8914\n",
      "Epoch 980: Cost tr: -0.3766 Cost val: 2.1416 \t Acc tr: 0.9634 Acc val: 0.8906\n",
      "Epoch 981: Cost tr: -0.2235 Cost val: 2.0789 \t Acc tr: 0.9615 Acc val: 0.8902\n",
      "Epoch 982: Cost tr: -0.5623 Cost val: 1.7907 \t Acc tr: 0.9593 Acc val: 0.8905\n",
      "Epoch 983: Cost tr: -0.5707 Cost val: 1.7881 \t Acc tr: 0.9602 Acc val: 0.8892\n",
      "Epoch 984: Cost tr: -0.0229 Cost val: 2.2066 \t Acc tr: 0.9599 Acc val: 0.8897\n",
      "Epoch 985: Cost tr: -0.4157 Cost val: 1.9679 \t Acc tr: 0.9638 Acc val: 0.8914\n",
      "Epoch 986: Cost tr: -0.509 Cost val: 1.7257 \t Acc tr: 0.9618 Acc val: 0.8916\n",
      "Epoch 987: Cost tr: -0.5462 Cost val: 1.5639 \t Acc tr: 0.9647 Acc val: 0.8925\n",
      "Epoch 988: Cost tr: -0.5765 Cost val: 1.852 \t Acc tr: 0.9618 Acc val: 0.8913\n",
      "Epoch 989: Cost tr: -0.4557 Cost val: 1.8627 \t Acc tr: 0.9642 Acc val: 0.8894\n",
      "Epoch 990: Cost tr: -0.6224 Cost val: 1.7349 \t Acc tr: 0.964 Acc val: 0.8917\n",
      "Epoch 991: Cost tr: -0.6335 Cost val: 1.9395 \t Acc tr: 0.9639 Acc val: 0.8913\n",
      "Epoch 992: Cost tr: -0.4351 Cost val: 1.8744 \t Acc tr: 0.963 Acc val: 0.8914\n",
      "Epoch 993: Cost tr: -0.4169 Cost val: 1.988 \t Acc tr: 0.966 Acc val: 0.8932\n",
      "Epoch 994: Cost tr: -0.3414 Cost val: 1.8365 \t Acc tr: 0.9636 Acc val: 0.892\n",
      "Epoch 995: Cost tr: -0.1531 Cost val: 1.7938 \t Acc tr: 0.9598 Acc val: 0.8914\n",
      "Epoch 996: Cost tr: -0.63 Cost val: 1.7066 \t Acc tr: 0.9638 Acc val: 0.8884\n",
      "Epoch 997: Cost tr: -0.84 Cost val: 1.6506 \t Acc tr: 0.9642 Acc val: 0.8899\n",
      "Epoch 998: Cost tr: -0.6504 Cost val: 1.8095 \t Acc tr: 0.9632 Acc val: 0.8904\n",
      "Epoch 999: Cost tr: -0.4855 Cost val: 1.6502 \t Acc tr: 0.9604 Acc val: 0.8915\n"
     ]
    }
   ],
   "source": [
    "BS = 50\n",
    "\n",
    "cost_tr_list = []\n",
    "cost_val_list = []\n",
    "\n",
    "acc_tr_list = []\n",
    "acc_val_list = []\n",
    "\n",
    "for ep in range(1000):\n",
    "\n",
    "    n_batches = N_train//BS\n",
    "\n",
    "    for it in range(n_batches):\n",
    "\n",
    "        edges_used_batch = edges_used_train[it*BS:(it+1)*BS]\n",
    "        \n",
    "        paths_batch = torch.tensor(edges_used_batch, dtype=torch.float)\n",
    "        z_mu, z_logvar, z_sample = encoder(paths_batch)\n",
    "        edges_pred = (decoder(z_sample)) #+ euc_dists_vector_torch.unsqueeze(0)\n",
    "        edges_eps = (edges_pred + eps*torch.randn_like(edges_pred)).clamp(0.0001)\n",
    "    \n",
    "        edges_matrix = np.zeros((BS, N, N))\n",
    "        edges_matrix[:, matrix_idx[:,0], matrix_idx[:,1]] = edges_eps.detach().numpy()\n",
    "        edges_matrix[:, matrix_idx[:,1], matrix_idx[:,0]] = edges_eps.detach().numpy()\n",
    "    \n",
    "        path_eps, _ = solve_tsp_parallel(G, edges_matrix, n_edges)\n",
    "        path_eps = torch.tensor(path_eps, dtype=torch.float)\n",
    "        \n",
    "        loss_per_sample = (((paths_batch*edges_pred).sum(-1) - (path_eps*edges_pred).sum(-1)))\n",
    "        kl_divergence = (-0.5 * torch.sum(1 + z_logvar - z_mu.pow(2) - z_logvar.exp(), dim=-1)).mean()\n",
    "        \n",
    "        loss = loss_per_sample.mean()\n",
    "        \n",
    "        total_loss = loss + alpha_kl*kl_divergence #+ 0.1*edges_reg\n",
    "    \n",
    "        #print(f'Loss: {loss.detach().item()} \\t KL div: {kl_divergence.detach().item()} \\t Tot: {total_loss.detach().item()}')\n",
    "        #print('Acc Train:', (paths_batch == path_eps).float().mean(1).mean())\n",
    "        \n",
    "        opt_decoder.zero_grad()\n",
    "        opt.zero_grad()\n",
    "        total_loss.backward()\n",
    "        opt_decoder.step()\n",
    "        opt.step()  \n",
    "\n",
    "    with torch.no_grad():\n",
    "\n",
    "        paths_batch_tr = torch.tensor(edges_used[:N_train], dtype=torch.float)\n",
    "        z_mu_tr, z_logvar_tr, z_sample_tr = encoder(paths_batch_tr)\n",
    "        edges_pred_tr = (decoder(z_mu_tr)) #+ euc_dists_vector_torch.unsqueeze(0)\n",
    "        \n",
    "        edges_matrix_tr = np.zeros((N_train, N, N))\n",
    "        edges_matrix_tr[:, matrix_idx[:,0], matrix_idx[:,1]] = edges_pred_tr.detach().numpy()\n",
    "        edges_matrix_tr[:, matrix_idx[:,1], matrix_idx[:,0]] = edges_pred_tr.detach().numpy()\n",
    "        \n",
    "        path_eps_tr, _ = solve_tsp_parallel(G, edges_matrix_tr, n_edges)\n",
    "        path_eps_tr = torch.tensor(path_eps_tr, dtype=torch.float)\n",
    "\n",
    "        loss_per_sample_tr = ((path_eps_tr*y_tr).sum(-1) - (paths_batch_tr*y_tr).sum(-1))\n",
    "        loss_tr = loss_per_sample_tr.mean().item()\n",
    "\n",
    "        acc_tr = (paths_batch_tr == path_eps_tr).float().mean(1).mean().item()\n",
    "        \n",
    "        paths_batch_val = torch.tensor(edges_used_val, dtype=torch.float)\n",
    "        z_mu_val, z_logvar_val, z_sample_val = encoder(paths_batch_val)\n",
    "        edges_pred_val = (decoder(z_mu_val)) #+ euc_dists_vector_torch.unsqueeze(0)\n",
    "        \n",
    "        edges_matrix_val = np.zeros((num_samples-N_train, N, N))\n",
    "        edges_matrix_val[:, matrix_idx[:,0], matrix_idx[:,1]] = edges_pred_val.detach().numpy()\n",
    "        edges_matrix_val[:, matrix_idx[:,1], matrix_idx[:,0]] = edges_pred_val.detach().numpy()\n",
    "        \n",
    "        path_eps_val, _ = solve_tsp_parallel(G, edges_matrix_val, n_edges)\n",
    "        path_eps_val = torch.tensor(path_eps_val, dtype=torch.float)\n",
    "\n",
    "        loss_per_sample_val = ((path_eps_val*y_val).sum(-1) - (paths_batch_val*y_val).sum(-1))\n",
    "        loss_val = loss_per_sample_val.mean().item()\n",
    "\n",
    "        acc_val = (paths_batch_val == path_eps_val).float().mean(1).mean().item()\n",
    "\n",
    "        print(f'Epoch {ep}: Cost tr: {round(loss_tr, 4)} Cost val: {round(loss_val, 4)} \\t Acc tr: {round(acc_tr,4)} Acc val: {round(acc_val, 4)}')\n",
    "\n",
    "        cost_tr_list.append(loss_tr)\n",
    "        cost_val_list.append(loss_val)\n",
    "        \n",
    "        acc_tr_list.append(acc_tr)\n",
    "        acc_val_list.append(acc_val)\n",
    "\n",
    "np.save(f'./outputs/tsp_cost_tr_{dim_X}_{lr}_{latent_dim}_{eps}_{alpha_kl}.npy', np.array(cost_tr_list))\n",
    "np.save(f'./outputs/tsp_cost_val_{dim_X}_{lr}_{latent_dim}_{eps}_{alpha_kl}.npy', np.array(cost_val_list))\n",
    "np.save(f'./outputs/tsp_acc_tr_{dim_X}_{lr}_{latent_dim}_{eps}_{alpha_kl}.npy', np.array(acc_tr_list))\n",
    "np.save(f'./outputs/tsp_acc_val_{dim_X}_{lr}_{latent_dim}_{eps}_{alpha_kl}.npy', np.array(acc_val_list))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pao_env",
   "language": "python",
   "name": "pao_env"
  },
  "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
