{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "VSJOwNIG57pB",
    "outputId": "91e17eb0-6756-493e-b376-f4531751481d"
   },
   "source": [
    "# Setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "ld7OUnHi4ZHt",
    "outputId": "06063379-9c83-4542-940b-e69a923223a0"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Num GPUs Available:  1\n"
     ]
    }
   ],
   "source": [
    "import time\n",
    "import math\n",
    "import scipy\n",
    "import scipy.signal\n",
    "import scipy.stats\n",
    "from scipy.stats import norm\n",
    "from scipy.stats import laplace\n",
    "from scipy import integrate\n",
    "import argparse\n",
    "import numpy as np\n",
    "import pickle\n",
    "import tensorflow as tf\n",
    "from tqdm import tqdm\n",
    "\n",
    "# local libs\n",
    "import sys\n",
    "sys.path.append(\"..\")\n",
    "import dpdl_privacy\n",
    "from train_tf import *\n",
    "\n",
    "print(\"Num GPUs Available: \", len(tf.config.experimental.list_physical_devices('GPU')))\n",
    "\n",
    "# gpu_devices = tf.config.experimental.list_physical_devices('GPU')\n",
    "# for device in gpu_devices: \n",
    "#     tf.config.experimental.set_memory_growth(device, True)\n",
    "    \n",
    "%matplotlib inline\n",
    "%config InlineBackend.figure_format = 'retina'\n",
    "#%matplotlib widget\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy import integrate\n",
    "matplotlib.rcParams['figure.dpi'] = 100  #Set quality of figures shown inline\n",
    "\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Set Parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "JLdim_list=[5,10]\n",
    "epochs=25 #number of epochs of training\n",
    "\n",
    "num_runs = 25\n",
    "batch_size=250 #batch_size should divide num_samples exactly\n",
    "\n",
    "sigma=1 #noise multiplier\n",
    "clipping_norm = 1\n",
    "# delta=1e-5\n",
    "\n",
    "\n",
    "###################################################\n",
    "\n",
    "# mesh_size=1e-4 # Controls accuracy of privacy calculations. If set it to 'None', it will be chosen automatically\n",
    "\n",
    "# max_eps=100\n",
    "# min_delta=10**(-10)\n",
    "# precision=10**(-15)\n",
    "\n",
    "# Hyperparameters for Adam Optimizer\n",
    "lr = 0.15# learning rate\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "Qj3tJcqV01JF"
   },
   "source": [
    "## Load model and data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of samples:  60000\n"
     ]
    }
   ],
   "source": [
    "\"\"\"Training a CNN on MNIST with Keras and the DP SGD optimizer.\"\"\"\n",
    "\n",
    "from __future__ import absolute_import\n",
    "from __future__ import division\n",
    "from __future__ import print_function\n",
    "\n",
    "from absl import app\n",
    "from absl import flags\n",
    "from absl import logging\n",
    "\n",
    "from tensorflow_privacy.privacy.analysis.rdp_accountant import compute_rdp\n",
    "from tensorflow_privacy.privacy.analysis.rdp_accountant import get_privacy_spent\n",
    "from tensorflow_privacy.privacy.optimizers.dp_optimizer_keras import DPKerasSGDOptimizer\n",
    "\n",
    "def load_mnist():\n",
    "    \"\"\"Loads MNIST and preprocesses to combine training and validation data.\"\"\"\n",
    "    train, test = tf.keras.datasets.mnist.load_data()\n",
    "    train_data, train_labels = train\n",
    "    test_data, test_labels = test\n",
    "\n",
    "    train_data = np.array(train_data, dtype=np.float32) / 255\n",
    "    test_data = np.array(test_data, dtype=np.float32) / 255\n",
    "\n",
    "    train_data = train_data.reshape((train_data.shape[0], 28, 28, 1))\n",
    "    test_data = test_data.reshape((test_data.shape[0], 28, 28, 1))\n",
    "\n",
    "    train_labels = np.array(train_labels, dtype=np.int32)\n",
    "    test_labels = np.array(test_labels, dtype=np.int32)\n",
    "\n",
    "    train_labels = tf.keras.utils.to_categorical(train_labels, num_classes=10)\n",
    "    test_labels = tf.keras.utils.to_categorical(test_labels, num_classes=10)\n",
    "\n",
    "    assert train_data.min() == 0.\n",
    "    assert train_data.max() == 1.\n",
    "    assert test_data.min() == 0.\n",
    "    assert test_data.max() == 1.\n",
    "\n",
    "    return train_data, train_labels, test_data, test_labels\n",
    "\n",
    "\n",
    "\n",
    "# logging.set_verbosity(logging.INFO)\n",
    "\n",
    "\n",
    "# Load training and test data.\n",
    "train_data, train_labels, test_data, test_labels = load_mnist()\n",
    "\n",
    "train_ds = tf.data.Dataset.from_tensor_slices((train_data, train_labels)).shuffle(5000).batch(batch_size)\n",
    "test_ds = tf.data.Dataset.from_tensor_slices((test_data, test_labels)).batch(10000)\n",
    "\n",
    "# Define a sequential Keras model\n",
    "\n",
    "def get_MNIST_model():\n",
    "    model = tf.keras.Sequential([\n",
    "      tf.keras.layers.Conv2D(16, 8,\n",
    "                             strides=2,\n",
    "                             padding='same',\n",
    "                             activation='relu',\n",
    "                             input_shape=(28, 28, 1)),\n",
    "      tf.keras.layers.MaxPool2D(2, 1),\n",
    "      tf.keras.layers.Conv2D(32, 4,\n",
    "                             strides=2,\n",
    "                             padding='valid',\n",
    "                             activation='relu'),\n",
    "      tf.keras.layers.MaxPool2D(2, 1),\n",
    "      tf.keras.layers.Flatten(),\n",
    "      tf.keras.layers.Dense(32, activation='relu'),\n",
    "      tf.keras.layers.Dense(10)\n",
    "    ])\n",
    "    return model\n",
    "\n",
    "\n",
    "num_samples=len(train_data)\n",
    "print('Number of samples: ',num_samples)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "bPJrfEw35sei"
   },
   "source": [
    "# Non-DP training"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "wl2v0iB29MdN"
   },
   "source": [
    "## Optimizing with keras"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting run  0\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 4ms/step - loss: 1.2173 - accuracy: 0.5969 - val_loss: 0.1039 - val_accuracy: 0.9660\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1139 - accuracy: 0.9653 - val_loss: 0.0686 - val_accuracy: 0.9784\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0774 - accuracy: 0.9767 - val_loss: 0.0655 - val_accuracy: 0.9785\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0604 - accuracy: 0.9813 - val_loss: 0.0453 - val_accuracy: 0.9849\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0471 - accuracy: 0.9848 - val_loss: 0.0442 - val_accuracy: 0.9860\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0402 - accuracy: 0.9874 - val_loss: 0.0486 - val_accuracy: 0.9833\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0384 - accuracy: 0.9881 - val_loss: 0.0453 - val_accuracy: 0.9850\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0342 - accuracy: 0.9900 - val_loss: 0.0331 - val_accuracy: 0.9887\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0294 - accuracy: 0.9908 - val_loss: 0.0374 - val_accuracy: 0.9877\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0283 - accuracy: 0.9904 - val_loss: 0.0308 - val_accuracy: 0.9891\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0238 - accuracy: 0.9924 - val_loss: 0.0357 - val_accuracy: 0.9887\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0225 - accuracy: 0.9932 - val_loss: 0.0294 - val_accuracy: 0.9904\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0185 - accuracy: 0.9943 - val_loss: 0.0298 - val_accuracy: 0.9898\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - ETA: 0s - loss: 0.0200 - accuracy: 0.99 - 1s 3ms/step - loss: 0.0200 - accuracy: 0.9938 - val_loss: 0.0274 - val_accuracy: 0.9915\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0183 - accuracy: 0.9944 - val_loss: 0.0278 - val_accuracy: 0.9913\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0167 - accuracy: 0.9950 - val_loss: 0.0255 - val_accuracy: 0.9921\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0143 - accuracy: 0.9962 - val_loss: 0.0295 - val_accuracy: 0.9907\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0142 - accuracy: 0.9959 - val_loss: 0.0278 - val_accuracy: 0.9909\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0136 - accuracy: 0.9962 - val_loss: 0.0295 - val_accuracy: 0.9908\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0115 - accuracy: 0.9965 - val_loss: 0.0283 - val_accuracy: 0.9916\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0097 - accuracy: 0.9971 - val_loss: 0.0341 - val_accuracy: 0.9886\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0086 - accuracy: 0.9974 - val_loss: 0.0293 - val_accuracy: 0.9910\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0090 - accuracy: 0.9972 - val_loss: 0.0280 - val_accuracy: 0.9909\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0084 - accuracy: 0.9978 - val_loss: 0.0326 - val_accuracy: 0.9901\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0071 - accuracy: 0.9980 - val_loss: 0.0350 - val_accuracy: 0.9901\n",
      "Starting run  1\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.2190 - accuracy: 0.5920 - val_loss: 0.1170 - val_accuracy: 0.9633\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1078 - accuracy: 0.9661 - val_loss: 0.0646 - val_accuracy: 0.9807\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1143 - accuracy: 0.9646 - val_loss: 0.0573 - val_accuracy: 0.9829\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0567 - accuracy: 0.9818 - val_loss: 0.0487 - val_accuracy: 0.9848\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0477 - accuracy: 0.9854 - val_loss: 0.0417 - val_accuracy: 0.9869\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0414 - accuracy: 0.9870 - val_loss: 0.0403 - val_accuracy: 0.9863\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0357 - accuracy: 0.9887 - val_loss: 0.0328 - val_accuracy: 0.9894\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0306 - accuracy: 0.9905 - val_loss: 0.0363 - val_accuracy: 0.9894\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0293 - accuracy: 0.9908 - val_loss: 0.0338 - val_accuracy: 0.9883\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0259 - accuracy: 0.9917 - val_loss: 0.0302 - val_accuracy: 0.9898\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0269 - accuracy: 0.9921 - val_loss: 0.0693 - val_accuracy: 0.9805\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0512 - accuracy: 0.9834 - val_loss: 0.0372 - val_accuracy: 0.9882\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0303 - accuracy: 0.9908 - val_loss: 0.0510 - val_accuracy: 0.9832\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0259 - accuracy: 0.9911 - val_loss: 0.0332 - val_accuracy: 0.9884\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0214 - accuracy: 0.9933 - val_loss: 0.0321 - val_accuracy: 0.9879\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0200 - accuracy: 0.9938 - val_loss: 0.0283 - val_accuracy: 0.9906\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0201 - accuracy: 0.9942 - val_loss: 0.0297 - val_accuracy: 0.9904\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0174 - accuracy: 0.9949 - val_loss: 0.0280 - val_accuracy: 0.9907\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0147 - accuracy: 0.9959 - val_loss: 0.0312 - val_accuracy: 0.9893\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0138 - accuracy: 0.9955 - val_loss: 0.0310 - val_accuracy: 0.9898\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0133 - accuracy: 0.9960 - val_loss: 0.0332 - val_accuracy: 0.9896\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0118 - accuracy: 0.9962 - val_loss: 0.0311 - val_accuracy: 0.9897\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0117 - accuracy: 0.9965 - val_loss: 0.0311 - val_accuracy: 0.9898\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0094 - accuracy: 0.9974 - val_loss: 0.0280 - val_accuracy: 0.9906\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0095 - accuracy: 0.9974 - val_loss: 0.0295 - val_accuracy: 0.9913\n",
      "Starting run  2\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1330 - accuracy: 0.6367 - val_loss: 0.1252 - val_accuracy: 0.9623\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1181 - accuracy: 0.9645 - val_loss: 0.0669 - val_accuracy: 0.9796\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0748 - accuracy: 0.9774 - val_loss: 0.0550 - val_accuracy: 0.9830\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0776 - accuracy: 0.9762 - val_loss: 0.0454 - val_accuracy: 0.9857\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0492 - accuracy: 0.9845 - val_loss: 0.0430 - val_accuracy: 0.9868\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0423 - accuracy: 0.9872 - val_loss: 0.0407 - val_accuracy: 0.9868\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0401 - accuracy: 0.9882 - val_loss: 0.0387 - val_accuracy: 0.9883\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0346 - accuracy: 0.9891 - val_loss: 0.0365 - val_accuracy: 0.9883\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0315 - accuracy: 0.9900 - val_loss: 0.0343 - val_accuracy: 0.9898\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0308 - accuracy: 0.9900 - val_loss: 0.0307 - val_accuracy: 0.9912\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0266 - accuracy: 0.9916 - val_loss: 0.0367 - val_accuracy: 0.9889\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0255 - accuracy: 0.9920 - val_loss: 0.0334 - val_accuracy: 0.9901\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0234 - accuracy: 0.9929 - val_loss: 0.0297 - val_accuracy: 0.9912\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0199 - accuracy: 0.9948 - val_loss: 0.0285 - val_accuracy: 0.9922\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0177 - accuracy: 0.9942 - val_loss: 0.0282 - val_accuracy: 0.9916\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0180 - accuracy: 0.9941 - val_loss: 0.0293 - val_accuracy: 0.9912\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.4981 - accuracy: 0.8721 - val_loss: 0.0622 - val_accuracy: 0.9798\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0521 - accuracy: 0.9834 - val_loss: 0.0491 - val_accuracy: 0.9853\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0400 - accuracy: 0.9875 - val_loss: 0.0441 - val_accuracy: 0.9865\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0316 - accuracy: 0.9892 - val_loss: 0.0422 - val_accuracy: 0.9874\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0298 - accuracy: 0.9906 - val_loss: 0.0389 - val_accuracy: 0.9879\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0254 - accuracy: 0.9918 - val_loss: 0.0358 - val_accuracy: 0.9887\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0217 - accuracy: 0.9933 - val_loss: 0.0373 - val_accuracy: 0.9877\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0196 - accuracy: 0.9934 - val_loss: 0.0359 - val_accuracy: 0.9898\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0179 - accuracy: 0.9946 - val_loss: 0.0464 - val_accuracy: 0.9866\n",
      "Starting run  3\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1359 - accuracy: 0.6242 - val_loss: 0.1025 - val_accuracy: 0.9696\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1108 - accuracy: 0.9673 - val_loss: 0.0669 - val_accuracy: 0.9800\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0770 - accuracy: 0.9779 - val_loss: 0.0606 - val_accuracy: 0.9799\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0597 - accuracy: 0.9820 - val_loss: 0.0487 - val_accuracy: 0.9853\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0459 - accuracy: 0.9859 - val_loss: 0.0431 - val_accuracy: 0.9874\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0396 - accuracy: 0.9878 - val_loss: 0.0357 - val_accuracy: 0.9890\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0368 - accuracy: 0.9884 - val_loss: 0.0359 - val_accuracy: 0.9884\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0339 - accuracy: 0.9896 - val_loss: 0.0354 - val_accuracy: 0.9882\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0299 - accuracy: 0.9916 - val_loss: 0.0311 - val_accuracy: 0.9899\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0274 - accuracy: 0.9919 - val_loss: 0.0353 - val_accuracy: 0.9883\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0233 - accuracy: 0.9931 - val_loss: 0.0307 - val_accuracy: 0.9901\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0225 - accuracy: 0.9929 - val_loss: 0.0318 - val_accuracy: 0.9893\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0204 - accuracy: 0.9939 - val_loss: 0.0279 - val_accuracy: 0.9902\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0201 - accuracy: 0.9941 - val_loss: 0.0378 - val_accuracy: 0.9882\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0177 - accuracy: 0.9949 - val_loss: 0.0287 - val_accuracy: 0.9904\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0154 - accuracy: 0.9949 - val_loss: 0.0341 - val_accuracy: 0.9892\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0150 - accuracy: 0.9956 - val_loss: 0.0280 - val_accuracy: 0.9905\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0161 - accuracy: 0.9949 - val_loss: 0.0276 - val_accuracy: 0.9905\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0138 - accuracy: 0.9962 - val_loss: 0.0292 - val_accuracy: 0.9901\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0115 - accuracy: 0.9970 - val_loss: 0.0269 - val_accuracy: 0.9903\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0101 - accuracy: 0.9969 - val_loss: 0.0320 - val_accuracy: 0.9905\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0099 - accuracy: 0.9968 - val_loss: 0.0274 - val_accuracy: 0.9906\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0080 - accuracy: 0.9977 - val_loss: 0.0299 - val_accuracy: 0.9900\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0093 - accuracy: 0.9972 - val_loss: 0.0300 - val_accuracy: 0.9904\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0080 - accuracy: 0.9982 - val_loss: 0.0279 - val_accuracy: 0.9912\n",
      "Starting run  4\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1911 - accuracy: 0.5969 - val_loss: 0.1085 - val_accuracy: 0.9657\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1171 - accuracy: 0.9645 - val_loss: 0.0677 - val_accuracy: 0.9792\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0760 - accuracy: 0.9768 - val_loss: 0.0548 - val_accuracy: 0.9825\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0619 - accuracy: 0.9815 - val_loss: 0.0460 - val_accuracy: 0.9854\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0530 - accuracy: 0.9832 - val_loss: 0.0372 - val_accuracy: 0.9881\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0394 - accuracy: 0.9878 - val_loss: 0.0394 - val_accuracy: 0.9879\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0395 - accuracy: 0.9881 - val_loss: 0.0384 - val_accuracy: 0.9877\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0324 - accuracy: 0.9902 - val_loss: 0.0367 - val_accuracy: 0.9886\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0290 - accuracy: 0.9911 - val_loss: 0.0320 - val_accuracy: 0.9897\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0278 - accuracy: 0.9912 - val_loss: 0.0332 - val_accuracy: 0.9890\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0265 - accuracy: 0.9916 - val_loss: 0.0271 - val_accuracy: 0.9914\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0219 - accuracy: 0.9931 - val_loss: 0.0307 - val_accuracy: 0.9900\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0202 - accuracy: 0.9940 - val_loss: 0.0352 - val_accuracy: 0.9886\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0188 - accuracy: 0.9937 - val_loss: 0.0301 - val_accuracy: 0.9908\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0199 - accuracy: 0.9943 - val_loss: 0.0289 - val_accuracy: 0.9918\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0158 - accuracy: 0.9948 - val_loss: 0.0263 - val_accuracy: 0.9917\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0143 - accuracy: 0.9955 - val_loss: 0.0293 - val_accuracy: 0.9907\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0134 - accuracy: 0.9958 - val_loss: 0.0332 - val_accuracy: 0.9889\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0132 - accuracy: 0.9961 - val_loss: 0.0308 - val_accuracy: 0.9906\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0120 - accuracy: 0.9965 - val_loss: 0.0308 - val_accuracy: 0.9913\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0117 - accuracy: 0.9966 - val_loss: 0.0301 - val_accuracy: 0.9903\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0103 - accuracy: 0.9967 - val_loss: 0.0279 - val_accuracy: 0.9915\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0090 - accuracy: 0.9975 - val_loss: 0.0333 - val_accuracy: 0.9897\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0094 - accuracy: 0.9971 - val_loss: 0.0278 - val_accuracy: 0.9920\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0081 - accuracy: 0.9978 - val_loss: 0.0308 - val_accuracy: 0.9904\n",
      "Starting run  5\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.9591 - accuracy: 0.6752 - val_loss: 0.1343 - val_accuracy: 0.9568\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1128 - accuracy: 0.9665 - val_loss: 0.0680 - val_accuracy: 0.9783\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0733 - accuracy: 0.9773 - val_loss: 0.0533 - val_accuracy: 0.9835\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0612 - accuracy: 0.9805 - val_loss: 0.0468 - val_accuracy: 0.9857\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0499 - accuracy: 0.9849 - val_loss: 0.0457 - val_accuracy: 0.9850\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0437 - accuracy: 0.9865 - val_loss: 0.0482 - val_accuracy: 0.9846\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0372 - accuracy: 0.9886 - val_loss: 0.0343 - val_accuracy: 0.9888\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0343 - accuracy: 0.9902 - val_loss: 0.0397 - val_accuracy: 0.9872\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0323 - accuracy: 0.9906 - val_loss: 0.0318 - val_accuracy: 0.9898\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0249 - accuracy: 0.9925 - val_loss: 0.0323 - val_accuracy: 0.9897\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0234 - accuracy: 0.9928 - val_loss: 0.0315 - val_accuracy: 0.9899\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0424 - accuracy: 0.9887 - val_loss: 0.0918 - val_accuracy: 0.9735\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0667 - accuracy: 0.9790 - val_loss: 0.0424 - val_accuracy: 0.9866\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0382 - accuracy: 0.9883 - val_loss: 0.0391 - val_accuracy: 0.9876\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0295 - accuracy: 0.9905 - val_loss: 0.0343 - val_accuracy: 0.9899\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0293 - accuracy: 0.9908 - val_loss: 0.0350 - val_accuracy: 0.9892\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0244 - accuracy: 0.9919 - val_loss: 0.0371 - val_accuracy: 0.9892\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0228 - accuracy: 0.9927 - val_loss: 0.0360 - val_accuracy: 0.9882\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0182 - accuracy: 0.9946 - val_loss: 0.0392 - val_accuracy: 0.9878\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0181 - accuracy: 0.9943 - val_loss: 0.0320 - val_accuracy: 0.9895\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0143 - accuracy: 0.9960 - val_loss: 0.0325 - val_accuracy: 0.9894\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0142 - accuracy: 0.9959 - val_loss: 0.0307 - val_accuracy: 0.9898\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0140 - accuracy: 0.9955 - val_loss: 0.0299 - val_accuracy: 0.9904\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0119 - accuracy: 0.9964 - val_loss: 0.0408 - val_accuracy: 0.9883\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0120 - accuracy: 0.9962 - val_loss: 0.0315 - val_accuracy: 0.9904\n",
      "Starting run  6\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1624 - accuracy: 0.5952 - val_loss: 0.1153 - val_accuracy: 0.9634\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1186 - accuracy: 0.9626 - val_loss: 0.1093 - val_accuracy: 0.9618\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0778 - accuracy: 0.9757 - val_loss: 0.0491 - val_accuracy: 0.9855\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0594 - accuracy: 0.9820 - val_loss: 0.0462 - val_accuracy: 0.9849\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0498 - accuracy: 0.9850 - val_loss: 0.0522 - val_accuracy: 0.9852\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0437 - accuracy: 0.9864 - val_loss: 0.0358 - val_accuracy: 0.9889\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0363 - accuracy: 0.9885 - val_loss: 0.0399 - val_accuracy: 0.9873\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0361 - accuracy: 0.9886 - val_loss: 0.0348 - val_accuracy: 0.9884\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0301 - accuracy: 0.9905 - val_loss: 0.0333 - val_accuracy: 0.9891\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0270 - accuracy: 0.9917 - val_loss: 0.0319 - val_accuracy: 0.9898\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0248 - accuracy: 0.9926 - val_loss: 0.0299 - val_accuracy: 0.9917\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0235 - accuracy: 0.9931 - val_loss: 0.0292 - val_accuracy: 0.9915\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0209 - accuracy: 0.9934 - val_loss: 0.0314 - val_accuracy: 0.9906\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0193 - accuracy: 0.9940 - val_loss: 0.0307 - val_accuracy: 0.9911\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0183 - accuracy: 0.9941 - val_loss: 0.0345 - val_accuracy: 0.9900\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0164 - accuracy: 0.9948 - val_loss: 0.0324 - val_accuracy: 0.9907\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0156 - accuracy: 0.9953 - val_loss: 0.0307 - val_accuracy: 0.9912\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0143 - accuracy: 0.9958 - val_loss: 0.0320 - val_accuracy: 0.9915\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0141 - accuracy: 0.9957 - val_loss: 0.0341 - val_accuracy: 0.9905\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0125 - accuracy: 0.9962 - val_loss: 0.0330 - val_accuracy: 0.9900\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0107 - accuracy: 0.9968 - val_loss: 0.0291 - val_accuracy: 0.9917\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0104 - accuracy: 0.9971 - val_loss: 0.0344 - val_accuracy: 0.9901\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0102 - accuracy: 0.9972 - val_loss: 0.0345 - val_accuracy: 0.9911\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0100 - accuracy: 0.9970 - val_loss: 0.0333 - val_accuracy: 0.9910\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0072 - accuracy: 0.9981 - val_loss: 0.0341 - val_accuracy: 0.9908\n",
      "Starting run  7\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1124 - accuracy: 0.6265 - val_loss: 0.1070 - val_accuracy: 0.9665\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1021 - accuracy: 0.9687 - val_loss: 0.1011 - val_accuracy: 0.9666\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0744 - accuracy: 0.9768 - val_loss: 0.0497 - val_accuracy: 0.9848\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0575 - accuracy: 0.9821 - val_loss: 0.0435 - val_accuracy: 0.9870\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0483 - accuracy: 0.9849 - val_loss: 0.0401 - val_accuracy: 0.9877\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0391 - accuracy: 0.9879 - val_loss: 0.0350 - val_accuracy: 0.9895\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0359 - accuracy: 0.9882 - val_loss: 0.0341 - val_accuracy: 0.9900\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0328 - accuracy: 0.9904 - val_loss: 0.0396 - val_accuracy: 0.9882\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0287 - accuracy: 0.9906 - val_loss: 0.0328 - val_accuracy: 0.9898\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0263 - accuracy: 0.9915 - val_loss: 0.0400 - val_accuracy: 0.9877\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0243 - accuracy: 0.9922 - val_loss: 0.0374 - val_accuracy: 0.9877\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0238 - accuracy: 0.9921 - val_loss: 0.0316 - val_accuracy: 0.9898\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0204 - accuracy: 0.9937 - val_loss: 0.0384 - val_accuracy: 0.9875\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0200 - accuracy: 0.9934 - val_loss: 0.0330 - val_accuracy: 0.9896\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0167 - accuracy: 0.9948 - val_loss: 0.0292 - val_accuracy: 0.9900\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0156 - accuracy: 0.9954 - val_loss: 0.0339 - val_accuracy: 0.9900\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0134 - accuracy: 0.9960 - val_loss: 0.0299 - val_accuracy: 0.9904\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0131 - accuracy: 0.9956 - val_loss: 0.0265 - val_accuracy: 0.9917\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0122 - accuracy: 0.9960 - val_loss: 0.0309 - val_accuracy: 0.9906\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0123 - accuracy: 0.9961 - val_loss: 0.0282 - val_accuracy: 0.9917\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0098 - accuracy: 0.9971 - val_loss: 0.0301 - val_accuracy: 0.9908\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0100 - accuracy: 0.9972 - val_loss: 0.0286 - val_accuracy: 0.9913\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0088 - accuracy: 0.9975 - val_loss: 0.0280 - val_accuracy: 0.9913\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0088 - accuracy: 0.9979 - val_loss: 0.0295 - val_accuracy: 0.9917\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0059 - accuracy: 0.9986 - val_loss: 0.0278 - val_accuracy: 0.9915\n",
      "Starting run  8\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1279 - accuracy: 0.6145 - val_loss: 0.1118 - val_accuracy: 0.9661\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1168 - accuracy: 0.9642 - val_loss: 0.0806 - val_accuracy: 0.9747\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0730 - accuracy: 0.9775 - val_loss: 0.0598 - val_accuracy: 0.9813\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0567 - accuracy: 0.9813 - val_loss: 0.0472 - val_accuracy: 0.9840\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0497 - accuracy: 0.9840 - val_loss: 0.0440 - val_accuracy: 0.9865\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0397 - accuracy: 0.9875 - val_loss: 0.0372 - val_accuracy: 0.9887\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0354 - accuracy: 0.9899 - val_loss: 0.0353 - val_accuracy: 0.9885\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0327 - accuracy: 0.9892 - val_loss: 0.0344 - val_accuracy: 0.9892\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0294 - accuracy: 0.9903 - val_loss: 0.0354 - val_accuracy: 0.9887\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0254 - accuracy: 0.9920 - val_loss: 0.0314 - val_accuracy: 0.9899\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0236 - accuracy: 0.9919 - val_loss: 0.0325 - val_accuracy: 0.9898\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0211 - accuracy: 0.9935 - val_loss: 0.0349 - val_accuracy: 0.9890\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0214 - accuracy: 0.9936 - val_loss: 0.0303 - val_accuracy: 0.9915\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0193 - accuracy: 0.9942 - val_loss: 0.0320 - val_accuracy: 0.9901\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0174 - accuracy: 0.9947 - val_loss: 0.0297 - val_accuracy: 0.9913\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0148 - accuracy: 0.9957 - val_loss: 0.0302 - val_accuracy: 0.9902\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0137 - accuracy: 0.9960 - val_loss: 0.0318 - val_accuracy: 0.9912\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0125 - accuracy: 0.9961 - val_loss: 0.0329 - val_accuracy: 0.9896\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0128 - accuracy: 0.9966 - val_loss: 0.0281 - val_accuracy: 0.9914\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0108 - accuracy: 0.9967 - val_loss: 0.0319 - val_accuracy: 0.9906\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0121 - accuracy: 0.9965 - val_loss: 0.0307 - val_accuracy: 0.9912\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0101 - accuracy: 0.9973 - val_loss: 0.0302 - val_accuracy: 0.9920\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0090 - accuracy: 0.9972 - val_loss: 0.0366 - val_accuracy: 0.9899\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0075 - accuracy: 0.9977 - val_loss: 0.0301 - val_accuracy: 0.9914\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0077 - accuracy: 0.9979 - val_loss: 0.0305 - val_accuracy: 0.9915\n",
      "Starting run  9\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1862 - accuracy: 0.6142 - val_loss: 0.1380 - val_accuracy: 0.9599\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1592 - accuracy: 0.9534 - val_loss: 0.0726 - val_accuracy: 0.9770\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0773 - accuracy: 0.9752 - val_loss: 0.0557 - val_accuracy: 0.9824\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0589 - accuracy: 0.9809 - val_loss: 0.0501 - val_accuracy: 0.9850\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0485 - accuracy: 0.9848 - val_loss: 0.0477 - val_accuracy: 0.9858\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0430 - accuracy: 0.9867 - val_loss: 0.0376 - val_accuracy: 0.9881\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0355 - accuracy: 0.9887 - val_loss: 0.0383 - val_accuracy: 0.9882\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0359 - accuracy: 0.9890 - val_loss: 0.0425 - val_accuracy: 0.9866\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0298 - accuracy: 0.9901 - val_loss: 0.0388 - val_accuracy: 0.9882\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0292 - accuracy: 0.9907 - val_loss: 0.0329 - val_accuracy: 0.9900\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0251 - accuracy: 0.9919 - val_loss: 0.0358 - val_accuracy: 0.9883\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0231 - accuracy: 0.9932 - val_loss: 0.0368 - val_accuracy: 0.9882\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0209 - accuracy: 0.9931 - val_loss: 0.0351 - val_accuracy: 0.9891\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0204 - accuracy: 0.9940 - val_loss: 0.0353 - val_accuracy: 0.9893\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0171 - accuracy: 0.9945 - val_loss: 0.0408 - val_accuracy: 0.9872\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0182 - accuracy: 0.9939 - val_loss: 0.0370 - val_accuracy: 0.9880\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0162 - accuracy: 0.9952 - val_loss: 0.0386 - val_accuracy: 0.9877\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0163 - accuracy: 0.9946 - val_loss: 0.0323 - val_accuracy: 0.9895\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0141 - accuracy: 0.9955 - val_loss: 0.0321 - val_accuracy: 0.9896\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0124 - accuracy: 0.9960 - val_loss: 0.0318 - val_accuracy: 0.9895\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0121 - accuracy: 0.9966 - val_loss: 0.0554 - val_accuracy: 0.9834\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0116 - accuracy: 0.9964 - val_loss: 0.0334 - val_accuracy: 0.9905\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0096 - accuracy: 0.9969 - val_loss: 0.0371 - val_accuracy: 0.9893\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0089 - accuracy: 0.9972 - val_loss: 0.0324 - val_accuracy: 0.9906\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0081 - accuracy: 0.9974 - val_loss: 0.0308 - val_accuracy: 0.9909\n",
      "Starting run  10\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.2701 - accuracy: 0.5884 - val_loss: 0.1371 - val_accuracy: 0.9584\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1274 - accuracy: 0.9606 - val_loss: 0.0764 - val_accuracy: 0.9763\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0854 - accuracy: 0.9733 - val_loss: 0.0570 - val_accuracy: 0.9804\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0632 - accuracy: 0.9809 - val_loss: 0.0652 - val_accuracy: 0.9794\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0635 - accuracy: 0.9802 - val_loss: 0.0432 - val_accuracy: 0.9860\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0482 - accuracy: 0.9851 - val_loss: 0.0461 - val_accuracy: 0.9845\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0434 - accuracy: 0.9865 - val_loss: 0.0392 - val_accuracy: 0.9864\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0380 - accuracy: 0.9879 - val_loss: 0.0462 - val_accuracy: 0.9844\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0332 - accuracy: 0.9900 - val_loss: 0.0347 - val_accuracy: 0.9888\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0296 - accuracy: 0.9912 - val_loss: 0.0320 - val_accuracy: 0.9895\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0283 - accuracy: 0.9918 - val_loss: 0.0350 - val_accuracy: 0.9888\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0276 - accuracy: 0.9911 - val_loss: 0.0294 - val_accuracy: 0.9901\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0240 - accuracy: 0.9924 - val_loss: 0.0358 - val_accuracy: 0.9886\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0219 - accuracy: 0.9932 - val_loss: 0.0362 - val_accuracy: 0.9879\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0197 - accuracy: 0.9935 - val_loss: 0.0398 - val_accuracy: 0.9879\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0212 - accuracy: 0.9936 - val_loss: 0.0351 - val_accuracy: 0.9897\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0174 - accuracy: 0.9951 - val_loss: 0.0299 - val_accuracy: 0.9899\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0166 - accuracy: 0.9945 - val_loss: 0.0330 - val_accuracy: 0.9894\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0165 - accuracy: 0.9948 - val_loss: 0.0295 - val_accuracy: 0.9904\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0142 - accuracy: 0.9959 - val_loss: 0.0297 - val_accuracy: 0.9901\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0128 - accuracy: 0.9965 - val_loss: 0.0304 - val_accuracy: 0.9901\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0130 - accuracy: 0.9962 - val_loss: 0.0284 - val_accuracy: 0.9909\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0109 - accuracy: 0.9965 - val_loss: 0.0310 - val_accuracy: 0.9910\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0116 - accuracy: 0.9965 - val_loss: 0.0291 - val_accuracy: 0.9912\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0105 - accuracy: 0.9969 - val_loss: 0.0334 - val_accuracy: 0.9896\n",
      "Starting run  11\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.2284 - accuracy: 0.5991 - val_loss: 0.1167 - val_accuracy: 0.9655\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1135 - accuracy: 0.9646 - val_loss: 0.0625 - val_accuracy: 0.9801\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0741 - accuracy: 0.9774 - val_loss: 0.0492 - val_accuracy: 0.9840\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0550 - accuracy: 0.9827 - val_loss: 0.0411 - val_accuracy: 0.9863\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0487 - accuracy: 0.9843 - val_loss: 0.0567 - val_accuracy: 0.9824\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0661 - accuracy: 0.9804 - val_loss: 0.0358 - val_accuracy: 0.9875\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0377 - accuracy: 0.9884 - val_loss: 0.0353 - val_accuracy: 0.9876\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0311 - accuracy: 0.9905 - val_loss: 0.0361 - val_accuracy: 0.9866\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0279 - accuracy: 0.9908 - val_loss: 0.0393 - val_accuracy: 0.9864\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0249 - accuracy: 0.9921 - val_loss: 0.0454 - val_accuracy: 0.9860\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0246 - accuracy: 0.9921 - val_loss: 0.0326 - val_accuracy: 0.9896\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0225 - accuracy: 0.9932 - val_loss: 0.0313 - val_accuracy: 0.9898\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0220 - accuracy: 0.9931 - val_loss: 0.0320 - val_accuracy: 0.9898\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0193 - accuracy: 0.9941 - val_loss: 0.0302 - val_accuracy: 0.9898\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0177 - accuracy: 0.9947 - val_loss: 0.0370 - val_accuracy: 0.9887\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0157 - accuracy: 0.9952 - val_loss: 0.0333 - val_accuracy: 0.9894\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0144 - accuracy: 0.9949 - val_loss: 0.0315 - val_accuracy: 0.9894\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0157 - accuracy: 0.9944 - val_loss: 0.0309 - val_accuracy: 0.9901\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0136 - accuracy: 0.9961 - val_loss: 0.0311 - val_accuracy: 0.9905\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0128 - accuracy: 0.9961 - val_loss: 0.0309 - val_accuracy: 0.9905\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0103 - accuracy: 0.9970 - val_loss: 0.0322 - val_accuracy: 0.9900\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0104 - accuracy: 0.9969 - val_loss: 0.0295 - val_accuracy: 0.9904\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0100 - accuracy: 0.9970 - val_loss: 0.0336 - val_accuracy: 0.9903\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0093 - accuracy: 0.9972 - val_loss: 0.0341 - val_accuracy: 0.9892\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0093 - accuracy: 0.9973 - val_loss: 0.0351 - val_accuracy: 0.9901\n",
      "Starting run  12\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1254 - accuracy: 0.6331 - val_loss: 0.1274 - val_accuracy: 0.9609\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1199 - accuracy: 0.9624 - val_loss: 0.0763 - val_accuracy: 0.9748\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0787 - accuracy: 0.9758 - val_loss: 0.0527 - val_accuracy: 0.9825\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0645 - accuracy: 0.9808 - val_loss: 0.0429 - val_accuracy: 0.9863\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0498 - accuracy: 0.9850 - val_loss: 0.0492 - val_accuracy: 0.9833\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0447 - accuracy: 0.9854 - val_loss: 0.0489 - val_accuracy: 0.9828\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0379 - accuracy: 0.9886 - val_loss: 0.0342 - val_accuracy: 0.9885\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0343 - accuracy: 0.9894 - val_loss: 0.0412 - val_accuracy: 0.9861\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0298 - accuracy: 0.9908 - val_loss: 0.0371 - val_accuracy: 0.9876\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0271 - accuracy: 0.9917 - val_loss: 0.0357 - val_accuracy: 0.9886\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0253 - accuracy: 0.9921 - val_loss: 0.0293 - val_accuracy: 0.9896\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0261 - accuracy: 0.9922 - val_loss: 0.0303 - val_accuracy: 0.9898\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0227 - accuracy: 0.9925 - val_loss: 0.0391 - val_accuracy: 0.9881\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0200 - accuracy: 0.9938 - val_loss: 0.0298 - val_accuracy: 0.9904\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0189 - accuracy: 0.9938 - val_loss: 0.0268 - val_accuracy: 0.9904\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0164 - accuracy: 0.9951 - val_loss: 0.0295 - val_accuracy: 0.9900\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0181 - accuracy: 0.9936 - val_loss: 0.0299 - val_accuracy: 0.9903\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0140 - accuracy: 0.9958 - val_loss: 0.0368 - val_accuracy: 0.9887\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0128 - accuracy: 0.9964 - val_loss: 0.0309 - val_accuracy: 0.9908\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0121 - accuracy: 0.9966 - val_loss: 0.0323 - val_accuracy: 0.9905\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0134 - accuracy: 0.9957 - val_loss: 0.0311 - val_accuracy: 0.9909\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0512 - accuracy: 0.9892 - val_loss: 0.0741 - val_accuracy: 0.9770\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0579 - accuracy: 0.9810 - val_loss: 0.0391 - val_accuracy: 0.9876\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0315 - accuracy: 0.9895 - val_loss: 0.0316 - val_accuracy: 0.9894\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0245 - accuracy: 0.9917 - val_loss: 0.0312 - val_accuracy: 0.9897\n",
      "Starting run  13\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1561 - accuracy: 0.6276 - val_loss: 0.1237 - val_accuracy: 0.9629\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1247 - accuracy: 0.9614 - val_loss: 0.0713 - val_accuracy: 0.9759\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0793 - accuracy: 0.9751 - val_loss: 0.0568 - val_accuracy: 0.9807\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0600 - accuracy: 0.9813 - val_loss: 0.0572 - val_accuracy: 0.9821\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0502 - accuracy: 0.9847 - val_loss: 0.0419 - val_accuracy: 0.9862\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0458 - accuracy: 0.9858 - val_loss: 0.0407 - val_accuracy: 0.9871\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0372 - accuracy: 0.9883 - val_loss: 0.0344 - val_accuracy: 0.9891\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0354 - accuracy: 0.9885 - val_loss: 0.0417 - val_accuracy: 0.9872\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0331 - accuracy: 0.9888 - val_loss: 0.0349 - val_accuracy: 0.9892\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0316 - accuracy: 0.9903 - val_loss: 0.0305 - val_accuracy: 0.9904\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0277 - accuracy: 0.9914 - val_loss: 0.0306 - val_accuracy: 0.9899\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0235 - accuracy: 0.9926 - val_loss: 0.0563 - val_accuracy: 0.9824\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0245 - accuracy: 0.9923 - val_loss: 0.0300 - val_accuracy: 0.9903\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0217 - accuracy: 0.9932 - val_loss: 0.0355 - val_accuracy: 0.9885\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0209 - accuracy: 0.9934 - val_loss: 0.0293 - val_accuracy: 0.9908\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0180 - accuracy: 0.9944 - val_loss: 0.0295 - val_accuracy: 0.9910\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0159 - accuracy: 0.9956 - val_loss: 0.0309 - val_accuracy: 0.9911\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0147 - accuracy: 0.9955 - val_loss: 0.0302 - val_accuracy: 0.9899\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0131 - accuracy: 0.9964 - val_loss: 0.0301 - val_accuracy: 0.9909\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0123 - accuracy: 0.9964 - val_loss: 0.0336 - val_accuracy: 0.9894\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0135 - accuracy: 0.9957 - val_loss: 0.0300 - val_accuracy: 0.9906\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0118 - accuracy: 0.9965 - val_loss: 0.0316 - val_accuracy: 0.9901\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0109 - accuracy: 0.9967 - val_loss: 0.0331 - val_accuracy: 0.9910\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0139 - accuracy: 0.9956 - val_loss: 0.0358 - val_accuracy: 0.9897\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0090 - accuracy: 0.9975 - val_loss: 0.0301 - val_accuracy: 0.9913\n",
      "Starting run  14\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1157 - accuracy: 0.6300 - val_loss: 0.0985 - val_accuracy: 0.9684\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1451 - accuracy: 0.9561 - val_loss: 0.0742 - val_accuracy: 0.9769\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0675 - accuracy: 0.9788 - val_loss: 0.0579 - val_accuracy: 0.9814\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0523 - accuracy: 0.9835 - val_loss: 0.0415 - val_accuracy: 0.9862\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0431 - accuracy: 0.9872 - val_loss: 0.0432 - val_accuracy: 0.9854\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0404 - accuracy: 0.9870 - val_loss: 0.0345 - val_accuracy: 0.9878\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0328 - accuracy: 0.9893 - val_loss: 0.0342 - val_accuracy: 0.9882\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0309 - accuracy: 0.9908 - val_loss: 0.0367 - val_accuracy: 0.9885\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0272 - accuracy: 0.9912 - val_loss: 0.0366 - val_accuracy: 0.9880\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0236 - accuracy: 0.9928 - val_loss: 0.0305 - val_accuracy: 0.9892\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0213 - accuracy: 0.9934 - val_loss: 0.0288 - val_accuracy: 0.9905\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0197 - accuracy: 0.9936 - val_loss: 0.0484 - val_accuracy: 0.9848\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0195 - accuracy: 0.9941 - val_loss: 0.0339 - val_accuracy: 0.9898\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0181 - accuracy: 0.9945 - val_loss: 0.0300 - val_accuracy: 0.9898\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0170 - accuracy: 0.9943 - val_loss: 0.0406 - val_accuracy: 0.9872\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0163 - accuracy: 0.9951 - val_loss: 0.0290 - val_accuracy: 0.9895\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0137 - accuracy: 0.9958 - val_loss: 0.0316 - val_accuracy: 0.9899\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0130 - accuracy: 0.9958 - val_loss: 0.0347 - val_accuracy: 0.9896\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0135 - accuracy: 0.9959 - val_loss: 0.0315 - val_accuracy: 0.9896\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0108 - accuracy: 0.9969 - val_loss: 0.0438 - val_accuracy: 0.9873\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0094 - accuracy: 0.9974 - val_loss: 0.0342 - val_accuracy: 0.9895\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0090 - accuracy: 0.9970 - val_loss: 0.0302 - val_accuracy: 0.9904\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0090 - accuracy: 0.9972 - val_loss: 0.0337 - val_accuracy: 0.9894\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0082 - accuracy: 0.9976 - val_loss: 0.0326 - val_accuracy: 0.9898\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0065 - accuracy: 0.9983 - val_loss: 0.0314 - val_accuracy: 0.9903\n",
      "Starting run  15\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1743 - accuracy: 0.6004 - val_loss: 0.1127 - val_accuracy: 0.9649\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1128 - accuracy: 0.9659 - val_loss: 0.0726 - val_accuracy: 0.9760\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0744 - accuracy: 0.9769 - val_loss: 0.0492 - val_accuracy: 0.9848\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0588 - accuracy: 0.9820 - val_loss: 0.0613 - val_accuracy: 0.9807\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0499 - accuracy: 0.9852 - val_loss: 0.0387 - val_accuracy: 0.9874\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0426 - accuracy: 0.9863 - val_loss: 0.0369 - val_accuracy: 0.9874\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0377 - accuracy: 0.9878 - val_loss: 0.0373 - val_accuracy: 0.9883\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0360 - accuracy: 0.9884 - val_loss: 0.0347 - val_accuracy: 0.9879\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0315 - accuracy: 0.9899 - val_loss: 0.0348 - val_accuracy: 0.9886\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0268 - accuracy: 0.9918 - val_loss: 0.0320 - val_accuracy: 0.9889\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0282 - accuracy: 0.9910 - val_loss: 0.0424 - val_accuracy: 0.9866\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0226 - accuracy: 0.9930 - val_loss: 0.0289 - val_accuracy: 0.9904\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0214 - accuracy: 0.9933 - val_loss: 0.0307 - val_accuracy: 0.9894\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0209 - accuracy: 0.9938 - val_loss: 0.0293 - val_accuracy: 0.9905\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0548 - accuracy: 0.9850 - val_loss: 0.0712 - val_accuracy: 0.9775\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0575 - accuracy: 0.9805 - val_loss: 0.0457 - val_accuracy: 0.9849\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0331 - accuracy: 0.9891 - val_loss: 0.0400 - val_accuracy: 0.9864\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0275 - accuracy: 0.9909 - val_loss: 0.0362 - val_accuracy: 0.9874\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0216 - accuracy: 0.9932 - val_loss: 0.0353 - val_accuracy: 0.9887\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0213 - accuracy: 0.9939 - val_loss: 0.0365 - val_accuracy: 0.9881\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0178 - accuracy: 0.9942 - val_loss: 0.0306 - val_accuracy: 0.9895\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0152 - accuracy: 0.9957 - val_loss: 0.0336 - val_accuracy: 0.9895\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0174 - accuracy: 0.9948 - val_loss: 0.0299 - val_accuracy: 0.9905\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0131 - accuracy: 0.9960 - val_loss: 0.0304 - val_accuracy: 0.9905\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0119 - accuracy: 0.9961 - val_loss: 0.0309 - val_accuracy: 0.9908\n",
      "Starting run  16\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1169 - accuracy: 0.6224 - val_loss: 0.1104 - val_accuracy: 0.9645\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1244 - accuracy: 0.9621 - val_loss: 0.0668 - val_accuracy: 0.9784\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0800 - accuracy: 0.9748 - val_loss: 0.0632 - val_accuracy: 0.9807\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.6113 - accuracy: 0.8616 - val_loss: 0.1854 - val_accuracy: 0.9427\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.2754 - accuracy: 0.9176 - val_loss: 0.1245 - val_accuracy: 0.9611\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1328 - accuracy: 0.9584 - val_loss: 0.1017 - val_accuracy: 0.9671\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1106 - accuracy: 0.9643 - val_loss: 0.0850 - val_accuracy: 0.9724\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0927 - accuracy: 0.9700 - val_loss: 0.0811 - val_accuracy: 0.9733\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0865 - accuracy: 0.9731 - val_loss: 0.0773 - val_accuracy: 0.9764\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0767 - accuracy: 0.9758 - val_loss: 0.0862 - val_accuracy: 0.9713\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0700 - accuracy: 0.9780 - val_loss: 0.0754 - val_accuracy: 0.9781\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0706 - accuracy: 0.9780 - val_loss: 0.0672 - val_accuracy: 0.9797\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0649 - accuracy: 0.9799 - val_loss: 0.0672 - val_accuracy: 0.9791\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0608 - accuracy: 0.9814 - val_loss: 0.0738 - val_accuracy: 0.9772\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0558 - accuracy: 0.9819 - val_loss: 0.0577 - val_accuracy: 0.9819\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0536 - accuracy: 0.9832 - val_loss: 0.1082 - val_accuracy: 0.9663\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0527 - accuracy: 0.9832 - val_loss: 0.0570 - val_accuracy: 0.9809\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0490 - accuracy: 0.9849 - val_loss: 0.0555 - val_accuracy: 0.9827\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0469 - accuracy: 0.9845 - val_loss: 0.0612 - val_accuracy: 0.9801\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0477 - accuracy: 0.9853 - val_loss: 0.0536 - val_accuracy: 0.9826\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0439 - accuracy: 0.9855 - val_loss: 0.0533 - val_accuracy: 0.9840\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0426 - accuracy: 0.9871 - val_loss: 0.0598 - val_accuracy: 0.9808\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0396 - accuracy: 0.9866 - val_loss: 0.0632 - val_accuracy: 0.9815\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0393 - accuracy: 0.9883 - val_loss: 0.0644 - val_accuracy: 0.9805\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0375 - accuracy: 0.9875 - val_loss: 0.0509 - val_accuracy: 0.9848\n",
      "Starting run  17\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.2867 - accuracy: 0.5511 - val_loss: 0.1992 - val_accuracy: 0.9348\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1325 - accuracy: 0.9602 - val_loss: 0.0832 - val_accuracy: 0.9735\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0852 - accuracy: 0.9736 - val_loss: 0.0509 - val_accuracy: 0.9850\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0618 - accuracy: 0.9808 - val_loss: 0.0495 - val_accuracy: 0.9856\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0524 - accuracy: 0.9834 - val_loss: 0.0439 - val_accuracy: 0.9859\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0455 - accuracy: 0.9854 - val_loss: 0.0411 - val_accuracy: 0.9866\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0397 - accuracy: 0.9866 - val_loss: 0.0352 - val_accuracy: 0.9891\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0338 - accuracy: 0.9898 - val_loss: 0.0337 - val_accuracy: 0.9889\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0299 - accuracy: 0.9903 - val_loss: 0.0367 - val_accuracy: 0.9885\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0301 - accuracy: 0.9905 - val_loss: 0.0326 - val_accuracy: 0.9898\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0255 - accuracy: 0.9920 - val_loss: 0.0432 - val_accuracy: 0.9859\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0239 - accuracy: 0.9926 - val_loss: 0.0322 - val_accuracy: 0.9897\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0219 - accuracy: 0.9932 - val_loss: 0.0311 - val_accuracy: 0.9901\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0185 - accuracy: 0.9943 - val_loss: 0.0312 - val_accuracy: 0.9901\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0197 - accuracy: 0.9937 - val_loss: 0.0314 - val_accuracy: 0.9899\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0184 - accuracy: 0.9945 - val_loss: 0.0369 - val_accuracy: 0.9887\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0157 - accuracy: 0.9953 - val_loss: 0.0325 - val_accuracy: 0.9904\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0136 - accuracy: 0.9959 - val_loss: 0.0297 - val_accuracy: 0.9905\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0132 - accuracy: 0.9960 - val_loss: 0.0320 - val_accuracy: 0.9894\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0132 - accuracy: 0.9959 - val_loss: 0.0347 - val_accuracy: 0.9899\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0119 - accuracy: 0.9962 - val_loss: 0.0323 - val_accuracy: 0.9905\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0098 - accuracy: 0.9973 - val_loss: 0.0329 - val_accuracy: 0.9906\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0108 - accuracy: 0.9973 - val_loss: 0.0317 - val_accuracy: 0.9906\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0089 - accuracy: 0.9975 - val_loss: 0.0304 - val_accuracy: 0.9913\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0079 - accuracy: 0.9976 - val_loss: 0.0312 - val_accuracy: 0.9909\n",
      "Starting run  18\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.0786 - accuracy: 0.6413 - val_loss: 0.1077 - val_accuracy: 0.9668\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1165 - accuracy: 0.9640 - val_loss: 0.1087 - val_accuracy: 0.9636\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0823 - accuracy: 0.9744 - val_loss: 0.0569 - val_accuracy: 0.9806\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0642 - accuracy: 0.9803 - val_loss: 0.0425 - val_accuracy: 0.9866\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0510 - accuracy: 0.9838 - val_loss: 0.0403 - val_accuracy: 0.9873\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0454 - accuracy: 0.9859 - val_loss: 0.0384 - val_accuracy: 0.9884\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0368 - accuracy: 0.9876 - val_loss: 0.0428 - val_accuracy: 0.9850\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0327 - accuracy: 0.9897 - val_loss: 0.0405 - val_accuracy: 0.9870\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0301 - accuracy: 0.9907 - val_loss: 0.0421 - val_accuracy: 0.9865\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0307 - accuracy: 0.9901 - val_loss: 0.0609 - val_accuracy: 0.9810\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0271 - accuracy: 0.9915 - val_loss: 0.0289 - val_accuracy: 0.9918\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0239 - accuracy: 0.9924 - val_loss: 0.0285 - val_accuracy: 0.9910\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0200 - accuracy: 0.9940 - val_loss: 0.0289 - val_accuracy: 0.9913\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0193 - accuracy: 0.9935 - val_loss: 0.0294 - val_accuracy: 0.9914\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0199 - accuracy: 0.9936 - val_loss: 0.0309 - val_accuracy: 0.9910\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0161 - accuracy: 0.9947 - val_loss: 0.0343 - val_accuracy: 0.9901\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0143 - accuracy: 0.9952 - val_loss: 0.0307 - val_accuracy: 0.9917\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0145 - accuracy: 0.9955 - val_loss: 0.0290 - val_accuracy: 0.9924\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0136 - accuracy: 0.9958 - val_loss: 0.0294 - val_accuracy: 0.9914\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0107 - accuracy: 0.9966 - val_loss: 0.0294 - val_accuracy: 0.9922\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0108 - accuracy: 0.9967 - val_loss: 0.0351 - val_accuracy: 0.9898\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0108 - accuracy: 0.9967 - val_loss: 0.0323 - val_accuracy: 0.9916\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0099 - accuracy: 0.9970 - val_loss: 0.0354 - val_accuracy: 0.9906\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0091 - accuracy: 0.9975 - val_loss: 0.0332 - val_accuracy: 0.9913\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0076 - accuracy: 0.9979 - val_loss: 0.0341 - val_accuracy: 0.9906\n",
      "Starting run  19\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1438 - accuracy: 0.6133 - val_loss: 0.1223 - val_accuracy: 0.9618\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1171 - accuracy: 0.9626 - val_loss: 0.0781 - val_accuracy: 0.9756\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0797 - accuracy: 0.9756 - val_loss: 0.0623 - val_accuracy: 0.9801\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0603 - accuracy: 0.9807 - val_loss: 0.0480 - val_accuracy: 0.9835\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0503 - accuracy: 0.9843 - val_loss: 0.0422 - val_accuracy: 0.9874\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0457 - accuracy: 0.9855 - val_loss: 0.0423 - val_accuracy: 0.9863\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0388 - accuracy: 0.9873 - val_loss: 0.0350 - val_accuracy: 0.9888\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0363 - accuracy: 0.9882 - val_loss: 0.0335 - val_accuracy: 0.9891\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0357 - accuracy: 0.9882 - val_loss: 0.0335 - val_accuracy: 0.9895\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0280 - accuracy: 0.9908 - val_loss: 0.0325 - val_accuracy: 0.9894\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0271 - accuracy: 0.9912 - val_loss: 0.0341 - val_accuracy: 0.9897\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0234 - accuracy: 0.9924 - val_loss: 0.0463 - val_accuracy: 0.9850\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0231 - accuracy: 0.9925 - val_loss: 0.0293 - val_accuracy: 0.9905\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0211 - accuracy: 0.9934 - val_loss: 0.0292 - val_accuracy: 0.9899\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0204 - accuracy: 0.9936 - val_loss: 0.0312 - val_accuracy: 0.9902\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0171 - accuracy: 0.9943 - val_loss: 0.0270 - val_accuracy: 0.9913\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0169 - accuracy: 0.9947 - val_loss: 0.0312 - val_accuracy: 0.9907\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0166 - accuracy: 0.9956 - val_loss: 0.0350 - val_accuracy: 0.9890\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0138 - accuracy: 0.9958 - val_loss: 0.0300 - val_accuracy: 0.9908\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0148 - accuracy: 0.9950 - val_loss: 0.0346 - val_accuracy: 0.9902\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0123 - accuracy: 0.9959 - val_loss: 0.0309 - val_accuracy: 0.9912\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0110 - accuracy: 0.9965 - val_loss: 0.0314 - val_accuracy: 0.9905\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0113 - accuracy: 0.9969 - val_loss: 0.0307 - val_accuracy: 0.9912\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0105 - accuracy: 0.9969 - val_loss: 0.0305 - val_accuracy: 0.9912\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0088 - accuracy: 0.9972 - val_loss: 0.0326 - val_accuracy: 0.9908\n",
      "Starting run  20\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.2106 - accuracy: 0.5921 - val_loss: 0.1256 - val_accuracy: 0.9577\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1115 - accuracy: 0.9654 - val_loss: 0.0635 - val_accuracy: 0.9801\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0735 - accuracy: 0.9777 - val_loss: 0.0501 - val_accuracy: 0.9843\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0586 - accuracy: 0.9814 - val_loss: 0.0434 - val_accuracy: 0.9867\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0479 - accuracy: 0.9851 - val_loss: 0.0421 - val_accuracy: 0.9855\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0416 - accuracy: 0.9865 - val_loss: 0.0363 - val_accuracy: 0.9881\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0375 - accuracy: 0.9876 - val_loss: 0.0324 - val_accuracy: 0.9900\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0325 - accuracy: 0.9901 - val_loss: 0.0363 - val_accuracy: 0.9880\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0311 - accuracy: 0.9904 - val_loss: 0.0438 - val_accuracy: 0.9859\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0255 - accuracy: 0.9923 - val_loss: 0.0325 - val_accuracy: 0.9895\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0221 - accuracy: 0.9930 - val_loss: 0.0409 - val_accuracy: 0.9865\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0230 - accuracy: 0.9930 - val_loss: 0.0285 - val_accuracy: 0.9906\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0193 - accuracy: 0.9937 - val_loss: 0.0325 - val_accuracy: 0.9896\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0184 - accuracy: 0.9945 - val_loss: 0.0321 - val_accuracy: 0.9894\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0173 - accuracy: 0.9949 - val_loss: 0.0268 - val_accuracy: 0.9911\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0150 - accuracy: 0.9955 - val_loss: 0.0273 - val_accuracy: 0.9911\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0146 - accuracy: 0.9952 - val_loss: 0.0278 - val_accuracy: 0.9907\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0134 - accuracy: 0.9960 - val_loss: 0.0260 - val_accuracy: 0.9918\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0127 - accuracy: 0.9962 - val_loss: 0.0273 - val_accuracy: 0.9913\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0113 - accuracy: 0.9966 - val_loss: 0.0260 - val_accuracy: 0.9921\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0095 - accuracy: 0.9968 - val_loss: 0.0287 - val_accuracy: 0.9903\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0090 - accuracy: 0.9974 - val_loss: 0.0250 - val_accuracy: 0.9923\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0085 - accuracy: 0.9976 - val_loss: 0.0302 - val_accuracy: 0.9906\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0083 - accuracy: 0.9974 - val_loss: 0.0296 - val_accuracy: 0.9910\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0068 - accuracy: 0.9986 - val_loss: 0.0368 - val_accuracy: 0.9897\n",
      "Starting run  21\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.2205 - accuracy: 0.5988 - val_loss: 0.1146 - val_accuracy: 0.9633\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1116 - accuracy: 0.9648 - val_loss: 0.0924 - val_accuracy: 0.9711\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0760 - accuracy: 0.9765 - val_loss: 0.0554 - val_accuracy: 0.9820\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0616 - accuracy: 0.9806 - val_loss: 0.0480 - val_accuracy: 0.9854\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0520 - accuracy: 0.9837 - val_loss: 0.0481 - val_accuracy: 0.9851\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0424 - accuracy: 0.9874 - val_loss: 0.0386 - val_accuracy: 0.9877\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0376 - accuracy: 0.9883 - val_loss: 0.0384 - val_accuracy: 0.9878\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0354 - accuracy: 0.9891 - val_loss: 0.0334 - val_accuracy: 0.9886\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0313 - accuracy: 0.9905 - val_loss: 0.0318 - val_accuracy: 0.9904\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0269 - accuracy: 0.9920 - val_loss: 0.0323 - val_accuracy: 0.9900\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0269 - accuracy: 0.9918 - val_loss: 0.0277 - val_accuracy: 0.9910\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0226 - accuracy: 0.9930 - val_loss: 0.0314 - val_accuracy: 0.9898\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0204 - accuracy: 0.9935 - val_loss: 0.0323 - val_accuracy: 0.9887\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0203 - accuracy: 0.9936 - val_loss: 0.0358 - val_accuracy: 0.9883\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0199 - accuracy: 0.9942 - val_loss: 0.0361 - val_accuracy: 0.9878\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0173 - accuracy: 0.9947 - val_loss: 0.0289 - val_accuracy: 0.9909\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0152 - accuracy: 0.9951 - val_loss: 0.0300 - val_accuracy: 0.9898\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0148 - accuracy: 0.9957 - val_loss: 0.0277 - val_accuracy: 0.9905\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0122 - accuracy: 0.9964 - val_loss: 0.0250 - val_accuracy: 0.9920\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0120 - accuracy: 0.9966 - val_loss: 0.0267 - val_accuracy: 0.9909\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0121 - accuracy: 0.9961 - val_loss: 0.0273 - val_accuracy: 0.9913\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0096 - accuracy: 0.9972 - val_loss: 0.0267 - val_accuracy: 0.9906\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0097 - accuracy: 0.9971 - val_loss: 0.0353 - val_accuracy: 0.9891\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0085 - accuracy: 0.9973 - val_loss: 0.0284 - val_accuracy: 0.9910\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0081 - accuracy: 0.9977 - val_loss: 0.0251 - val_accuracy: 0.9927\n",
      "Starting run  22\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1617 - accuracy: 0.6188 - val_loss: 0.1118 - val_accuracy: 0.9659\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1167 - accuracy: 0.9637 - val_loss: 0.0657 - val_accuracy: 0.9783\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0784 - accuracy: 0.9744 - val_loss: 0.0563 - val_accuracy: 0.9813\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0603 - accuracy: 0.9806 - val_loss: 0.0432 - val_accuracy: 0.9866\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0519 - accuracy: 0.9842 - val_loss: 0.0398 - val_accuracy: 0.9875\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0636 - accuracy: 0.9817 - val_loss: 0.1323 - val_accuracy: 0.9587\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0981 - accuracy: 0.9693 - val_loss: 0.0653 - val_accuracy: 0.9804\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0576 - accuracy: 0.9815 - val_loss: 0.0417 - val_accuracy: 0.9862\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0408 - accuracy: 0.9873 - val_loss: 0.0379 - val_accuracy: 0.9876\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0351 - accuracy: 0.9888 - val_loss: 0.0374 - val_accuracy: 0.9877\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0342 - accuracy: 0.9895 - val_loss: 0.0350 - val_accuracy: 0.9890\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0300 - accuracy: 0.9906 - val_loss: 0.0342 - val_accuracy: 0.9882\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0240 - accuracy: 0.9926 - val_loss: 0.0323 - val_accuracy: 0.9888\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0224 - accuracy: 0.9925 - val_loss: 0.0337 - val_accuracy: 0.9899\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0216 - accuracy: 0.9932 - val_loss: 0.0458 - val_accuracy: 0.9838\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0204 - accuracy: 0.9933 - val_loss: 0.0304 - val_accuracy: 0.9905\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0165 - accuracy: 0.9950 - val_loss: 0.0347 - val_accuracy: 0.9890\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0158 - accuracy: 0.9955 - val_loss: 0.0309 - val_accuracy: 0.9909\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0144 - accuracy: 0.9956 - val_loss: 0.0333 - val_accuracy: 0.9899\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0146 - accuracy: 0.9957 - val_loss: 0.0332 - val_accuracy: 0.9899\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0126 - accuracy: 0.9960 - val_loss: 0.0321 - val_accuracy: 0.9910\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0136 - accuracy: 0.9955 - val_loss: 0.0331 - val_accuracy: 0.9894\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0105 - accuracy: 0.9972 - val_loss: 0.0341 - val_accuracy: 0.9895\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0098 - accuracy: 0.9970 - val_loss: 0.0340 - val_accuracy: 0.9897\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0088 - accuracy: 0.9972 - val_loss: 0.0320 - val_accuracy: 0.9909\n",
      "Starting run  23\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.1805 - accuracy: 0.6087 - val_loss: 0.1227 - val_accuracy: 0.9616\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1134 - accuracy: 0.9645 - val_loss: 0.0686 - val_accuracy: 0.9780\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0728 - accuracy: 0.9768 - val_loss: 0.0539 - val_accuracy: 0.9832\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0559 - accuracy: 0.9828 - val_loss: 0.0510 - val_accuracy: 0.9835\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0509 - accuracy: 0.9839 - val_loss: 0.0419 - val_accuracy: 0.9860\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0447 - accuracy: 0.9862 - val_loss: 0.0819 - val_accuracy: 0.9739\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0399 - accuracy: 0.9869 - val_loss: 0.0341 - val_accuracy: 0.9887\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0317 - accuracy: 0.9896 - val_loss: 0.0345 - val_accuracy: 0.9885\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0316 - accuracy: 0.9909 - val_loss: 0.0347 - val_accuracy: 0.9880\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0293 - accuracy: 0.9904 - val_loss: 0.0317 - val_accuracy: 0.9897\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0233 - accuracy: 0.9932 - val_loss: 0.0342 - val_accuracy: 0.9891\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0219 - accuracy: 0.9933 - val_loss: 0.0378 - val_accuracy: 0.9879\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0221 - accuracy: 0.9932 - val_loss: 0.0305 - val_accuracy: 0.9897\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0200 - accuracy: 0.9935 - val_loss: 0.0318 - val_accuracy: 0.9893\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0199 - accuracy: 0.9942 - val_loss: 0.0297 - val_accuracy: 0.9897\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0160 - accuracy: 0.9953 - val_loss: 0.0302 - val_accuracy: 0.9897\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0152 - accuracy: 0.9951 - val_loss: 0.0314 - val_accuracy: 0.9901\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0160 - accuracy: 0.9950 - val_loss: 0.0302 - val_accuracy: 0.9902\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0113 - accuracy: 0.9964 - val_loss: 0.0295 - val_accuracy: 0.9906\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0108 - accuracy: 0.9969 - val_loss: 0.0320 - val_accuracy: 0.9896\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0099 - accuracy: 0.9972 - val_loss: 0.0338 - val_accuracy: 0.9895\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0106 - accuracy: 0.9968 - val_loss: 0.0370 - val_accuracy: 0.9886\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0113 - accuracy: 0.9972 - val_loss: 0.0313 - val_accuracy: 0.9910\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0107 - accuracy: 0.9969 - val_loss: 0.0318 - val_accuracy: 0.9902\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0085 - accuracy: 0.9976 - val_loss: 0.0302 - val_accuracy: 0.9909\n",
      "Starting run  24\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 1.2412 - accuracy: 0.5874 - val_loss: 0.1139 - val_accuracy: 0.9646\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.1152 - accuracy: 0.9639 - val_loss: 0.0697 - val_accuracy: 0.9779\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0814 - accuracy: 0.9738 - val_loss: 0.0555 - val_accuracy: 0.9824\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0607 - accuracy: 0.9805 - val_loss: 0.0444 - val_accuracy: 0.9859\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0536 - accuracy: 0.9829 - val_loss: 0.0421 - val_accuracy: 0.9864\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0417 - accuracy: 0.9870 - val_loss: 0.0335 - val_accuracy: 0.9893\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0372 - accuracy: 0.9881 - val_loss: 0.0356 - val_accuracy: 0.9888\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0349 - accuracy: 0.9897 - val_loss: 0.0319 - val_accuracy: 0.9904\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0326 - accuracy: 0.9893 - val_loss: 0.0322 - val_accuracy: 0.9904\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0266 - accuracy: 0.9908 - val_loss: 0.0313 - val_accuracy: 0.9904\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0250 - accuracy: 0.9920 - val_loss: 0.0327 - val_accuracy: 0.9895\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0237 - accuracy: 0.9921 - val_loss: 0.0318 - val_accuracy: 0.9895\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0235 - accuracy: 0.9933 - val_loss: 0.0294 - val_accuracy: 0.9916\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0201 - accuracy: 0.9942 - val_loss: 0.0291 - val_accuracy: 0.9915\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0208 - accuracy: 0.9938 - val_loss: 0.0359 - val_accuracy: 0.9882\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0172 - accuracy: 0.9944 - val_loss: 0.0316 - val_accuracy: 0.9915\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0155 - accuracy: 0.9954 - val_loss: 0.0292 - val_accuracy: 0.9916\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0134 - accuracy: 0.9961 - val_loss: 0.0318 - val_accuracy: 0.9904\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0129 - accuracy: 0.9960 - val_loss: 0.0405 - val_accuracy: 0.9885\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0137 - accuracy: 0.9958 - val_loss: 0.0291 - val_accuracy: 0.9910\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0114 - accuracy: 0.9963 - val_loss: 0.0269 - val_accuracy: 0.9920\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0101 - accuracy: 0.9969 - val_loss: 0.0333 - val_accuracy: 0.9893\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0101 - accuracy: 0.9971 - val_loss: 0.0305 - val_accuracy: 0.9909\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0087 - accuracy: 0.9978 - val_loss: 0.0302 - val_accuracy: 0.9911\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 1s 3ms/step - loss: 0.0082 - accuracy: 0.9978 - val_loss: 0.0345 - val_accuracy: 0.9895\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(0.7, 1.0)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 351,
       "width": 530
      },
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\n",
    "avg_accuracy_list = np.zeros(epochs)\n",
    "for i in range(num_runs):\n",
    "    print('Starting run ', i)\n",
    "    MyModel = get_MNIST_model()\n",
    "    optimizer = tf.keras.optimizers.SGD(learning_rate=lr)\n",
    "    loss = tf.keras.losses.CategoricalCrossentropy(from_logits=True)\n",
    "\n",
    "    # Compile MyModel with Keras\n",
    "    MyModel.compile(optimizer=optimizer, loss=loss, metrics=['accuracy'])\n",
    "\n",
    "    # Train MyModel with Keras\n",
    "    start_time = time.time()\n",
    "    training_metrics=MyModel.fit(train_data, train_labels,\n",
    "            epochs=epochs,\n",
    "            validation_data=(test_data, test_labels),\n",
    "            batch_size=batch_size).history\n",
    "\n",
    "    total_time = time.time()-start_time\n",
    "    accuracy_list = training_metrics['val_accuracy']\n",
    "    epochtime_list = epochs*[total_time/epochs]\n",
    "    avg_accuracy_list +=np.array(accuracy_list)/num_runs\n",
    "\n",
    "    #print(epochtime_list,accuracy_list)\n",
    "    tf.keras.backend.clear_session()\n",
    "\n",
    "record_dict = {'accuracy':avg_accuracy_list}\n",
    "with open(f'pickles/nonDP_MNIST{batch_size}_approx.pickle','wb') as handle:\n",
    "    pickle.dump(record_dict,handle)\n",
    "    \n",
    "plt.plot(avg_accuracy_list)\n",
    "plt.ylim(0.7,1)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# DPVanilla"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Tensorflow implementation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting run  0\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 50s 201ms/step - loss: 1.9458 - accuracy: 0.3530 - val_loss: 0.7858 - val_accuracy: 0.7490\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.6866 - accuracy: 0.7857 - val_loss: 0.4962 - val_accuracy: 0.8562\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4952 - accuracy: 0.8608 - val_loss: 0.4512 - val_accuracy: 0.8859\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4751 - accuracy: 0.8832 - val_loss: 0.4373 - val_accuracy: 0.9010\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4411 - accuracy: 0.8971 - val_loss: 0.4198 - val_accuracy: 0.9093\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4353 - accuracy: 0.9025 - val_loss: 0.4129 - val_accuracy: 0.9150\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.4199 - accuracy: 0.9106 - val_loss: 0.3926 - val_accuracy: 0.9226\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4023 - accuracy: 0.9147 - val_loss: 0.3755 - val_accuracy: 0.9266\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4074 - accuracy: 0.9161 - val_loss: 0.3667 - val_accuracy: 0.9293\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3969 - accuracy: 0.9228 - val_loss: 0.3571 - val_accuracy: 0.9318\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3984 - accuracy: 0.9243 - val_loss: 0.3522 - val_accuracy: 0.9354\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3804 - accuracy: 0.9269 - val_loss: 0.3401 - val_accuracy: 0.9384\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3559 - accuracy: 0.9308 - val_loss: 0.3221 - val_accuracy: 0.9401\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3532 - accuracy: 0.9318 - val_loss: 0.3220 - val_accuracy: 0.9422\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3526 - accuracy: 0.9334 - val_loss: 0.3115 - val_accuracy: 0.9445\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3258 - accuracy: 0.9369 - val_loss: 0.3062 - val_accuracy: 0.9447\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3237 - accuracy: 0.9375 - val_loss: 0.2874 - val_accuracy: 0.9469\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2999 - accuracy: 0.9421 - val_loss: 0.2851 - val_accuracy: 0.9480\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3005 - accuracy: 0.9441 - val_loss: 0.2771 - val_accuracy: 0.9494\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3019 - accuracy: 0.9439 - val_loss: 0.2783 - val_accuracy: 0.9490\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2899 - accuracy: 0.9454 - val_loss: 0.2679 - val_accuracy: 0.9529\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2902 - accuracy: 0.9468 - val_loss: 0.2634 - val_accuracy: 0.9530\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2919 - accuracy: 0.9475 - val_loss: 0.2540 - val_accuracy: 0.9542\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2659 - accuracy: 0.9490 - val_loss: 0.2633 - val_accuracy: 0.9525\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2638 - accuracy: 0.9511 - val_loss: 0.2427 - val_accuracy: 0.9549\n",
      "\n",
      "\n",
      "\n",
      "Starting run  1\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 50s 202ms/step - loss: 1.9052 - accuracy: 0.4102 - val_loss: 0.7759 - val_accuracy: 0.7483\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.7169 - accuracy: 0.7667 - val_loss: 0.5629 - val_accuracy: 0.8299\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.5571 - accuracy: 0.8357 - val_loss: 0.4832 - val_accuracy: 0.8715\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 49s 202ms/step - loss: 0.5164 - accuracy: 0.8644 - val_loss: 0.4588 - val_accuracy: 0.8870\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.4832 - accuracy: 0.8851 - val_loss: 0.4233 - val_accuracy: 0.9008\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.4567 - accuracy: 0.8983 - val_loss: 0.3934 - val_accuracy: 0.9116\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 49s 203ms/step - loss: 0.4316 - accuracy: 0.9061 - val_loss: 0.3722 - val_accuracy: 0.9185\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 49s 202ms/step - loss: 0.4137 - accuracy: 0.9124 - val_loss: 0.3566 - val_accuracy: 0.9248\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 202ms/step - loss: 0.4013 - accuracy: 0.9165 - val_loss: 0.3383 - val_accuracy: 0.9288\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 202ms/step - loss: 0.3857 - accuracy: 0.9227 - val_loss: 0.3325 - val_accuracy: 0.9312\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3757 - accuracy: 0.9252 - val_loss: 0.3310 - val_accuracy: 0.9335\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3855 - accuracy: 0.9271 - val_loss: 0.3193 - val_accuracy: 0.9358\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3604 - accuracy: 0.9308 - val_loss: 0.3069 - val_accuracy: 0.9383\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3537 - accuracy: 0.9351 - val_loss: 0.3021 - val_accuracy: 0.9398\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 202ms/step - loss: 0.3485 - accuracy: 0.9359 - val_loss: 0.2934 - val_accuracy: 0.9419\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3363 - accuracy: 0.9379 - val_loss: 0.2864 - val_accuracy: 0.9461\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3328 - accuracy: 0.9394 - val_loss: 0.2817 - val_accuracy: 0.9453\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3089 - accuracy: 0.9423 - val_loss: 0.2743 - val_accuracy: 0.9470\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 202ms/step - loss: 0.3055 - accuracy: 0.9435 - val_loss: 0.2709 - val_accuracy: 0.9482\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3026 - accuracy: 0.9447 - val_loss: 0.2600 - val_accuracy: 0.9505\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.2990 - accuracy: 0.9462 - val_loss: 0.2613 - val_accuracy: 0.9511\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.2935 - accuracy: 0.9455 - val_loss: 0.2570 - val_accuracy: 0.9510\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.2842 - accuracy: 0.9480 - val_loss: 0.2461 - val_accuracy: 0.9530\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.2837 - accuracy: 0.9494 - val_loss: 0.2488 - val_accuracy: 0.9525\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.2837 - accuracy: 0.9498 - val_loss: 0.2380 - val_accuracy: 0.9536\n",
      "\n",
      "\n",
      "\n",
      "Starting run  2\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 50s 199ms/step - loss: 1.8991 - accuracy: 0.4163 - val_loss: 0.7070 - val_accuracy: 0.7805\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.6485 - accuracy: 0.7978 - val_loss: 0.5413 - val_accuracy: 0.8511\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 49s 206ms/step - loss: 0.5336 - accuracy: 0.8532 - val_loss: 0.5024 - val_accuracy: 0.8749\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.4998 - accuracy: 0.8774 - val_loss: 0.4768 - val_accuracy: 0.8905\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4777 - accuracy: 0.8898 - val_loss: 0.4490 - val_accuracy: 0.9024\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4667 - accuracy: 0.9004 - val_loss: 0.4350 - val_accuracy: 0.9077\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.4464 - accuracy: 0.9065 - val_loss: 0.4145 - val_accuracy: 0.9147\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4332 - accuracy: 0.9106 - val_loss: 0.3914 - val_accuracy: 0.9215\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4209 - accuracy: 0.9150 - val_loss: 0.3738 - val_accuracy: 0.9261\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3833 - accuracy: 0.9240 - val_loss: 0.3646 - val_accuracy: 0.9282\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3873 - accuracy: 0.9241 - val_loss: 0.3447 - val_accuracy: 0.9320\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3610 - accuracy: 0.9289 - val_loss: 0.3298 - val_accuracy: 0.9348\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3345 - accuracy: 0.9342 - val_loss: 0.3159 - val_accuracy: 0.9381\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3267 - accuracy: 0.9346 - val_loss: 0.3006 - val_accuracy: 0.9417\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3109 - accuracy: 0.9406 - val_loss: 0.2992 - val_accuracy: 0.9420\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3116 - accuracy: 0.9391 - val_loss: 0.2898 - val_accuracy: 0.9440\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2965 - accuracy: 0.9426 - val_loss: 0.2761 - val_accuracy: 0.9468\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2942 - accuracy: 0.9450 - val_loss: 0.2672 - val_accuracy: 0.9467\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2773 - accuracy: 0.9452 - val_loss: 0.2646 - val_accuracy: 0.9478\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2844 - accuracy: 0.9454 - val_loss: 0.2629 - val_accuracy: 0.9487\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2756 - accuracy: 0.9477 - val_loss: 0.2585 - val_accuracy: 0.9498\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2808 - accuracy: 0.9459 - val_loss: 0.2537 - val_accuracy: 0.9503\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2621 - accuracy: 0.9488 - val_loss: 0.2463 - val_accuracy: 0.9531\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2719 - accuracy: 0.9493 - val_loss: 0.2371 - val_accuracy: 0.9527\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2591 - accuracy: 0.9506 - val_loss: 0.2333 - val_accuracy: 0.9534\n",
      "\n",
      "\n",
      "\n",
      "Starting run  3\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 198ms/step - loss: 1.9408 - accuracy: 0.3408 - val_loss: 0.8357 - val_accuracy: 0.7369\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.7855 - accuracy: 0.7399 - val_loss: 0.5528 - val_accuracy: 0.8255\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5604 - accuracy: 0.8296 - val_loss: 0.4449 - val_accuracy: 0.8778\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4990 - accuracy: 0.8692 - val_loss: 0.4291 - val_accuracy: 0.8917\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4797 - accuracy: 0.8845 - val_loss: 0.4193 - val_accuracy: 0.9037\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4509 - accuracy: 0.8953 - val_loss: 0.4067 - val_accuracy: 0.9119\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4454 - accuracy: 0.9022 - val_loss: 0.3932 - val_accuracy: 0.9168\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4227 - accuracy: 0.9091 - val_loss: 0.3822 - val_accuracy: 0.9205\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4123 - accuracy: 0.9149 - val_loss: 0.3821 - val_accuracy: 0.9238\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4004 - accuracy: 0.9180 - val_loss: 0.3578 - val_accuracy: 0.9273\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3734 - accuracy: 0.9232 - val_loss: 0.3451 - val_accuracy: 0.9306\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3675 - accuracy: 0.9257 - val_loss: 0.3374 - val_accuracy: 0.9331\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3403 - accuracy: 0.9311 - val_loss: 0.3173 - val_accuracy: 0.9365\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3475 - accuracy: 0.9316 - val_loss: 0.3134 - val_accuracy: 0.9381\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.3340 - accuracy: 0.9343 - val_loss: 0.3029 - val_accuracy: 0.9405\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3293 - accuracy: 0.9342 - val_loss: 0.2893 - val_accuracy: 0.9439\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3036 - accuracy: 0.9396 - val_loss: 0.2841 - val_accuracy: 0.9451\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3100 - accuracy: 0.9393 - val_loss: 0.2840 - val_accuracy: 0.9456\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2999 - accuracy: 0.9413 - val_loss: 0.2756 - val_accuracy: 0.9463\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2856 - accuracy: 0.9430 - val_loss: 0.2703 - val_accuracy: 0.9492\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2900 - accuracy: 0.9436 - val_loss: 0.2572 - val_accuracy: 0.9504\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2786 - accuracy: 0.9478 - val_loss: 0.2521 - val_accuracy: 0.9520\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2822 - accuracy: 0.9474 - val_loss: 0.2495 - val_accuracy: 0.9534\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.2682 - accuracy: 0.9501 - val_loss: 0.2463 - val_accuracy: 0.9533\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2772 - accuracy: 0.9487 - val_loss: 0.2477 - val_accuracy: 0.9535\n",
      "\n",
      "\n",
      "\n",
      "Starting run  4\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 1.9793 - accuracy: 0.3758 - val_loss: 0.8079 - val_accuracy: 0.7471\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.7138 - accuracy: 0.7729 - val_loss: 0.5027 - val_accuracy: 0.8562\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5295 - accuracy: 0.8442 - val_loss: 0.4704 - val_accuracy: 0.8832\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4932 - accuracy: 0.8771 - val_loss: 0.4447 - val_accuracy: 0.8986\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.4565 - accuracy: 0.8956 - val_loss: 0.4208 - val_accuracy: 0.9101\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4330 - accuracy: 0.9062 - val_loss: 0.4108 - val_accuracy: 0.9172\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4229 - accuracy: 0.9112 - val_loss: 0.3968 - val_accuracy: 0.9226\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4180 - accuracy: 0.9163 - val_loss: 0.3761 - val_accuracy: 0.9274\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3995 - accuracy: 0.9200 - val_loss: 0.3735 - val_accuracy: 0.9293\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3994 - accuracy: 0.9226 - val_loss: 0.3663 - val_accuracy: 0.9332\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3965 - accuracy: 0.9231 - val_loss: 0.3535 - val_accuracy: 0.9361\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3739 - accuracy: 0.9289 - val_loss: 0.3322 - val_accuracy: 0.9396\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3621 - accuracy: 0.9305 - val_loss: 0.3287 - val_accuracy: 0.9403\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3531 - accuracy: 0.9329 - val_loss: 0.3244 - val_accuracy: 0.9422\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3560 - accuracy: 0.9334 - val_loss: 0.3106 - val_accuracy: 0.9430\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3385 - accuracy: 0.9367 - val_loss: 0.3058 - val_accuracy: 0.9443\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3284 - accuracy: 0.9391 - val_loss: 0.3078 - val_accuracy: 0.9441\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3183 - accuracy: 0.9388 - val_loss: 0.2929 - val_accuracy: 0.9468\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3245 - accuracy: 0.9394 - val_loss: 0.2870 - val_accuracy: 0.9479\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3080 - accuracy: 0.9424 - val_loss: 0.2734 - val_accuracy: 0.9491\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3193 - accuracy: 0.9422 - val_loss: 0.2723 - val_accuracy: 0.9491\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3091 - accuracy: 0.9437 - val_loss: 0.2623 - val_accuracy: 0.9508\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2939 - accuracy: 0.9453 - val_loss: 0.2528 - val_accuracy: 0.9516\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2954 - accuracy: 0.9467 - val_loss: 0.2577 - val_accuracy: 0.9516\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2831 - accuracy: 0.9478 - val_loss: 0.2470 - val_accuracy: 0.9524\n",
      "\n",
      "\n",
      "\n",
      "Starting run  5\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 50s 199ms/step - loss: 1.9793 - accuracy: 0.3712 - val_loss: 0.8800 - val_accuracy: 0.7251\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.8143 - accuracy: 0.7437 - val_loss: 0.5978 - val_accuracy: 0.8221\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5971 - accuracy: 0.8286 - val_loss: 0.5201 - val_accuracy: 0.8614\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.5415 - accuracy: 0.8630 - val_loss: 0.4620 - val_accuracy: 0.8843\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4845 - accuracy: 0.8858 - val_loss: 0.4291 - val_accuracy: 0.9002\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4516 - accuracy: 0.8968 - val_loss: 0.4158 - val_accuracy: 0.9071\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.4449 - accuracy: 0.9013 - val_loss: 0.4002 - val_accuracy: 0.9112\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4267 - accuracy: 0.9093 - val_loss: 0.3771 - val_accuracy: 0.9163\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4121 - accuracy: 0.9148 - val_loss: 0.3654 - val_accuracy: 0.9207\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4042 - accuracy: 0.9171 - val_loss: 0.3473 - val_accuracy: 0.9247\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3786 - accuracy: 0.9223 - val_loss: 0.3395 - val_accuracy: 0.9273\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3884 - accuracy: 0.9233 - val_loss: 0.3277 - val_accuracy: 0.9313\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3675 - accuracy: 0.9266 - val_loss: 0.3189 - val_accuracy: 0.9328\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3363 - accuracy: 0.9322 - val_loss: 0.3062 - val_accuracy: 0.9356\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3448 - accuracy: 0.9308 - val_loss: 0.3010 - val_accuracy: 0.9377\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3419 - accuracy: 0.9337 - val_loss: 0.2915 - val_accuracy: 0.9380\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3266 - accuracy: 0.9342 - val_loss: 0.2886 - val_accuracy: 0.9386\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3207 - accuracy: 0.9376 - val_loss: 0.2796 - val_accuracy: 0.9410\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3194 - accuracy: 0.9380 - val_loss: 0.2763 - val_accuracy: 0.9435\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3160 - accuracy: 0.9397 - val_loss: 0.2762 - val_accuracy: 0.9435\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3167 - accuracy: 0.9381 - val_loss: 0.2635 - val_accuracy: 0.9456\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3187 - accuracy: 0.9405 - val_loss: 0.2639 - val_accuracy: 0.9457\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3068 - accuracy: 0.9413 - val_loss: 0.2520 - val_accuracy: 0.9475\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2958 - accuracy: 0.9437 - val_loss: 0.2513 - val_accuracy: 0.9500\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3004 - accuracy: 0.9445 - val_loss: 0.2446 - val_accuracy: 0.9509\n",
      "\n",
      "\n",
      "\n",
      "Starting run  6\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 1.9647 - accuracy: 0.3421 - val_loss: 0.6843 - val_accuracy: 0.7942\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.6123 - accuracy: 0.8113 - val_loss: 0.4312 - val_accuracy: 0.8720\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4458 - accuracy: 0.8737 - val_loss: 0.3954 - val_accuracy: 0.8955\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4153 - accuracy: 0.8921 - val_loss: 0.3785 - val_accuracy: 0.9088\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4165 - accuracy: 0.9021 - val_loss: 0.3819 - val_accuracy: 0.9131\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4020 - accuracy: 0.9094 - val_loss: 0.3721 - val_accuracy: 0.9199\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3851 - accuracy: 0.9165 - val_loss: 0.3522 - val_accuracy: 0.9250\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3719 - accuracy: 0.9195 - val_loss: 0.3389 - val_accuracy: 0.9269\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3573 - accuracy: 0.9237 - val_loss: 0.3280 - val_accuracy: 0.9312\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3547 - accuracy: 0.9270 - val_loss: 0.3306 - val_accuracy: 0.9335\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3577 - accuracy: 0.9270 - val_loss: 0.3153 - val_accuracy: 0.9349\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3464 - accuracy: 0.9303 - val_loss: 0.3133 - val_accuracy: 0.9368\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3387 - accuracy: 0.9339 - val_loss: 0.3054 - val_accuracy: 0.9388\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3435 - accuracy: 0.9332 - val_loss: 0.2961 - val_accuracy: 0.9399\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3263 - accuracy: 0.9352 - val_loss: 0.2929 - val_accuracy: 0.9416\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3177 - accuracy: 0.9385 - val_loss: 0.2913 - val_accuracy: 0.9421\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3119 - accuracy: 0.9393 - val_loss: 0.2793 - val_accuracy: 0.9444\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2971 - accuracy: 0.9409 - val_loss: 0.2699 - val_accuracy: 0.9451\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3035 - accuracy: 0.9397 - val_loss: 0.2659 - val_accuracy: 0.9467\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2948 - accuracy: 0.9432 - val_loss: 0.2590 - val_accuracy: 0.9472\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2926 - accuracy: 0.9438 - val_loss: 0.2529 - val_accuracy: 0.9494\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2842 - accuracy: 0.9456 - val_loss: 0.2573 - val_accuracy: 0.9495\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2777 - accuracy: 0.9460 - val_loss: 0.2494 - val_accuracy: 0.9516\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2580 - accuracy: 0.9501 - val_loss: 0.2455 - val_accuracy: 0.9523\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.2627 - accuracy: 0.9489 - val_loss: 0.2434 - val_accuracy: 0.9514\n",
      "\n",
      "\n",
      "\n",
      "Starting run  7\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 1.8430 - accuracy: 0.4521 - val_loss: 0.7203 - val_accuracy: 0.7574\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.6415 - accuracy: 0.7892 - val_loss: 0.4758 - val_accuracy: 0.8539\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.4653 - accuracy: 0.8612 - val_loss: 0.4016 - val_accuracy: 0.8933\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4227 - accuracy: 0.8901 - val_loss: 0.3782 - val_accuracy: 0.9080\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3918 - accuracy: 0.9025 - val_loss: 0.3667 - val_accuracy: 0.9149\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3789 - accuracy: 0.9105 - val_loss: 0.3525 - val_accuracy: 0.9210\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.3727 - accuracy: 0.9169 - val_loss: 0.3374 - val_accuracy: 0.9265\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3678 - accuracy: 0.9208 - val_loss: 0.3263 - val_accuracy: 0.9290\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3399 - accuracy: 0.9266 - val_loss: 0.3210 - val_accuracy: 0.9331\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3376 - accuracy: 0.9284 - val_loss: 0.3094 - val_accuracy: 0.9360\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3257 - accuracy: 0.9307 - val_loss: 0.3013 - val_accuracy: 0.9377\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3159 - accuracy: 0.9344 - val_loss: 0.2908 - val_accuracy: 0.9397\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3222 - accuracy: 0.9359 - val_loss: 0.2868 - val_accuracy: 0.9410\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3218 - accuracy: 0.9371 - val_loss: 0.2771 - val_accuracy: 0.9445\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2861 - accuracy: 0.9424 - val_loss: 0.2615 - val_accuracy: 0.9463\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2768 - accuracy: 0.9431 - val_loss: 0.2525 - val_accuracy: 0.9471\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2897 - accuracy: 0.9421 - val_loss: 0.2499 - val_accuracy: 0.9483\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2851 - accuracy: 0.9441 - val_loss: 0.2408 - val_accuracy: 0.9507\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2654 - accuracy: 0.9470 - val_loss: 0.2425 - val_accuracy: 0.9506\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2685 - accuracy: 0.9465 - val_loss: 0.2348 - val_accuracy: 0.9528\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2557 - accuracy: 0.9505 - val_loss: 0.2390 - val_accuracy: 0.9538\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2662 - accuracy: 0.9506 - val_loss: 0.2273 - val_accuracy: 0.9536\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2604 - accuracy: 0.9510 - val_loss: 0.2325 - val_accuracy: 0.9544\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2628 - accuracy: 0.9498 - val_loss: 0.2257 - val_accuracy: 0.9553\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2589 - accuracy: 0.9521 - val_loss: 0.2248 - val_accuracy: 0.9547\n",
      "\n",
      "\n",
      "\n",
      "Starting run  8\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 1.8940 - accuracy: 0.4103 - val_loss: 0.6305 - val_accuracy: 0.8072\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5686 - accuracy: 0.8271 - val_loss: 0.4408 - val_accuracy: 0.8828\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4606 - accuracy: 0.8764 - val_loss: 0.4291 - val_accuracy: 0.8995\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.4520 - accuracy: 0.8929 - val_loss: 0.4255 - val_accuracy: 0.9077\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4372 - accuracy: 0.9001 - val_loss: 0.4045 - val_accuracy: 0.9153\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4259 - accuracy: 0.9072 - val_loss: 0.3991 - val_accuracy: 0.9179\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4127 - accuracy: 0.9151 - val_loss: 0.3709 - val_accuracy: 0.9243\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3894 - accuracy: 0.9192 - val_loss: 0.3691 - val_accuracy: 0.9261\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3852 - accuracy: 0.9213 - val_loss: 0.3551 - val_accuracy: 0.9298\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3547 - accuracy: 0.9293 - val_loss: 0.3379 - val_accuracy: 0.9315\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3616 - accuracy: 0.9283 - val_loss: 0.3317 - val_accuracy: 0.9347\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3496 - accuracy: 0.9306 - val_loss: 0.3200 - val_accuracy: 0.9382\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3469 - accuracy: 0.9326 - val_loss: 0.3074 - val_accuracy: 0.9386\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3319 - accuracy: 0.9351 - val_loss: 0.2965 - val_accuracy: 0.9402\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3132 - accuracy: 0.9376 - val_loss: 0.3001 - val_accuracy: 0.9408\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3392 - accuracy: 0.9359 - val_loss: 0.2921 - val_accuracy: 0.9431\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3213 - accuracy: 0.9388 - val_loss: 0.2743 - val_accuracy: 0.9471\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3083 - accuracy: 0.9402 - val_loss: 0.2782 - val_accuracy: 0.9464\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2995 - accuracy: 0.9437 - val_loss: 0.2602 - val_accuracy: 0.9494\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2844 - accuracy: 0.9433 - val_loss: 0.2576 - val_accuracy: 0.9501\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2804 - accuracy: 0.9446 - val_loss: 0.2534 - val_accuracy: 0.9509\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2740 - accuracy: 0.9453 - val_loss: 0.2501 - val_accuracy: 0.9509\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2778 - accuracy: 0.9467 - val_loss: 0.2419 - val_accuracy: 0.9528\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2721 - accuracy: 0.9490 - val_loss: 0.2376 - val_accuracy: 0.9529\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2632 - accuracy: 0.9497 - val_loss: 0.2361 - val_accuracy: 0.9530\n",
      "\n",
      "\n",
      "\n",
      "Starting run  9\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 1.9936 - accuracy: 0.3880 - val_loss: 0.8418 - val_accuracy: 0.7316\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.7346 - accuracy: 0.7660 - val_loss: 0.5226 - val_accuracy: 0.8391\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5092 - accuracy: 0.8464 - val_loss: 0.4382 - val_accuracy: 0.8804\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4543 - accuracy: 0.8782 - val_loss: 0.4142 - val_accuracy: 0.8937\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4491 - accuracy: 0.8898 - val_loss: 0.3969 - val_accuracy: 0.9057\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4327 - accuracy: 0.8979 - val_loss: 0.3819 - val_accuracy: 0.9109\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3999 - accuracy: 0.9071 - val_loss: 0.3656 - val_accuracy: 0.9151\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3905 - accuracy: 0.9135 - val_loss: 0.3533 - val_accuracy: 0.9196\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3866 - accuracy: 0.9138 - val_loss: 0.3518 - val_accuracy: 0.9221\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3693 - accuracy: 0.9212 - val_loss: 0.3289 - val_accuracy: 0.9265\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3553 - accuracy: 0.9232 - val_loss: 0.3141 - val_accuracy: 0.9327\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3372 - accuracy: 0.9282 - val_loss: 0.3097 - val_accuracy: 0.9331\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3284 - accuracy: 0.9301 - val_loss: 0.3055 - val_accuracy: 0.9351\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3281 - accuracy: 0.9326 - val_loss: 0.3004 - val_accuracy: 0.9395\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3157 - accuracy: 0.9346 - val_loss: 0.2925 - val_accuracy: 0.9427\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3115 - accuracy: 0.9359 - val_loss: 0.2859 - val_accuracy: 0.9438\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.3007 - accuracy: 0.9374 - val_loss: 0.2784 - val_accuracy: 0.9444\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3024 - accuracy: 0.9389 - val_loss: 0.2761 - val_accuracy: 0.9452\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2892 - accuracy: 0.9399 - val_loss: 0.2768 - val_accuracy: 0.9460\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3057 - accuracy: 0.9406 - val_loss: 0.2686 - val_accuracy: 0.9475\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.2840 - accuracy: 0.9424 - val_loss: 0.2651 - val_accuracy: 0.9503\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2904 - accuracy: 0.9450 - val_loss: 0.2659 - val_accuracy: 0.9504\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2886 - accuracy: 0.9454 - val_loss: 0.2617 - val_accuracy: 0.9524\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2826 - accuracy: 0.9458 - val_loss: 0.2603 - val_accuracy: 0.9527\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2784 - accuracy: 0.9470 - val_loss: 0.2563 - val_accuracy: 0.9530\n",
      "\n",
      "\n",
      "\n",
      "Starting run  10\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 1.9702 - accuracy: 0.3176 - val_loss: 0.8196 - val_accuracy: 0.7260\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.7635 - accuracy: 0.7459 - val_loss: 0.5121 - val_accuracy: 0.8402\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5435 - accuracy: 0.8307 - val_loss: 0.4648 - val_accuracy: 0.8679\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4890 - accuracy: 0.8653 - val_loss: 0.4496 - val_accuracy: 0.8825\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4608 - accuracy: 0.8836 - val_loss: 0.4515 - val_accuracy: 0.8911\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4488 - accuracy: 0.8906 - val_loss: 0.4371 - val_accuracy: 0.8974\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.4501 - accuracy: 0.8969 - val_loss: 0.4295 - val_accuracy: 0.9041\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4395 - accuracy: 0.9041 - val_loss: 0.4208 - val_accuracy: 0.9116\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4306 - accuracy: 0.9074 - val_loss: 0.4020 - val_accuracy: 0.9155\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4170 - accuracy: 0.9134 - val_loss: 0.3893 - val_accuracy: 0.9194\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4009 - accuracy: 0.9192 - val_loss: 0.3687 - val_accuracy: 0.9265\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3866 - accuracy: 0.9213 - val_loss: 0.3548 - val_accuracy: 0.9282\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3812 - accuracy: 0.9244 - val_loss: 0.3422 - val_accuracy: 0.9295\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3696 - accuracy: 0.9264 - val_loss: 0.3394 - val_accuracy: 0.9312\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3530 - accuracy: 0.9292 - val_loss: 0.3437 - val_accuracy: 0.9334\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3634 - accuracy: 0.9287 - val_loss: 0.3191 - val_accuracy: 0.9389\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3501 - accuracy: 0.9325 - val_loss: 0.3278 - val_accuracy: 0.9389\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3358 - accuracy: 0.9359 - val_loss: 0.3153 - val_accuracy: 0.9422\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3382 - accuracy: 0.9345 - val_loss: 0.3110 - val_accuracy: 0.9419\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3275 - accuracy: 0.9375 - val_loss: 0.2968 - val_accuracy: 0.9440\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3190 - accuracy: 0.9380 - val_loss: 0.2833 - val_accuracy: 0.9469\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3116 - accuracy: 0.9412 - val_loss: 0.2823 - val_accuracy: 0.9474\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3007 - accuracy: 0.9431 - val_loss: 0.2732 - val_accuracy: 0.9486\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2820 - accuracy: 0.9451 - val_loss: 0.2675 - val_accuracy: 0.9496\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2942 - accuracy: 0.9437 - val_loss: 0.2591 - val_accuracy: 0.9503\n",
      "\n",
      "\n",
      "\n",
      "Starting run  11\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 50s 201ms/step - loss: 1.9654 - accuracy: 0.3786 - val_loss: 0.7785 - val_accuracy: 0.7583\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.7014 - accuracy: 0.7803 - val_loss: 0.4847 - val_accuracy: 0.8543\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4987 - accuracy: 0.8536 - val_loss: 0.4291 - val_accuracy: 0.8829\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4487 - accuracy: 0.8786 - val_loss: 0.4043 - val_accuracy: 0.8985\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.4231 - accuracy: 0.8937 - val_loss: 0.3878 - val_accuracy: 0.9088\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4060 - accuracy: 0.9018 - val_loss: 0.3694 - val_accuracy: 0.9154\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3987 - accuracy: 0.9069 - val_loss: 0.3656 - val_accuracy: 0.9178\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3836 - accuracy: 0.9139 - val_loss: 0.3497 - val_accuracy: 0.9229\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3797 - accuracy: 0.9169 - val_loss: 0.3426 - val_accuracy: 0.9259\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3671 - accuracy: 0.9204 - val_loss: 0.3381 - val_accuracy: 0.9295\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3627 - accuracy: 0.9219 - val_loss: 0.3221 - val_accuracy: 0.9314\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3484 - accuracy: 0.9259 - val_loss: 0.3167 - val_accuracy: 0.9349\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3386 - accuracy: 0.9274 - val_loss: 0.3078 - val_accuracy: 0.9370\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3239 - accuracy: 0.9325 - val_loss: 0.2956 - val_accuracy: 0.9384\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3168 - accuracy: 0.9326 - val_loss: 0.3009 - val_accuracy: 0.9387\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3196 - accuracy: 0.9336 - val_loss: 0.3000 - val_accuracy: 0.9402\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3087 - accuracy: 0.9369 - val_loss: 0.2891 - val_accuracy: 0.9422\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2891 - accuracy: 0.9390 - val_loss: 0.2838 - val_accuracy: 0.9437\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3042 - accuracy: 0.9391 - val_loss: 0.2751 - val_accuracy: 0.9437\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2983 - accuracy: 0.9395 - val_loss: 0.2758 - val_accuracy: 0.9449\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2918 - accuracy: 0.9413 - val_loss: 0.2696 - val_accuracy: 0.9474\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2908 - accuracy: 0.9438 - val_loss: 0.2586 - val_accuracy: 0.9495\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2818 - accuracy: 0.9450 - val_loss: 0.2570 - val_accuracy: 0.9495\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2721 - accuracy: 0.9459 - val_loss: 0.2512 - val_accuracy: 0.9509\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2693 - accuracy: 0.9477 - val_loss: 0.2517 - val_accuracy: 0.9515\n",
      "\n",
      "\n",
      "\n",
      "Starting run  12\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 50s 198ms/step - loss: 2.0056 - accuracy: 0.3026 - val_loss: 0.8699 - val_accuracy: 0.7164\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.7467 - accuracy: 0.7581 - val_loss: 0.4924 - val_accuracy: 0.8432\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.5079 - accuracy: 0.8408 - val_loss: 0.4103 - val_accuracy: 0.8832\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4321 - accuracy: 0.8811 - val_loss: 0.3734 - val_accuracy: 0.9033\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.3990 - accuracy: 0.8985 - val_loss: 0.3541 - val_accuracy: 0.9140\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3868 - accuracy: 0.9073 - val_loss: 0.3453 - val_accuracy: 0.9206\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.3764 - accuracy: 0.9135 - val_loss: 0.3315 - val_accuracy: 0.9270\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.3477 - accuracy: 0.9208 - val_loss: 0.3178 - val_accuracy: 0.9294\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.3327 - accuracy: 0.9253 - val_loss: 0.3061 - val_accuracy: 0.9352\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3339 - accuracy: 0.9273 - val_loss: 0.2941 - val_accuracy: 0.9384\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3216 - accuracy: 0.9308 - val_loss: 0.2761 - val_accuracy: 0.9419\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2956 - accuracy: 0.9364 - val_loss: 0.2642 - val_accuracy: 0.9441\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2914 - accuracy: 0.9382 - val_loss: 0.2605 - val_accuracy: 0.9447\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2938 - accuracy: 0.9386 - val_loss: 0.2538 - val_accuracy: 0.9467\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2881 - accuracy: 0.9413 - val_loss: 0.2434 - val_accuracy: 0.9492\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 50s 207ms/step - loss: 0.2728 - accuracy: 0.9436 - val_loss: 0.2370 - val_accuracy: 0.9508\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2732 - accuracy: 0.9435 - val_loss: 0.2356 - val_accuracy: 0.9513\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2573 - accuracy: 0.9466 - val_loss: 0.2251 - val_accuracy: 0.9526\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2498 - accuracy: 0.9479 - val_loss: 0.2201 - val_accuracy: 0.9540\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2436 - accuracy: 0.9495 - val_loss: 0.2180 - val_accuracy: 0.9550\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2418 - accuracy: 0.9507 - val_loss: 0.2074 - val_accuracy: 0.9571\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2380 - accuracy: 0.9514 - val_loss: 0.2077 - val_accuracy: 0.9565\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2545 - accuracy: 0.9504 - val_loss: 0.2079 - val_accuracy: 0.9571\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2381 - accuracy: 0.9536 - val_loss: 0.2087 - val_accuracy: 0.9575\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2422 - accuracy: 0.9530 - val_loss: 0.2027 - val_accuracy: 0.9578\n",
      "\n",
      "\n",
      "\n",
      "Starting run  13\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 1.9557 - accuracy: 0.3929 - val_loss: 0.9049 - val_accuracy: 0.7060\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.8251 - accuracy: 0.7281 - val_loss: 0.6153 - val_accuracy: 0.8061\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.6150 - accuracy: 0.8116 - val_loss: 0.5045 - val_accuracy: 0.8550\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5244 - accuracy: 0.8562 - val_loss: 0.4550 - val_accuracy: 0.8809\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4862 - accuracy: 0.8758 - val_loss: 0.4350 - val_accuracy: 0.8930\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4713 - accuracy: 0.8898 - val_loss: 0.4190 - val_accuracy: 0.9015\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4544 - accuracy: 0.8968 - val_loss: 0.4268 - val_accuracy: 0.9046\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4408 - accuracy: 0.9025 - val_loss: 0.3988 - val_accuracy: 0.9137\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4375 - accuracy: 0.9066 - val_loss: 0.3897 - val_accuracy: 0.9179\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.4340 - accuracy: 0.9086 - val_loss: 0.3794 - val_accuracy: 0.9224\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4165 - accuracy: 0.9153 - val_loss: 0.3627 - val_accuracy: 0.9267\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 50s 209ms/step - loss: 0.4034 - accuracy: 0.9181 - val_loss: 0.3571 - val_accuracy: 0.9268\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3820 - accuracy: 0.9229 - val_loss: 0.3416 - val_accuracy: 0.9302\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3634 - accuracy: 0.9246 - val_loss: 0.3291 - val_accuracy: 0.9330\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3745 - accuracy: 0.9244 - val_loss: 0.3225 - val_accuracy: 0.9345\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3557 - accuracy: 0.9289 - val_loss: 0.3251 - val_accuracy: 0.9349\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3577 - accuracy: 0.9307 - val_loss: 0.3102 - val_accuracy: 0.9395\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.3365 - accuracy: 0.9345 - val_loss: 0.2963 - val_accuracy: 0.9408\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3283 - accuracy: 0.9365 - val_loss: 0.2892 - val_accuracy: 0.9426\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3240 - accuracy: 0.9366 - val_loss: 0.2821 - val_accuracy: 0.9447\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.3046 - accuracy: 0.9395 - val_loss: 0.2794 - val_accuracy: 0.9460\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3056 - accuracy: 0.9403 - val_loss: 0.2692 - val_accuracy: 0.9473\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2993 - accuracy: 0.9423 - val_loss: 0.2676 - val_accuracy: 0.9474\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3070 - accuracy: 0.9409 - val_loss: 0.2647 - val_accuracy: 0.9481\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2903 - accuracy: 0.9435 - val_loss: 0.2533 - val_accuracy: 0.9499\n",
      "\n",
      "\n",
      "\n",
      "Starting run  14\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 2.0770 - accuracy: 0.2915 - val_loss: 1.2139 - val_accuracy: 0.6013\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 1.0752 - accuracy: 0.6420 - val_loss: 0.8142 - val_accuracy: 0.7412\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.7785 - accuracy: 0.7521 - val_loss: 0.5988 - val_accuracy: 0.8159\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.6282 - accuracy: 0.8144 - val_loss: 0.5246 - val_accuracy: 0.8527\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.5493 - accuracy: 0.8507 - val_loss: 0.4674 - val_accuracy: 0.8724\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5006 - accuracy: 0.8691 - val_loss: 0.4242 - val_accuracy: 0.8912\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.4708 - accuracy: 0.8841 - val_loss: 0.3980 - val_accuracy: 0.9009\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4291 - accuracy: 0.8960 - val_loss: 0.3770 - val_accuracy: 0.9106\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4132 - accuracy: 0.9030 - val_loss: 0.3664 - val_accuracy: 0.9120\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4001 - accuracy: 0.9098 - val_loss: 0.3551 - val_accuracy: 0.9186\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3771 - accuracy: 0.9147 - val_loss: 0.3385 - val_accuracy: 0.9227\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3793 - accuracy: 0.9192 - val_loss: 0.3306 - val_accuracy: 0.9274\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3709 - accuracy: 0.9211 - val_loss: 0.3184 - val_accuracy: 0.9308\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3553 - accuracy: 0.9253 - val_loss: 0.3081 - val_accuracy: 0.9334\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3364 - accuracy: 0.9306 - val_loss: 0.2957 - val_accuracy: 0.9365\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3362 - accuracy: 0.9321 - val_loss: 0.2922 - val_accuracy: 0.9391\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3233 - accuracy: 0.9341 - val_loss: 0.2885 - val_accuracy: 0.9389\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3182 - accuracy: 0.9351 - val_loss: 0.2788 - val_accuracy: 0.9423\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3093 - accuracy: 0.9375 - val_loss: 0.2865 - val_accuracy: 0.9432\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3040 - accuracy: 0.9392 - val_loss: 0.2677 - val_accuracy: 0.9460\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2991 - accuracy: 0.9403 - val_loss: 0.2629 - val_accuracy: 0.9462\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2928 - accuracy: 0.9417 - val_loss: 0.2579 - val_accuracy: 0.9478\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2800 - accuracy: 0.9444 - val_loss: 0.2473 - val_accuracy: 0.9504\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2774 - accuracy: 0.9439 - val_loss: 0.2490 - val_accuracy: 0.9509\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2695 - accuracy: 0.9459 - val_loss: 0.2474 - val_accuracy: 0.9518\n",
      "\n",
      "\n",
      "\n",
      "Starting run  15\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 50s 202ms/step - loss: 1.9514 - accuracy: 0.3854 - val_loss: 0.6667 - val_accuracy: 0.7630\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 202ms/step - loss: 0.6066 - accuracy: 0.7947 - val_loss: 0.4040 - val_accuracy: 0.8843\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 49s 202ms/step - loss: 0.4309 - accuracy: 0.8792 - val_loss: 0.3682 - val_accuracy: 0.9034\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 49s 202ms/step - loss: 0.3992 - accuracy: 0.8965 - val_loss: 0.3586 - val_accuracy: 0.9119\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3980 - accuracy: 0.9051 - val_loss: 0.3499 - val_accuracy: 0.9184\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3811 - accuracy: 0.9132 - val_loss: 0.3404 - val_accuracy: 0.9226\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3620 - accuracy: 0.9180 - val_loss: 0.3378 - val_accuracy: 0.9254\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3670 - accuracy: 0.9205 - val_loss: 0.3245 - val_accuracy: 0.9292\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3625 - accuracy: 0.9225 - val_loss: 0.3186 - val_accuracy: 0.9329\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3355 - accuracy: 0.9290 - val_loss: 0.3123 - val_accuracy: 0.9348\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3452 - accuracy: 0.9287 - val_loss: 0.3026 - val_accuracy: 0.9364\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3312 - accuracy: 0.9310 - val_loss: 0.3035 - val_accuracy: 0.9384\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3257 - accuracy: 0.9353 - val_loss: 0.3018 - val_accuracy: 0.9404\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3268 - accuracy: 0.9342 - val_loss: 0.2980 - val_accuracy: 0.9413\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3136 - accuracy: 0.9368 - val_loss: 0.2799 - val_accuracy: 0.9427\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 202ms/step - loss: 0.3159 - accuracy: 0.9388 - val_loss: 0.2739 - val_accuracy: 0.9444\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 202ms/step - loss: 0.3126 - accuracy: 0.9391 - val_loss: 0.2739 - val_accuracy: 0.9458\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3059 - accuracy: 0.9410 - val_loss: 0.2706 - val_accuracy: 0.9464\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 202ms/step - loss: 0.2938 - accuracy: 0.9433 - val_loss: 0.2737 - val_accuracy: 0.9464\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.2908 - accuracy: 0.9424 - val_loss: 0.2691 - val_accuracy: 0.9470\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.2818 - accuracy: 0.9454 - val_loss: 0.2635 - val_accuracy: 0.9476\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.2854 - accuracy: 0.9451 - val_loss: 0.2637 - val_accuracy: 0.9470\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.2765 - accuracy: 0.9467 - val_loss: 0.2512 - val_accuracy: 0.9498\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.2783 - accuracy: 0.9460 - val_loss: 0.2518 - val_accuracy: 0.9506\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.2863 - accuracy: 0.9453 - val_loss: 0.2479 - val_accuracy: 0.9516\n",
      "\n",
      "\n",
      "\n",
      "Starting run  16\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 1.9675 - accuracy: 0.3820 - val_loss: 0.7446 - val_accuracy: 0.7474\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.6856 - accuracy: 0.7657 - val_loss: 0.4714 - val_accuracy: 0.8481\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4860 - accuracy: 0.8528 - val_loss: 0.4053 - val_accuracy: 0.8871\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4308 - accuracy: 0.8815 - val_loss: 0.3734 - val_accuracy: 0.9034\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4031 - accuracy: 0.8976 - val_loss: 0.3704 - val_accuracy: 0.9101\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3950 - accuracy: 0.9056 - val_loss: 0.3486 - val_accuracy: 0.9178\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3677 - accuracy: 0.9155 - val_loss: 0.3476 - val_accuracy: 0.9215\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3794 - accuracy: 0.9157 - val_loss: 0.3390 - val_accuracy: 0.9268\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3677 - accuracy: 0.9212 - val_loss: 0.3358 - val_accuracy: 0.9293\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3412 - accuracy: 0.9263 - val_loss: 0.3192 - val_accuracy: 0.9315\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3509 - accuracy: 0.9271 - val_loss: 0.3204 - val_accuracy: 0.9331\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3551 - accuracy: 0.9282 - val_loss: 0.3094 - val_accuracy: 0.9365\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3376 - accuracy: 0.9315 - val_loss: 0.3065 - val_accuracy: 0.9368\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3222 - accuracy: 0.9338 - val_loss: 0.2982 - val_accuracy: 0.9385\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3187 - accuracy: 0.9346 - val_loss: 0.2939 - val_accuracy: 0.9410\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3206 - accuracy: 0.9364 - val_loss: 0.2914 - val_accuracy: 0.9419\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3262 - accuracy: 0.9361 - val_loss: 0.2966 - val_accuracy: 0.9423\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3138 - accuracy: 0.9395 - val_loss: 0.2786 - val_accuracy: 0.9444\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3070 - accuracy: 0.9420 - val_loss: 0.2864 - val_accuracy: 0.9449\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3017 - accuracy: 0.9426 - val_loss: 0.2677 - val_accuracy: 0.9481\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3145 - accuracy: 0.9418 - val_loss: 0.2738 - val_accuracy: 0.9473\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3158 - accuracy: 0.9425 - val_loss: 0.2690 - val_accuracy: 0.9478\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2965 - accuracy: 0.9457 - val_loss: 0.2567 - val_accuracy: 0.9495\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2930 - accuracy: 0.9445 - val_loss: 0.2553 - val_accuracy: 0.9520\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2895 - accuracy: 0.9456 - val_loss: 0.2500 - val_accuracy: 0.9520\n",
      "\n",
      "\n",
      "\n",
      "Starting run  17\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 1.9610 - accuracy: 0.3400 - val_loss: 0.8295 - val_accuracy: 0.7150\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.7373 - accuracy: 0.7490 - val_loss: 0.5267 - val_accuracy: 0.8437\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5384 - accuracy: 0.8446 - val_loss: 0.4787 - val_accuracy: 0.8798\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4931 - accuracy: 0.8751 - val_loss: 0.4556 - val_accuracy: 0.8940\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4691 - accuracy: 0.8883 - val_loss: 0.4470 - val_accuracy: 0.9018\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.4449 - accuracy: 0.8988 - val_loss: 0.4202 - val_accuracy: 0.9100\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4482 - accuracy: 0.9022 - val_loss: 0.4035 - val_accuracy: 0.9160\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4278 - accuracy: 0.9107 - val_loss: 0.3801 - val_accuracy: 0.9213\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4022 - accuracy: 0.9160 - val_loss: 0.3742 - val_accuracy: 0.9252\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3888 - accuracy: 0.9186 - val_loss: 0.3596 - val_accuracy: 0.9272\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3891 - accuracy: 0.9212 - val_loss: 0.3507 - val_accuracy: 0.9300\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3732 - accuracy: 0.9252 - val_loss: 0.3477 - val_accuracy: 0.9319\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3749 - accuracy: 0.9259 - val_loss: 0.3308 - val_accuracy: 0.9354\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.3459 - accuracy: 0.9307 - val_loss: 0.3240 - val_accuracy: 0.9369\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3550 - accuracy: 0.9295 - val_loss: 0.3092 - val_accuracy: 0.9383\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3325 - accuracy: 0.9342 - val_loss: 0.2881 - val_accuracy: 0.9411\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3187 - accuracy: 0.9358 - val_loss: 0.2917 - val_accuracy: 0.9433\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3162 - accuracy: 0.9387 - val_loss: 0.2940 - val_accuracy: 0.9428\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3136 - accuracy: 0.9388 - val_loss: 0.2822 - val_accuracy: 0.9454\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3122 - accuracy: 0.9391 - val_loss: 0.2744 - val_accuracy: 0.9469\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3101 - accuracy: 0.9397 - val_loss: 0.2654 - val_accuracy: 0.9481\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2939 - accuracy: 0.9420 - val_loss: 0.2586 - val_accuracy: 0.9481\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2939 - accuracy: 0.9434 - val_loss: 0.2568 - val_accuracy: 0.9488\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2856 - accuracy: 0.9452 - val_loss: 0.2579 - val_accuracy: 0.9488\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2823 - accuracy: 0.9470 - val_loss: 0.2450 - val_accuracy: 0.9522\n",
      "\n",
      "\n",
      "\n",
      "Starting run  18\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 2.0089 - accuracy: 0.3119 - val_loss: 0.9471 - val_accuracy: 0.6842\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.8433 - accuracy: 0.7196 - val_loss: 0.6001 - val_accuracy: 0.8138\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.6182 - accuracy: 0.8081 - val_loss: 0.5895 - val_accuracy: 0.8296\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5546 - accuracy: 0.8484 - val_loss: 0.5405 - val_accuracy: 0.8590\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5360 - accuracy: 0.8638 - val_loss: 0.5042 - val_accuracy: 0.8792\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 47s 198ms/step - loss: 0.5287 - accuracy: 0.8771 - val_loss: 0.4877 - val_accuracy: 0.8880\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4964 - accuracy: 0.8844 - val_loss: 0.4863 - val_accuracy: 0.8919\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4959 - accuracy: 0.8927 - val_loss: 0.4618 - val_accuracy: 0.9025\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4713 - accuracy: 0.9000 - val_loss: 0.4647 - val_accuracy: 0.9029\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4712 - accuracy: 0.9013 - val_loss: 0.4400 - val_accuracy: 0.9094\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4490 - accuracy: 0.9083 - val_loss: 0.4293 - val_accuracy: 0.9120\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4282 - accuracy: 0.9113 - val_loss: 0.4265 - val_accuracy: 0.9166\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.4255 - accuracy: 0.9120 - val_loss: 0.4090 - val_accuracy: 0.9202\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4069 - accuracy: 0.9175 - val_loss: 0.3910 - val_accuracy: 0.9224\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3976 - accuracy: 0.9203 - val_loss: 0.3892 - val_accuracy: 0.9238\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3906 - accuracy: 0.9236 - val_loss: 0.3727 - val_accuracy: 0.9262\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3846 - accuracy: 0.9251 - val_loss: 0.3724 - val_accuracy: 0.9287\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3660 - accuracy: 0.9274 - val_loss: 0.3557 - val_accuracy: 0.9321\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3634 - accuracy: 0.9282 - val_loss: 0.3502 - val_accuracy: 0.9343\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3512 - accuracy: 0.9303 - val_loss: 0.3363 - val_accuracy: 0.9365\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3567 - accuracy: 0.9329 - val_loss: 0.3344 - val_accuracy: 0.9373\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3348 - accuracy: 0.9349 - val_loss: 0.3199 - val_accuracy: 0.9390\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3337 - accuracy: 0.9353 - val_loss: 0.3188 - val_accuracy: 0.9386\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 49s 203ms/step - loss: 0.3307 - accuracy: 0.9360 - val_loss: 0.3106 - val_accuracy: 0.9427\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3203 - accuracy: 0.9376 - val_loss: 0.3101 - val_accuracy: 0.9429\n",
      "\n",
      "\n",
      "\n",
      "Starting run  19\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 50s 199ms/step - loss: 1.9705 - accuracy: 0.3347 - val_loss: 0.9543 - val_accuracy: 0.6886\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.9122 - accuracy: 0.7023 - val_loss: 0.7298 - val_accuracy: 0.7591\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.7356 - accuracy: 0.7740 - val_loss: 0.6468 - val_accuracy: 0.8118\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.6579 - accuracy: 0.8148 - val_loss: 0.5609 - val_accuracy: 0.8486\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5951 - accuracy: 0.8458 - val_loss: 0.5065 - val_accuracy: 0.8734\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.5500 - accuracy: 0.8660 - val_loss: 0.4719 - val_accuracy: 0.8870\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.5214 - accuracy: 0.8816 - val_loss: 0.4698 - val_accuracy: 0.8936\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4991 - accuracy: 0.8907 - val_loss: 0.4369 - val_accuracy: 0.9012\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.4839 - accuracy: 0.8967 - val_loss: 0.4311 - val_accuracy: 0.9058\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4538 - accuracy: 0.9060 - val_loss: 0.4078 - val_accuracy: 0.9117\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.4495 - accuracy: 0.9074 - val_loss: 0.3933 - val_accuracy: 0.9153\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4377 - accuracy: 0.9108 - val_loss: 0.3757 - val_accuracy: 0.9199\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4180 - accuracy: 0.9155 - val_loss: 0.3743 - val_accuracy: 0.9228\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4020 - accuracy: 0.9190 - val_loss: 0.3379 - val_accuracy: 0.9286\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3976 - accuracy: 0.9217 - val_loss: 0.3325 - val_accuracy: 0.9317\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3573 - accuracy: 0.9275 - val_loss: 0.3239 - val_accuracy: 0.9331\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3623 - accuracy: 0.9263 - val_loss: 0.3140 - val_accuracy: 0.9353\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3501 - accuracy: 0.9313 - val_loss: 0.2998 - val_accuracy: 0.9383\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3520 - accuracy: 0.9322 - val_loss: 0.3073 - val_accuracy: 0.9374\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3404 - accuracy: 0.9329 - val_loss: 0.2957 - val_accuracy: 0.9400\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3338 - accuracy: 0.9345 - val_loss: 0.2889 - val_accuracy: 0.9423\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3199 - accuracy: 0.9368 - val_loss: 0.2749 - val_accuracy: 0.9438\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3170 - accuracy: 0.9385 - val_loss: 0.2790 - val_accuracy: 0.9427\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3231 - accuracy: 0.9385 - val_loss: 0.2780 - val_accuracy: 0.9455\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3082 - accuracy: 0.9403 - val_loss: 0.2663 - val_accuracy: 0.9466\n",
      "\n",
      "\n",
      "\n",
      "Starting run  20\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 200ms/step - loss: 1.9582 - accuracy: 0.3677 - val_loss: 0.8214 - val_accuracy: 0.7575\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.7293 - accuracy: 0.7840 - val_loss: 0.4934 - val_accuracy: 0.8591\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5066 - accuracy: 0.8569 - val_loss: 0.4204 - val_accuracy: 0.8889\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.4434 - accuracy: 0.8849 - val_loss: 0.3942 - val_accuracy: 0.9037\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4099 - accuracy: 0.9021 - val_loss: 0.3710 - val_accuracy: 0.9144\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.4017 - accuracy: 0.9080 - val_loss: 0.3621 - val_accuracy: 0.9201\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4092 - accuracy: 0.9124 - val_loss: 0.3608 - val_accuracy: 0.9250\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3883 - accuracy: 0.9190 - val_loss: 0.3388 - val_accuracy: 0.9276\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3672 - accuracy: 0.9219 - val_loss: 0.3330 - val_accuracy: 0.9311\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3675 - accuracy: 0.9241 - val_loss: 0.3276 - val_accuracy: 0.9327\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3534 - accuracy: 0.9274 - val_loss: 0.3140 - val_accuracy: 0.9360\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3470 - accuracy: 0.9310 - val_loss: 0.3083 - val_accuracy: 0.9381\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3382 - accuracy: 0.9332 - val_loss: 0.3021 - val_accuracy: 0.9399\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3290 - accuracy: 0.9338 - val_loss: 0.2906 - val_accuracy: 0.9427\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3143 - accuracy: 0.9374 - val_loss: 0.2874 - val_accuracy: 0.9436\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3116 - accuracy: 0.9383 - val_loss: 0.2688 - val_accuracy: 0.9466\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.3088 - accuracy: 0.9386 - val_loss: 0.2645 - val_accuracy: 0.9478\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2939 - accuracy: 0.9423 - val_loss: 0.2649 - val_accuracy: 0.9493\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2880 - accuracy: 0.9432 - val_loss: 0.2593 - val_accuracy: 0.9509\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3006 - accuracy: 0.9427 - val_loss: 0.2569 - val_accuracy: 0.9508\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2846 - accuracy: 0.9462 - val_loss: 0.2534 - val_accuracy: 0.9519\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2785 - accuracy: 0.9449 - val_loss: 0.2489 - val_accuracy: 0.9541\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2958 - accuracy: 0.9461 - val_loss: 0.2455 - val_accuracy: 0.9546\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2776 - accuracy: 0.9489 - val_loss: 0.2428 - val_accuracy: 0.9551\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2709 - accuracy: 0.9491 - val_loss: 0.2439 - val_accuracy: 0.9558\n",
      "\n",
      "\n",
      "\n",
      "Starting run  21\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 2.0629 - accuracy: 0.3153 - val_loss: 0.9724 - val_accuracy: 0.6780\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.8134 - accuracy: 0.7328 - val_loss: 0.4786 - val_accuracy: 0.8524\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4680 - accuracy: 0.8592 - val_loss: 0.3885 - val_accuracy: 0.8939\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4075 - accuracy: 0.8910 - val_loss: 0.3647 - val_accuracy: 0.9084\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3990 - accuracy: 0.9008 - val_loss: 0.3632 - val_accuracy: 0.9131\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3782 - accuracy: 0.9110 - val_loss: 0.3460 - val_accuracy: 0.9245\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3715 - accuracy: 0.9176 - val_loss: 0.3311 - val_accuracy: 0.9282\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3674 - accuracy: 0.9220 - val_loss: 0.3240 - val_accuracy: 0.9317\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3410 - accuracy: 0.9281 - val_loss: 0.3066 - val_accuracy: 0.9371\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3280 - accuracy: 0.9304 - val_loss: 0.2973 - val_accuracy: 0.9389\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3286 - accuracy: 0.9339 - val_loss: 0.2917 - val_accuracy: 0.9408\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3117 - accuracy: 0.9363 - val_loss: 0.2798 - val_accuracy: 0.9430\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3019 - accuracy: 0.9380 - val_loss: 0.2725 - val_accuracy: 0.9446\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2962 - accuracy: 0.9414 - val_loss: 0.2645 - val_accuracy: 0.9478\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2963 - accuracy: 0.9411 - val_loss: 0.2612 - val_accuracy: 0.9474\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2859 - accuracy: 0.9429 - val_loss: 0.2549 - val_accuracy: 0.9470\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2792 - accuracy: 0.9444 - val_loss: 0.2508 - val_accuracy: 0.9515\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2709 - accuracy: 0.9465 - val_loss: 0.2355 - val_accuracy: 0.9524\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2678 - accuracy: 0.9474 - val_loss: 0.2363 - val_accuracy: 0.9536\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2532 - accuracy: 0.9506 - val_loss: 0.2280 - val_accuracy: 0.9540\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2687 - accuracy: 0.9499 - val_loss: 0.2305 - val_accuracy: 0.9536\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2504 - accuracy: 0.9516 - val_loss: 0.2179 - val_accuracy: 0.9559\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2585 - accuracy: 0.9505 - val_loss: 0.2080 - val_accuracy: 0.9586\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2498 - accuracy: 0.9522 - val_loss: 0.2063 - val_accuracy: 0.9586\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2328 - accuracy: 0.9555 - val_loss: 0.2057 - val_accuracy: 0.9593\n",
      "\n",
      "\n",
      "\n",
      "Starting run  22\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 50s 200ms/step - loss: 1.8754 - accuracy: 0.4164 - val_loss: 0.6288 - val_accuracy: 0.8104\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5527 - accuracy: 0.8314 - val_loss: 0.3894 - val_accuracy: 0.8910\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4086 - accuracy: 0.8891 - val_loss: 0.3715 - val_accuracy: 0.9089\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3887 - accuracy: 0.9019 - val_loss: 0.3641 - val_accuracy: 0.9179\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3843 - accuracy: 0.9092 - val_loss: 0.3606 - val_accuracy: 0.9249\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3807 - accuracy: 0.9159 - val_loss: 0.3476 - val_accuracy: 0.9294\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3761 - accuracy: 0.9205 - val_loss: 0.3425 - val_accuracy: 0.9319\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3552 - accuracy: 0.9254 - val_loss: 0.3333 - val_accuracy: 0.9338\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3606 - accuracy: 0.9258 - val_loss: 0.3323 - val_accuracy: 0.9355\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3608 - accuracy: 0.9270 - val_loss: 0.3198 - val_accuracy: 0.9371\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3442 - accuracy: 0.9305 - val_loss: 0.3130 - val_accuracy: 0.9395\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3603 - accuracy: 0.9301 - val_loss: 0.3064 - val_accuracy: 0.9414\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3452 - accuracy: 0.9342 - val_loss: 0.3102 - val_accuracy: 0.9411\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3300 - accuracy: 0.9375 - val_loss: 0.2983 - val_accuracy: 0.9449\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3340 - accuracy: 0.9368 - val_loss: 0.2871 - val_accuracy: 0.9450\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3084 - accuracy: 0.9404 - val_loss: 0.2883 - val_accuracy: 0.9480\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3071 - accuracy: 0.9418 - val_loss: 0.2861 - val_accuracy: 0.9485\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2912 - accuracy: 0.9444 - val_loss: 0.2748 - val_accuracy: 0.9498\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2948 - accuracy: 0.9446 - val_loss: 0.2708 - val_accuracy: 0.9508\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2902 - accuracy: 0.9449 - val_loss: 0.2678 - val_accuracy: 0.9508\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.2921 - accuracy: 0.9463 - val_loss: 0.2518 - val_accuracy: 0.9529\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2768 - accuracy: 0.9467 - val_loss: 0.2504 - val_accuracy: 0.9540\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2673 - accuracy: 0.9486 - val_loss: 0.2414 - val_accuracy: 0.9556\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2775 - accuracy: 0.9493 - val_loss: 0.2473 - val_accuracy: 0.9551\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2661 - accuracy: 0.9496 - val_loss: 0.2333 - val_accuracy: 0.9563\n",
      "\n",
      "\n",
      "\n",
      "Starting run  23\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 2.0195 - accuracy: 0.2751 - val_loss: 0.9415 - val_accuracy: 0.6639\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.8481 - accuracy: 0.7117 - val_loss: 0.6685 - val_accuracy: 0.7887\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.6381 - accuracy: 0.8069 - val_loss: 0.5396 - val_accuracy: 0.8546\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5641 - accuracy: 0.8479 - val_loss: 0.4837 - val_accuracy: 0.8757\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5152 - accuracy: 0.8676 - val_loss: 0.4735 - val_accuracy: 0.8886\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 201ms/step - loss: 0.4939 - accuracy: 0.8821 - val_loss: 0.4479 - val_accuracy: 0.8977\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4734 - accuracy: 0.8911 - val_loss: 0.4230 - val_accuracy: 0.9062\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4391 - accuracy: 0.9003 - val_loss: 0.4054 - val_accuracy: 0.9138\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4195 - accuracy: 0.9072 - val_loss: 0.3786 - val_accuracy: 0.9197\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4040 - accuracy: 0.9118 - val_loss: 0.3660 - val_accuracy: 0.9235\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4128 - accuracy: 0.9148 - val_loss: 0.3570 - val_accuracy: 0.9265\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3830 - accuracy: 0.9196 - val_loss: 0.3398 - val_accuracy: 0.9294\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3717 - accuracy: 0.9219 - val_loss: 0.3307 - val_accuracy: 0.9331\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3585 - accuracy: 0.9266 - val_loss: 0.3216 - val_accuracy: 0.9352\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3402 - accuracy: 0.9289 - val_loss: 0.3053 - val_accuracy: 0.9382\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3369 - accuracy: 0.9313 - val_loss: 0.3048 - val_accuracy: 0.9390\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3266 - accuracy: 0.9328 - val_loss: 0.2941 - val_accuracy: 0.9411\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3255 - accuracy: 0.9345 - val_loss: 0.3024 - val_accuracy: 0.9420\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3097 - accuracy: 0.9366 - val_loss: 0.2915 - val_accuracy: 0.9453\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3081 - accuracy: 0.9393 - val_loss: 0.2879 - val_accuracy: 0.9450\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3110 - accuracy: 0.9411 - val_loss: 0.2728 - val_accuracy: 0.9471\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2833 - accuracy: 0.9443 - val_loss: 0.2868 - val_accuracy: 0.9465\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2885 - accuracy: 0.9431 - val_loss: 0.2758 - val_accuracy: 0.9487\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2925 - accuracy: 0.9436 - val_loss: 0.2670 - val_accuracy: 0.9502\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2828 - accuracy: 0.9460 - val_loss: 0.2586 - val_accuracy: 0.9506\n",
      "\n",
      "\n",
      "\n",
      "Starting run  24\n",
      "Epoch 1/25\n",
      "240/240 [==============================] - 49s 199ms/step - loss: 1.9250 - accuracy: 0.4037 - val_loss: 0.7110 - val_accuracy: 0.7805\n",
      "Epoch 2/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.6840 - accuracy: 0.7895 - val_loss: 0.4863 - val_accuracy: 0.8566\n",
      "Epoch 3/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.5198 - accuracy: 0.8540 - val_loss: 0.4430 - val_accuracy: 0.8799\n",
      "Epoch 4/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4823 - accuracy: 0.8765 - val_loss: 0.4025 - val_accuracy: 0.8984\n",
      "Epoch 5/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4362 - accuracy: 0.8947 - val_loss: 0.3880 - val_accuracy: 0.9053\n",
      "Epoch 6/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4172 - accuracy: 0.9028 - val_loss: 0.3712 - val_accuracy: 0.9126\n",
      "Epoch 7/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.4062 - accuracy: 0.9084 - val_loss: 0.3527 - val_accuracy: 0.9196\n",
      "Epoch 8/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3931 - accuracy: 0.9158 - val_loss: 0.3405 - val_accuracy: 0.9250\n",
      "Epoch 9/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.3761 - accuracy: 0.9197 - val_loss: 0.3325 - val_accuracy: 0.9276\n",
      "Epoch 10/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3557 - accuracy: 0.9227 - val_loss: 0.3230 - val_accuracy: 0.9311\n",
      "Epoch 11/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3585 - accuracy: 0.9257 - val_loss: 0.3180 - val_accuracy: 0.9330\n",
      "Epoch 12/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3470 - accuracy: 0.9279 - val_loss: 0.3101 - val_accuracy: 0.9343\n",
      "Epoch 13/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.3388 - accuracy: 0.9299 - val_loss: 0.3029 - val_accuracy: 0.9368\n",
      "Epoch 14/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3208 - accuracy: 0.9326 - val_loss: 0.3061 - val_accuracy: 0.9369\n",
      "Epoch 15/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3234 - accuracy: 0.9351 - val_loss: 0.3005 - val_accuracy: 0.9384\n",
      "Epoch 16/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3099 - accuracy: 0.9369 - val_loss: 0.2901 - val_accuracy: 0.9440\n",
      "Epoch 17/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3174 - accuracy: 0.9389 - val_loss: 0.2856 - val_accuracy: 0.9446\n",
      "Epoch 18/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.3046 - accuracy: 0.9411 - val_loss: 0.2795 - val_accuracy: 0.9453\n",
      "Epoch 19/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2958 - accuracy: 0.9423 - val_loss: 0.2675 - val_accuracy: 0.9469\n",
      "Epoch 20/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2843 - accuracy: 0.9421 - val_loss: 0.2668 - val_accuracy: 0.9476\n",
      "Epoch 21/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2891 - accuracy: 0.9435 - val_loss: 0.2624 - val_accuracy: 0.9487\n",
      "Epoch 22/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2777 - accuracy: 0.9467 - val_loss: 0.2533 - val_accuracy: 0.9505\n",
      "Epoch 23/25\n",
      "240/240 [==============================] - 48s 199ms/step - loss: 0.2695 - accuracy: 0.9465 - val_loss: 0.2520 - val_accuracy: 0.9515\n",
      "Epoch 24/25\n",
      "240/240 [==============================] - 48s 198ms/step - loss: 0.2875 - accuracy: 0.9454 - val_loss: 0.2496 - val_accuracy: 0.9522\n",
      "Epoch 25/25\n",
      "240/240 [==============================] - 48s 200ms/step - loss: 0.2784 - accuracy: 0.9486 - val_loss: 0.2459 - val_accuracy: 0.9532\n",
      "\n",
      "\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 345,
       "width": 530
      },
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "avg_accuracy_list = np.zeros(epochs)\n",
    "\n",
    "for i in range(num_runs):\n",
    "    print('Starting run ',i)\n",
    "    MyModel=get_MNIST_model()\n",
    "    optimizer = DPKerasSGDOptimizer(\n",
    "        l2_norm_clip=clipping_norm,\n",
    "        noise_multiplier=sigma,\n",
    "        num_microbatches=batch_size,\n",
    "        learning_rate=lr)\n",
    "    # Compute vector of per-example loss rather than its mean over a minibatch.\n",
    "    loss = tf.keras.losses.CategoricalCrossentropy(\n",
    "        from_logits=True, reduction=tf.losses.Reduction.NONE)\n",
    "\n",
    "    # Compile MyModel with Keras\n",
    "    MyModel.compile(optimizer=optimizer, loss=loss, metrics=['accuracy'])\n",
    "\n",
    "    # Train MyModel with Keras\n",
    "    start_time = time.time()\n",
    "    training_metrics=MyModel.fit(train_data, train_labels,\n",
    "            epochs=epochs,\n",
    "            validation_data=(test_data, test_labels),\n",
    "            batch_size=batch_size).history\n",
    "\n",
    "    total_time = time.time()-start_time\n",
    "    accuracy_list = training_metrics['val_accuracy']\n",
    "    epochtime_list = epochs*[total_time/epochs]\n",
    "\n",
    "    avg_accuracy_list+=np.array(accuracy_list)/num_runs\n",
    "    #print(epochtime_list,accuracy_list)\n",
    "    tf.keras.backend.clear_session()\n",
    "    \n",
    "    print('\\n\\n')\n",
    "\n",
    "plt.plot(avg_accuracy_list)\n",
    "record_dict = {'accuracy':avg_accuracy_list}\n",
    "with open(f'pickles/DPVanilla_MNIST{batch_size}_approx.pickle','wb') as handle:\n",
    "    pickle.dump(record_dict,handle)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "1M0DqJKq7Jrz"
   },
   "source": [
    "# DPJL"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "id": "bxY6ZNin5XIa",
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting JLdim  3\n",
      "Starting run  0\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:27, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.807494, Accuracy: 72.239998\n",
      "Per epoch time: 13.530612230300903\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:11, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.531526, Accuracy: 83.900002\n",
      "Per epoch time: 13.380520820617676\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:56, 13.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.457751, Accuracy: 87.739998\n",
      "Per epoch time: 13.352476596832275\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:44, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.408800, Accuracy: 90.000000\n",
      "Per epoch time: 13.560363054275513\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:07<04:30, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.387907, Accuracy: 90.800003\n",
      "Per epoch time: 13.431126356124878\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:17, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.360928, Accuracy: 91.769997\n",
      "Per epoch time: 13.524229764938354\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:34<04:03, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.355376, Accuracy: 92.119995\n",
      "Per epoch time: 13.430315017700195\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:49, 13.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.330173, Accuracy: 92.760002\n",
      "Per epoch time: 13.397756576538086\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:01<03:36, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.308702, Accuracy: 93.290001\n",
      "Per epoch time: 13.461379528045654\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:15<03:23, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.302128, Accuracy: 93.540001\n",
      "Per epoch time: 13.478881359100342\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:28<03:09, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.291655, Accuracy: 93.639999\n",
      "Per epoch time: 13.426415205001831\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:42<02:55, 13.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.276805, Accuracy: 94.209999\n",
      "Per epoch time: 13.306766748428345\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:55<02:41, 13.49s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.269888, Accuracy: 94.230003\n",
      "Per epoch time: 13.361121892929077\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:09<02:28, 13.48s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.259387, Accuracy: 94.559998\n",
      "Per epoch time: 13.377999782562256\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:22<02:14, 13.48s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.251826, Accuracy: 94.840004\n",
      "Per epoch time: 13.396579265594482\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:36<02:01, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.242004, Accuracy: 94.930000\n",
      "Per epoch time: 13.475750923156738\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:49<01:48, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.234397, Accuracy: 95.080002\n",
      "Per epoch time: 13.431895971298218\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:03<01:34, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.227144, Accuracy: 95.139999\n",
      "Per epoch time: 13.410400390625\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:16<01:21, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.224695, Accuracy: 95.250000\n",
      "Per epoch time: 13.47082781791687\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:30<01:07, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.223801, Accuracy: 95.410004\n",
      "Per epoch time: 13.568190336227417\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:44<00:54, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.212088, Accuracy: 95.580002\n",
      "Per epoch time: 13.384124279022217\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:57<00:40, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.204953, Accuracy: 95.740005\n",
      "Per epoch time: 13.457900524139404\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:11<00:27, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.217213, Accuracy: 95.590004\n",
      "Per epoch time: 13.447502613067627\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:24<00:13, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.197573, Accuracy: 95.900002\n",
      "Per epoch time: 13.421866655349731\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:38<00:00, 13.53s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.193974, Accuracy: 95.900002\n",
      "Per epoch time: 13.377983093261719\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  1\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:24, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.715706, Accuracy: 77.550003\n",
      "Per epoch time: 13.413620471954346\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:28<05:30, 14.38s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.427895, Accuracy: 87.639999\n",
      "Per epoch time: 14.877514600753784\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:41<05:06, 13.95s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.366018, Accuracy: 90.360001\n",
      "Per epoch time: 13.372330665588379\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:55<04:49, 13.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.328974, Accuracy: 91.849998\n",
      "Per epoch time: 13.491918802261353\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:08<04:33, 13.69s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.315494, Accuracy: 92.739998\n",
      "Per epoch time: 13.380014181137085\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:22<04:18, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.295052, Accuracy: 93.320000\n",
      "Per epoch time: 13.41116452217102\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:36<04:05, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.284757, Accuracy: 93.769997\n",
      "Per epoch time: 13.494190454483032\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:49<03:50, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.270333, Accuracy: 94.199997\n",
      "Per epoch time: 13.320274829864502\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:03<03:36, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.263348, Accuracy: 94.520004\n",
      "Per epoch time: 13.402978420257568\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:16<03:23, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.255840, Accuracy: 94.599998\n",
      "Per epoch time: 13.499435901641846\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:30<03:09, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.253642, Accuracy: 94.820000\n",
      "Per epoch time: 13.440615892410278\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:55, 13.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.241881, Accuracy: 94.950005\n",
      "Per epoch time: 13.377913236618042\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:57<02:42, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.239655, Accuracy: 95.050003\n",
      "Per epoch time: 13.362689971923828\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:28, 13.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.229254, Accuracy: 95.320000\n",
      "Per epoch time: 13.382322788238525\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:24<02:14, 13.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.220180, Accuracy: 95.470001\n",
      "Per epoch time: 13.405037879943848\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:01, 13.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.219464, Accuracy: 95.660004\n",
      "Per epoch time: 13.428300142288208\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:48, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.213546, Accuracy: 95.810005\n",
      "Per epoch time: 13.538496971130371\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:34, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.202727, Accuracy: 96.000000\n",
      "Per epoch time: 13.443574666976929\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.206381, Accuracy: 96.010002\n",
      "Per epoch time: 13.37997579574585\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:31<01:07, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.202907, Accuracy: 96.090004\n",
      "Per epoch time: 13.485068559646606\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:45<00:54, 13.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.206155, Accuracy: 95.970001\n",
      "Per epoch time: 13.376476526260376\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:58<00:40, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.198984, Accuracy: 96.070000\n",
      "Per epoch time: 13.414163827896118\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:12<00:27, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.211790, Accuracy: 95.920006\n",
      "Per epoch time: 13.40265703201294\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:25<00:13, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.204879, Accuracy: 96.120003\n",
      "Per epoch time: 13.416379451751709\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:39<00:00, 13.57s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.197900, Accuracy: 96.170006\n",
      "Per epoch time: 13.52479863166809\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  2\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:24, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.671486, Accuracy: 77.080002\n",
      "Per epoch time: 13.453456163406372\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:12, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.466330, Accuracy: 86.440002\n",
      "Per epoch time: 13.53934359550476\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:59, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.487994, Accuracy: 87.699997\n",
      "Per epoch time: 13.52201247215271\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:48, 13.73s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.405513, Accuracy: 90.570000\n",
      "Per epoch time: 13.827943325042725\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:08<04:35, 13.79s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.392403, Accuracy: 91.209999\n",
      "Per epoch time: 13.800491094589233\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:22<04:20, 13.70s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.385818, Accuracy: 91.860001\n",
      "Per epoch time: 13.447189807891846\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:05, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.369553, Accuracy: 92.239998\n",
      "Per epoch time: 13.475260972976685\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:49<03:51, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.357091, Accuracy: 92.729996\n",
      "Per epoch time: 13.387701272964478\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.331417, Accuracy: 93.220001\n",
      "Per epoch time: 13.397026538848877\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:16<03:23, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.318965, Accuracy: 93.480003\n",
      "Per epoch time: 13.45188593864441\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:10, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.303252, Accuracy: 93.830002\n",
      "Per epoch time: 13.617924928665161\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:56, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.301907, Accuracy: 93.959999\n",
      "Per epoch time: 13.4314546585083\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:57<02:43, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.294950, Accuracy: 94.199997\n",
      "Per epoch time: 13.555174350738525\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:29, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.278812, Accuracy: 94.400002\n",
      "Per epoch time: 13.493756771087646\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:24<02:15, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.271477, Accuracy: 94.340004\n",
      "Per epoch time: 13.43552279472351\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.259459, Accuracy: 94.720001\n",
      "Per epoch time: 13.542430877685547\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:48, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.252677, Accuracy: 94.919998\n",
      "Per epoch time: 13.505719423294067\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:34, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.244078, Accuracy: 95.110001\n",
      "Per epoch time: 13.406275749206543\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.239317, Accuracy: 95.099998\n",
      "Per epoch time: 13.493804454803467\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:32<01:07, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.232188, Accuracy: 95.410004\n",
      "Per epoch time: 13.540746450424194\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:45<00:54, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.219953, Accuracy: 95.459999\n",
      "Per epoch time: 13.533048391342163\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:59<00:40, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.215050, Accuracy: 95.570000\n",
      "Per epoch time: 13.456660985946655\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:12<00:27, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.210103, Accuracy: 95.610001\n",
      "Per epoch time: 13.390102624893188\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:26<00:13, 13.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.211423, Accuracy: 95.680000\n",
      "Per epoch time: 13.327141046524048\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:39<00:00, 13.59s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.203870, Accuracy: 95.730003\n",
      "Per epoch time: 13.472315549850464\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  3\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:24, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.552536, Accuracy: 82.700005\n",
      "Per epoch time: 13.42412805557251\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:10, 13.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.353312, Accuracy: 89.850006\n",
      "Per epoch time: 13.426561117172241\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:57, 13.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.308013, Accuracy: 91.949997\n",
      "Per epoch time: 13.439003705978394\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:43, 13.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.294485, Accuracy: 92.940002\n",
      "Per epoch time: 13.378659963607788\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:07<04:31, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.276647, Accuracy: 93.639999\n",
      "Per epoch time: 13.545971632003784\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:17, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.268803, Accuracy: 94.029999\n",
      "Per epoch time: 13.466649055480957\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:34<04:03, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.260715, Accuracy: 94.470001\n",
      "Per epoch time: 13.379384756088257\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:49, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.251193, Accuracy: 94.700005\n",
      "Per epoch time: 13.354541540145874\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:01<03:36, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.242060, Accuracy: 94.880005\n",
      "Per epoch time: 13.53268313407898\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:15<03:23, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.244494, Accuracy: 95.139999\n",
      "Per epoch time: 13.457550764083862\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:28<03:08, 13.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.237870, Accuracy: 95.200005\n",
      "Per epoch time: 13.321770668029785\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:42<02:55, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.230231, Accuracy: 95.410004\n",
      "Per epoch time: 13.468560457229614\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:55<02:42, 13.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.233896, Accuracy: 95.540001\n",
      "Per epoch time: 13.380642890930176\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:09<02:28, 13.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.223629, Accuracy: 95.660004\n",
      "Per epoch time: 13.490177392959595\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:22<02:15, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.218823, Accuracy: 95.820000\n",
      "Per epoch time: 13.391750574111938\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:36<02:01, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.216648, Accuracy: 95.740005\n",
      "Per epoch time: 13.39618468284607\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:49<01:48, 13.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.212640, Accuracy: 95.860001\n",
      "Per epoch time: 13.469884157180786\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:03<01:34, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.208351, Accuracy: 95.880005\n",
      "Per epoch time: 13.466071367263794\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:16<01:21, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.198351, Accuracy: 96.200005\n",
      "Per epoch time: 13.493277549743652\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:30<01:07, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.198796, Accuracy: 96.190002\n",
      "Per epoch time: 13.364785194396973\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:43<00:54, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.197176, Accuracy: 96.190002\n",
      "Per epoch time: 13.468262910842896\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:57<00:40, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.196499, Accuracy: 96.170006\n",
      "Per epoch time: 13.460782766342163\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:11<00:27, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.191936, Accuracy: 96.279999\n",
      "Per epoch time: 13.536171197891235\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:24<00:13, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.186375, Accuracy: 96.459999\n",
      "Per epoch time: 13.403088808059692\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:38<00:00, 13.54s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.185428, Accuracy: 96.350006\n",
      "Per epoch time: 13.823366165161133\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  4\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:24, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.539118, Accuracy: 82.000000\n",
      "Per epoch time: 13.443759202957153\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:10, 13.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.362046, Accuracy: 89.550003\n",
      "Per epoch time: 13.399979591369629\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:58, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.355465, Accuracy: 90.650002\n",
      "Per epoch time: 13.551795244216919\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:44, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.328681, Accuracy: 92.119995\n",
      "Per epoch time: 13.453566312789917\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:07<04:31, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.309640, Accuracy: 92.720001\n",
      "Per epoch time: 13.500428915023804\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:17, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.292291, Accuracy: 93.239998\n",
      "Per epoch time: 13.478521347045898\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:05, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.280636, Accuracy: 93.690002\n",
      "Per epoch time: 13.62345552444458\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:51, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.275130, Accuracy: 93.820000\n",
      "Per epoch time: 13.509915828704834\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.257521, Accuracy: 94.270004\n",
      "Per epoch time: 13.467428922653198\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:15<03:23, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.252903, Accuracy: 94.470001\n",
      "Per epoch time: 13.481786966323853\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:10, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.241559, Accuracy: 94.650002\n",
      "Per epoch time: 13.478016138076782\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:57, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.235800, Accuracy: 94.959999\n",
      "Per epoch time: 13.58652114868164\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:56<02:42, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.228029, Accuracy: 95.150002\n",
      "Per epoch time: 13.406704664230347\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:29, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.222453, Accuracy: 95.209999\n",
      "Per epoch time: 13.503879308700562\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:23<02:15, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.218271, Accuracy: 95.450005\n",
      "Per epoch time: 13.47884726524353\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.214620, Accuracy: 95.570000\n",
      "Per epoch time: 13.491267919540405\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:50<01:48, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.211805, Accuracy: 95.639999\n",
      "Per epoch time: 13.538348913192749\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:35, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.204865, Accuracy: 95.620003\n",
      "Per epoch time: 13.489139080047607\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.206186, Accuracy: 95.670006\n",
      "Per epoch time: 13.531792879104614\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:31<01:07, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.196574, Accuracy: 95.900002\n",
      "Per epoch time: 13.442058563232422\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:45<00:54, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.190872, Accuracy: 95.930000\n",
      "Per epoch time: 13.483470916748047\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:58<00:40, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.191024, Accuracy: 95.980003\n",
      "Per epoch time: 13.357105255126953\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:12<00:27, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.186622, Accuracy: 96.150002\n",
      "Per epoch time: 13.45825481414795\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:26<00:13, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.178116, Accuracy: 96.190002\n",
      "Per epoch time: 13.730431079864502\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:39<00:00, 13.59s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.178535, Accuracy: 96.279999\n",
      "Per epoch time: 13.658609390258789\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  5\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:26, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.597663, Accuracy: 80.070000\n",
      "Per epoch time: 13.49904203414917\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:10, 13.49s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.412645, Accuracy: 88.840004\n",
      "Per epoch time: 13.323936462402344\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:56, 13.48s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.380442, Accuracy: 90.690002\n",
      "Per epoch time: 13.36794924736023\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:43, 13.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.345911, Accuracy: 91.869995\n",
      "Per epoch time: 13.461280822753906\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:07<04:30, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.314979, Accuracy: 92.900002\n",
      "Per epoch time: 13.463746786117554\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:17, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.295942, Accuracy: 93.639999\n",
      "Per epoch time: 13.474540710449219\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:34<04:03, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.277129, Accuracy: 94.139999\n",
      "Per epoch time: 13.428675413131714\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:49, 13.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.266090, Accuracy: 94.500000\n",
      "Per epoch time: 13.388503074645996\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:01<03:36, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.259649, Accuracy: 94.570000\n",
      "Per epoch time: 13.542467832565308\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:15<03:22, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.242379, Accuracy: 95.070000\n",
      "Per epoch time: 13.36815857887268\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:28<03:09, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.241565, Accuracy: 94.980003\n",
      "Per epoch time: 13.409826040267944\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:42<02:55, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.231203, Accuracy: 95.260002\n",
      "Per epoch time: 13.45766305923462\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:55<02:42, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.223140, Accuracy: 95.300003\n",
      "Per epoch time: 13.485454559326172\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:09<02:29, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.216336, Accuracy: 95.570000\n",
      "Per epoch time: 13.524228811264038\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:23<02:15, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.212646, Accuracy: 95.889999\n",
      "Per epoch time: 13.397515773773193\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:36<02:02, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.210548, Accuracy: 96.050003\n",
      "Per epoch time: 13.570562362670898\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:50<01:49, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.211245, Accuracy: 95.870003\n",
      "Per epoch time: 13.802831172943115\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:36, 13.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.208753, Accuracy: 96.130005\n",
      "Per epoch time: 13.723912477493286\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:17<01:21, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.201601, Accuracy: 95.980003\n",
      "Per epoch time: 13.381720304489136\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:31<01:08, 13.76s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.184674, Accuracy: 96.260002\n",
      "Per epoch time: 13.88734221458435\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:45<00:54, 13.69s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.186433, Accuracy: 96.270004\n",
      "Per epoch time: 13.427139282226562\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:58<00:40, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.190007, Accuracy: 96.310005\n",
      "Per epoch time: 13.3863365650177\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:12<00:27, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.183285, Accuracy: 96.430000\n",
      "Per epoch time: 13.448156356811523\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:25<00:13, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.180657, Accuracy: 96.440002\n",
      "Per epoch time: 13.43239688873291\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:39<00:00, 13.58s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.179080, Accuracy: 96.510002\n",
      "Per epoch time: 13.37833571434021\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  6\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:26, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.677267, Accuracy: 78.559998\n",
      "Per epoch time: 13.489936113357544\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:12, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.443039, Accuracy: 87.169998\n",
      "Per epoch time: 13.527332544326782\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:58, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.388944, Accuracy: 89.750000\n",
      "Per epoch time: 13.44949746131897\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:44, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.336009, Accuracy: 91.570000\n",
      "Per epoch time: 13.452645301818848\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:07<04:31, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.315703, Accuracy: 92.599998\n",
      "Per epoch time: 13.448016881942749\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:17, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.295548, Accuracy: 93.349998\n",
      "Per epoch time: 13.456962585449219\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:34<04:03, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.288333, Accuracy: 93.540001\n",
      "Per epoch time: 13.422027111053467\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:51, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.269471, Accuracy: 94.000000\n",
      "Per epoch time: 13.73799467086792\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.250820, Accuracy: 94.320000\n",
      "Per epoch time: 13.386685609817505\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:15<03:23, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.247915, Accuracy: 94.599998\n",
      "Per epoch time: 13.486459732055664\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:09, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.240603, Accuracy: 94.779999\n",
      "Per epoch time: 13.358301162719727\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:42<02:55, 13.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.233334, Accuracy: 95.029999\n",
      "Per epoch time: 13.394204139709473\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:56<02:42, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.227665, Accuracy: 95.169998\n",
      "Per epoch time: 13.464593887329102\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:09<02:28, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.219907, Accuracy: 95.330002\n",
      "Per epoch time: 13.379966974258423\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:23<02:15, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.209859, Accuracy: 95.580002\n",
      "Per epoch time: 13.47257685661316\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:36<02:01, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.208654, Accuracy: 95.580002\n",
      "Per epoch time: 13.443552017211914\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:50<01:48, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.208422, Accuracy: 95.730003\n",
      "Per epoch time: 13.444478511810303\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:34, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.209139, Accuracy: 95.779999\n",
      "Per epoch time: 13.547956705093384\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:17<01:21, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.202843, Accuracy: 95.709999\n",
      "Per epoch time: 13.606727361679077\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:31<01:07, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.194326, Accuracy: 95.800003\n",
      "Per epoch time: 13.48673677444458\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:44<00:54, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.188588, Accuracy: 96.050003\n",
      "Per epoch time: 13.41629958152771\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:58<00:40, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.191716, Accuracy: 96.120003\n",
      "Per epoch time: 13.68152666091919\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:12<00:27, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.192690, Accuracy: 96.020004\n",
      "Per epoch time: 13.440170526504517\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:25<00:13, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.187764, Accuracy: 96.160004\n",
      "Per epoch time: 13.440278768539429\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:39<00:00, 13.57s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.179235, Accuracy: 96.270004\n",
      "Per epoch time: 13.462956666946411\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  7\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:26, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.521133, Accuracy: 84.589996\n",
      "Per epoch time: 13.49128532409668\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:12, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.417686, Accuracy: 88.590004\n",
      "Per epoch time: 13.493103742599487\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:59, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.385795, Accuracy: 90.839996\n",
      "Per epoch time: 13.580168724060059\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:46, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.360461, Accuracy: 91.779999\n",
      "Per epoch time: 13.557839155197144\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:08<04:32, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.343145, Accuracy: 92.580002\n",
      "Per epoch time: 13.526457071304321\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:18, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.329254, Accuracy: 92.750000\n",
      "Per epoch time: 13.477766513824463\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:04, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.319080, Accuracy: 93.449997\n",
      "Per epoch time: 13.426286220550537\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:49<03:52, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.301577, Accuracy: 93.870003\n",
      "Per epoch time: 13.756488561630249\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.302237, Accuracy: 93.800003\n",
      "Per epoch time: 13.439007759094238\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:16<03:24, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.284934, Accuracy: 94.440002\n",
      "Per epoch time: 13.46110200881958\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:10, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.268960, Accuracy: 94.709999\n",
      "Per epoch time: 13.509499549865723\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:57, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.257330, Accuracy: 94.779999\n",
      "Per epoch time: 13.545546054840088\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:56<02:43, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.256828, Accuracy: 94.860001\n",
      "Per epoch time: 13.496260166168213\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:29, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.249371, Accuracy: 94.900002\n",
      "Per epoch time: 13.532866716384888\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:24<02:16, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.239966, Accuracy: 95.230003\n",
      "Per epoch time: 13.552669763565063\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.243592, Accuracy: 95.139999\n",
      "Per epoch time: 13.47208857536316\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:48, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.237264, Accuracy: 95.310005\n",
      "Per epoch time: 13.494911909103394\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:35, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.234704, Accuracy: 95.279999\n",
      "Per epoch time: 13.443984031677246\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.229043, Accuracy: 95.550003\n",
      "Per epoch time: 13.495822668075562\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:32<01:08, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.217162, Accuracy: 95.720001\n",
      "Per epoch time: 13.56987452507019\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:45<00:54, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.211085, Accuracy: 95.870003\n",
      "Per epoch time: 13.577887535095215\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:59<00:40, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.208168, Accuracy: 95.840004\n",
      "Per epoch time: 13.47205638885498\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:13<00:27, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.194211, Accuracy: 96.010002\n",
      "Per epoch time: 13.674118280410767\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:26<00:13, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.200546, Accuracy: 96.050003\n",
      "Per epoch time: 13.61722731590271\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:40<00:00, 13.62s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.195548, Accuracy: 96.100006\n",
      "Per epoch time: 13.56017279624939\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  8\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:23, 13.47s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.840090, Accuracy: 70.630005\n",
      "Per epoch time: 13.382688522338867\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:11, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.441556, Accuracy: 87.349998\n",
      "Per epoch time: 13.473239183425903\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:58, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.404479, Accuracy: 89.540001\n",
      "Per epoch time: 13.538439750671387\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:45, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.387700, Accuracy: 90.940002\n",
      "Per epoch time: 13.542562246322632\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:07<04:31, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.372492, Accuracy: 91.860001\n",
      "Per epoch time: 13.473387956619263\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:17, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.353267, Accuracy: 92.419998\n",
      "Per epoch time: 13.3779935836792\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:34<04:04, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.353563, Accuracy: 92.610001\n",
      "Per epoch time: 13.512487649917603\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:50, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.340474, Accuracy: 93.029999\n",
      "Per epoch time: 13.493445873260498\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.333515, Accuracy: 93.309998\n",
      "Per epoch time: 13.600336790084839\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:15<03:24, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.325815, Accuracy: 93.449997\n",
      "Per epoch time: 13.685423374176025\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:10, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.312554, Accuracy: 93.790001\n",
      "Per epoch time: 13.447336435317993\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:56, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.317042, Accuracy: 93.709999\n",
      "Per epoch time: 13.495737552642822\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:56<02:43, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.296185, Accuracy: 94.099998\n",
      "Per epoch time: 13.666392087936401\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:30, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.294664, Accuracy: 94.139999\n",
      "Per epoch time: 13.518529176712036\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:24<02:16, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.288716, Accuracy: 94.300003\n",
      "Per epoch time: 13.435680150985718\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.266037, Accuracy: 94.650002\n",
      "Per epoch time: 13.539231538772583\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:48, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.256496, Accuracy: 94.779999\n",
      "Per epoch time: 13.526703834533691\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:35, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.245228, Accuracy: 94.919998\n",
      "Per epoch time: 13.556566715240479\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:22, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.247432, Accuracy: 94.980003\n",
      "Per epoch time: 13.682158470153809\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:32<01:08, 13.76s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.232931, Accuracy: 95.139999\n",
      "Per epoch time: 13.883331537246704\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:46<00:54, 13.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.228608, Accuracy: 95.320000\n",
      "Per epoch time: 13.541297435760498\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [05:00<00:41, 13.75s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.228315, Accuracy: 95.320000\n",
      "Per epoch time: 13.73556113243103\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:13<00:27, 13.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.219135, Accuracy: 95.420006\n",
      "Per epoch time: 13.412805318832397\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:27<00:13, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.215531, Accuracy: 95.470001\n",
      "Per epoch time: 13.492767810821533\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:41<00:00, 13.64s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.200290, Accuracy: 95.870003\n",
      "Per epoch time: 13.852894306182861\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  9\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:27, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.519928, Accuracy: 83.660004\n",
      "Per epoch time: 13.555357456207275\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:13, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.379371, Accuracy: 89.450005\n",
      "Per epoch time: 13.562469244003296\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:59, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.344967, Accuracy: 91.229996\n",
      "Per epoch time: 13.534338235855103\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:45, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.333434, Accuracy: 92.239998\n",
      "Per epoch time: 13.481594562530518\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:08<04:31, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.307611, Accuracy: 93.000000\n",
      "Per epoch time: 13.443614959716797\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:18, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.297682, Accuracy: 93.279999\n",
      "Per epoch time: 13.572799682617188\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:04, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.276252, Accuracy: 93.839996\n",
      "Per epoch time: 13.514850616455078\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:51, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.268733, Accuracy: 94.029999\n",
      "Per epoch time: 13.509006977081299\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.254365, Accuracy: 94.570000\n",
      "Per epoch time: 13.518854856491089\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:16<03:23, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.253171, Accuracy: 94.700005\n",
      "Per epoch time: 13.47509503364563\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:11, 13.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.243565, Accuracy: 94.870003\n",
      "Per epoch time: 13.787145137786865\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:57, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.237090, Accuracy: 94.950005\n",
      "Per epoch time: 13.520435333251953\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:57<02:43, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.226383, Accuracy: 95.209999\n",
      "Per epoch time: 13.508777856826782\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:29, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.223639, Accuracy: 95.279999\n",
      "Per epoch time: 13.541810989379883\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:24<02:16, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.224495, Accuracy: 95.370003\n",
      "Per epoch time: 13.577476501464844\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:38<02:02, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.210331, Accuracy: 95.650002\n",
      "Per epoch time: 13.627359867095947\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:49, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.209926, Accuracy: 95.580002\n",
      "Per epoch time: 13.571605443954468\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:05<01:35, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.203693, Accuracy: 95.860001\n",
      "Per epoch time: 13.55752420425415\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:19<01:21, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.202557, Accuracy: 95.980003\n",
      "Per epoch time: 13.593843936920166\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:32<01:08, 13.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.203025, Accuracy: 95.900002\n",
      "Per epoch time: 13.631935119628906\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:46<00:54, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.203595, Accuracy: 95.900002\n",
      "Per epoch time: 13.418640375137329\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:59<00:40, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.199072, Accuracy: 96.139999\n",
      "Per epoch time: 13.53163480758667\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:13<00:27, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.190739, Accuracy: 96.200005\n",
      "Per epoch time: 13.445280075073242\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:27<00:13, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.188413, Accuracy: 96.300003\n",
      "Per epoch time: 13.500985622406006\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:40<00:00, 13.63s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.184029, Accuracy: 96.330002\n",
      "Per epoch time: 13.543514966964722\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  10\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:26, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.712995, Accuracy: 76.520004\n",
      "Per epoch time: 13.502046346664429\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:16, 13.76s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.489080, Accuracy: 85.509995\n",
      "Per epoch time: 13.783594608306885\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:41<05:00, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.417648, Accuracy: 89.090004\n",
      "Per epoch time: 13.446722507476807\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:47, 13.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.390183, Accuracy: 90.300003\n",
      "Per epoch time: 13.625893592834473\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:08<04:33, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.372100, Accuracy: 91.139999\n",
      "Per epoch time: 13.528524398803711\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:18, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.343597, Accuracy: 92.159996\n",
      "Per epoch time: 13.42764949798584\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:05, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.337451, Accuracy: 92.419998\n",
      "Per epoch time: 13.624131679534912\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:49<03:51, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.307875, Accuracy: 93.209999\n",
      "Per epoch time: 13.461501836776733\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.299449, Accuracy: 93.400002\n",
      "Per epoch time: 13.532447099685669\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:16<03:24, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.293909, Accuracy: 93.680000\n",
      "Per epoch time: 13.508013725280762\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:10, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.273538, Accuracy: 94.099998\n",
      "Per epoch time: 13.454443216323853\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:56, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.273611, Accuracy: 94.290001\n",
      "Per epoch time: 13.551474571228027\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:57<02:43, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.264527, Accuracy: 94.510002\n",
      "Per epoch time: 13.447441816329956\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:29, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.254493, Accuracy: 94.730003\n",
      "Per epoch time: 13.638493537902832\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:24<02:16, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.254255, Accuracy: 94.870003\n",
      "Per epoch time: 13.49964451789856\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:38<02:02, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.243721, Accuracy: 95.110001\n",
      "Per epoch time: 13.559049367904663\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:48, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.240807, Accuracy: 95.169998\n",
      "Per epoch time: 13.45474648475647\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:05<01:35, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.237998, Accuracy: 95.209999\n",
      "Per epoch time: 13.428962707519531\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.228115, Accuracy: 95.420006\n",
      "Per epoch time: 13.49114465713501\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:32<01:07, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.224209, Accuracy: 95.430000\n",
      "Per epoch time: 13.468269109725952\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:45<00:54, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.225727, Accuracy: 95.550003\n",
      "Per epoch time: 13.459737062454224\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:59<00:40, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.216466, Accuracy: 95.779999\n",
      "Per epoch time: 13.506758689880371\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:12<00:27, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.215446, Accuracy: 95.889999\n",
      "Per epoch time: 13.485883712768555\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:26<00:13, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.209320, Accuracy: 95.830002\n",
      "Per epoch time: 13.622459650039673\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:40<00:00, 13.61s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.211922, Accuracy: 95.800003\n",
      "Per epoch time: 13.560973405838013\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  11\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:23, 13.48s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.946267, Accuracy: 69.059998\n",
      "Per epoch time: 13.394974708557129\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:11, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.537042, Accuracy: 82.180000\n",
      "Per epoch time: 13.534562110900879\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:58, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.447686, Accuracy: 87.680000\n",
      "Per epoch time: 13.486140012741089\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:45, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.413976, Accuracy: 89.310005\n",
      "Per epoch time: 13.530110120773315\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:07<04:31, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.403504, Accuracy: 90.270004\n",
      "Per epoch time: 13.470133543014526\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:17, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.405140, Accuracy: 90.769997\n",
      "Per epoch time: 13.405587434768677\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:34<04:04, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.356477, Accuracy: 91.769997\n",
      "Per epoch time: 13.48567533493042\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:50, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.338612, Accuracy: 92.599998\n",
      "Per epoch time: 13.543492317199707\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.326011, Accuracy: 92.949997\n",
      "Per epoch time: 13.564888954162598\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:15<03:23, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.322291, Accuracy: 93.129997\n",
      "Per epoch time: 13.409465789794922\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:11, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.302199, Accuracy: 93.690002\n",
      "Per epoch time: 13.748284101486206\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:57, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.302349, Accuracy: 93.760002\n",
      "Per epoch time: 13.492393016815186\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:56<02:43, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.285018, Accuracy: 94.230003\n",
      "Per epoch time: 13.431915044784546\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:29, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.280197, Accuracy: 94.300003\n",
      "Per epoch time: 13.466179847717285\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:23<02:15, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.272878, Accuracy: 94.639999\n",
      "Per epoch time: 13.409514904022217\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.272451, Accuracy: 94.620003\n",
      "Per epoch time: 13.52128529548645\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:50<01:48, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.251938, Accuracy: 94.950005\n",
      "Per epoch time: 13.482709169387817\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:35, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.244172, Accuracy: 95.150002\n",
      "Per epoch time: 13.52360224723816\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.237524, Accuracy: 95.150002\n",
      "Per epoch time: 13.510522365570068\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:31<01:07, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.236531, Accuracy: 95.200005\n",
      "Per epoch time: 13.4032621383667\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:45<00:54, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.226686, Accuracy: 95.480003\n",
      "Per epoch time: 13.522033929824829\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:58<00:40, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.218922, Accuracy: 95.560005\n",
      "Per epoch time: 13.512442111968994\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:12<00:27, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.220270, Accuracy: 95.639999\n",
      "Per epoch time: 13.479028463363647\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:25<00:13, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.224711, Accuracy: 95.680000\n",
      "Per epoch time: 13.437548398971558\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:39<00:00, 13.59s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.213193, Accuracy: 95.820000\n",
      "Per epoch time: 13.726351022720337\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  12\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:26, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.797479, Accuracy: 71.809998\n",
      "Per epoch time: 13.530075550079346\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:12, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.478046, Accuracy: 85.900002\n",
      "Per epoch time: 13.470726251602173\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:58, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.408116, Accuracy: 89.209999\n",
      "Per epoch time: 13.47249436378479\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:44, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.385635, Accuracy: 90.510002\n",
      "Per epoch time: 13.352170705795288\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:07<04:30, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.365592, Accuracy: 91.669998\n",
      "Per epoch time: 13.474969625473022\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:17, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.340802, Accuracy: 92.360001\n",
      "Per epoch time: 13.52365779876709\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:34<04:03, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.311675, Accuracy: 93.070000\n",
      "Per epoch time: 13.433096170425415\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:50, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.311817, Accuracy: 93.139999\n",
      "Per epoch time: 13.427163362503052\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:01<03:36, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.299008, Accuracy: 93.449997\n",
      "Per epoch time: 13.496046543121338\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:15<03:23, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.276127, Accuracy: 94.090004\n",
      "Per epoch time: 13.494886875152588\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:09, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.258332, Accuracy: 94.270004\n",
      "Per epoch time: 13.401759386062622\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:42<02:56, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.250970, Accuracy: 94.529999\n",
      "Per epoch time: 13.50741958618164\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:56<02:43, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.240957, Accuracy: 94.779999\n",
      "Per epoch time: 13.676456451416016\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:29, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.241414, Accuracy: 94.849998\n",
      "Per epoch time: 13.508874416351318\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:23<02:16, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.224046, Accuracy: 95.240005\n",
      "Per epoch time: 13.480942249298096\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.221315, Accuracy: 95.200005\n",
      "Per epoch time: 13.39985990524292\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:50<01:48, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.219029, Accuracy: 95.349998\n",
      "Per epoch time: 13.465415239334106\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:34, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.210091, Accuracy: 95.380005\n",
      "Per epoch time: 13.434599876403809\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:17<01:21, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.196860, Accuracy: 95.800003\n",
      "Per epoch time: 13.609647035598755\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:31<01:07, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.188915, Accuracy: 96.010002\n",
      "Per epoch time: 13.418403625488281\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:44<00:54, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.189164, Accuracy: 95.889999\n",
      "Per epoch time: 13.442945003509521\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:58<00:40, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.187219, Accuracy: 96.020004\n",
      "Per epoch time: 13.582517385482788\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:12<00:27, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.179040, Accuracy: 96.220001\n",
      "Per epoch time: 13.498085737228394\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:25<00:13, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.181011, Accuracy: 96.110001\n",
      "Per epoch time: 13.533527374267578\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:39<00:00, 13.57s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.176291, Accuracy: 96.230003\n",
      "Per epoch time: 13.39682912826538\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  13\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:26, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.696759, Accuracy: 77.160004\n",
      "Per epoch time: 13.5192391872406\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:11, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.485751, Accuracy: 86.959999\n",
      "Per epoch time: 13.430191040039062\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:41<05:02, 13.77s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.445819, Accuracy: 89.410004\n",
      "Per epoch time: 13.906200408935547\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:47, 13.70s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.416138, Accuracy: 90.669998\n",
      "Per epoch time: 13.520169019699097\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:08<04:32, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.388543, Accuracy: 91.360001\n",
      "Per epoch time: 13.444602489471436\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:19, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.384162, Accuracy: 91.809998\n",
      "Per epoch time: 13.563377141952515\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:05, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.353665, Accuracy: 92.400002\n",
      "Per epoch time: 13.46400785446167\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:49<03:51, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.339226, Accuracy: 92.970001\n",
      "Per epoch time: 13.5834641456604\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.324349, Accuracy: 93.540001\n",
      "Per epoch time: 13.513310194015503\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:16<03:24, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.340566, Accuracy: 93.229996\n",
      "Per epoch time: 13.558530330657959\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:30<03:10, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.299261, Accuracy: 94.129997\n",
      "Per epoch time: 13.565592765808105\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:57, 13.69s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.281409, Accuracy: 94.510002\n",
      "Per epoch time: 13.695930004119873\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:57<02:43, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.277143, Accuracy: 94.709999\n",
      "Per epoch time: 13.502154350280762\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:11<02:30, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.262936, Accuracy: 94.870003\n",
      "Per epoch time: 13.534546852111816\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:24<02:16, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.257792, Accuracy: 95.040001\n",
      "Per epoch time: 13.571580648422241\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:38<02:03, 13.69s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.247620, Accuracy: 95.000000\n",
      "Per epoch time: 13.689343214035034\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:52<01:49, 13.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.238047, Accuracy: 95.290001\n",
      "Per epoch time: 13.67209243774414\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:05<01:35, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.233265, Accuracy: 95.560005\n",
      "Per epoch time: 13.422378540039062\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:19<01:21, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.234394, Accuracy: 95.430000\n",
      "Per epoch time: 13.514232873916626\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:33<01:08, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.223827, Accuracy: 95.730003\n",
      "Per epoch time: 13.499870777130127\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:46<00:54, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.227843, Accuracy: 95.630005\n",
      "Per epoch time: 13.71236777305603\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [05:00<00:40, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.216694, Accuracy: 95.910004\n",
      "Per epoch time: 13.457998275756836\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:13<00:27, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.209319, Accuracy: 96.030006\n",
      "Per epoch time: 13.514607906341553\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:27<00:13, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.205901, Accuracy: 96.110001\n",
      "Per epoch time: 13.575884580612183\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:41<00:00, 13.66s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.200695, Accuracy: 96.050003\n",
      "Per epoch time: 13.673448324203491\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  14\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:31, 13.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.712196, Accuracy: 75.559998\n",
      "Per epoch time: 13.704136610031128\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:15, 13.73s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.466060, Accuracy: 86.099998\n",
      "Per epoch time: 13.583741903305054\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:41<05:00, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.396929, Accuracy: 89.630005\n",
      "Per epoch time: 13.509624481201172\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:46, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.384835, Accuracy: 90.370003\n",
      "Per epoch time: 13.49811315536499\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:08<04:33, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.334432, Accuracy: 92.099998\n",
      "Per epoch time: 13.644762754440308\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:22<04:19, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.313184, Accuracy: 92.750000\n",
      "Per epoch time: 13.541353940963745\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:06, 13.70s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.307064, Accuracy: 93.269997\n",
      "Per epoch time: 13.669845342636108\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:49<03:54, 13.77s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.287966, Accuracy: 93.510002\n",
      "Per epoch time: 13.85568356513977\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:03<03:40, 13.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.280630, Accuracy: 93.800003\n",
      "Per epoch time: 13.747744798660278\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:17<03:26, 13.75s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.269216, Accuracy: 94.160004\n",
      "Per epoch time: 13.545521974563599\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:30<03:11, 13.70s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.258920, Accuracy: 94.419998\n",
      "Per epoch time: 13.491180419921875\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:44<02:57, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.241931, Accuracy: 94.860001\n",
      "Per epoch time: 13.435319900512695\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:57<02:43, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.240350, Accuracy: 94.889999\n",
      "Per epoch time: 13.526465654373169\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:11<02:30, 13.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.230326, Accuracy: 95.330002\n",
      "Per epoch time: 13.697857856750488\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:25<02:16, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.225289, Accuracy: 95.440002\n",
      "Per epoch time: 13.50563383102417\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:38<02:02, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.216740, Accuracy: 95.650002\n",
      "Per epoch time: 13.533373594284058\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:52<01:49, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.224271, Accuracy: 95.550003\n",
      "Per epoch time: 13.505680084228516\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:06<01:35, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.209549, Accuracy: 95.860001\n",
      "Per epoch time: 13.482141256332397\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:19<01:21, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.201737, Accuracy: 95.990005\n",
      "Per epoch time: 13.599850177764893\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:33<01:08, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.197538, Accuracy: 96.090004\n",
      "Per epoch time: 13.469190835952759\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:46<00:54, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.199713, Accuracy: 96.000000\n",
      "Per epoch time: 13.456369161605835\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [05:00<00:40, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.190155, Accuracy: 96.130005\n",
      "Per epoch time: 13.565654516220093\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:14<00:27, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.186695, Accuracy: 96.130005\n",
      "Per epoch time: 13.528409957885742\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:28<00:13, 13.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.185001, Accuracy: 96.250000\n",
      "Per epoch time: 13.727408647537231\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:41<00:00, 13.66s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.184653, Accuracy: 96.300003\n",
      "Per epoch time: 13.49770188331604\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  15\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:25, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.612605, Accuracy: 79.470001\n",
      "Per epoch time: 13.491010665893555\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:12, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.362496, Accuracy: 89.410004\n",
      "Per epoch time: 13.494996547698975\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:58, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.318922, Accuracy: 91.549995\n",
      "Per epoch time: 13.469631910324097\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:46, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.298279, Accuracy: 92.379997\n",
      "Per epoch time: 13.642560958862305\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:08<04:32, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.282362, Accuracy: 93.220001\n",
      "Per epoch time: 13.559605360031128\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:19, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.267587, Accuracy: 93.790001\n",
      "Per epoch time: 13.595012903213501\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:05, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.254769, Accuracy: 94.290001\n",
      "Per epoch time: 13.575409889221191\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:49<03:52, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.251898, Accuracy: 94.419998\n",
      "Per epoch time: 13.567623138427734\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:38, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.249791, Accuracy: 94.660004\n",
      "Per epoch time: 13.56216049194336\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:16<03:25, 13.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.238099, Accuracy: 94.840004\n",
      "Per epoch time: 13.642489433288574\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:30<03:12, 13.74s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.231462, Accuracy: 95.070000\n",
      "Per epoch time: 13.767717599868774\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:58, 13.70s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.222438, Accuracy: 95.270004\n",
      "Per epoch time: 13.502328872680664\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:57<02:43, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.212568, Accuracy: 95.500000\n",
      "Per epoch time: 13.442004442214966\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:11<02:29, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.203644, Accuracy: 95.610001\n",
      "Per epoch time: 13.455184936523438\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:24<02:16, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.197135, Accuracy: 95.670006\n",
      "Per epoch time: 13.496231079101562\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:38<02:02, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.189915, Accuracy: 95.959999\n",
      "Per epoch time: 13.583406686782837\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:49, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.188872, Accuracy: 96.020004\n",
      "Per epoch time: 13.54734992980957\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:05<01:35, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.185299, Accuracy: 96.260002\n",
      "Per epoch time: 13.552720069885254\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:19<01:21, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.183624, Accuracy: 96.130005\n",
      "Per epoch time: 13.553112506866455\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:32<01:08, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.177795, Accuracy: 96.210007\n",
      "Per epoch time: 13.507269859313965\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:46<00:54, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.178191, Accuracy: 96.480003\n",
      "Per epoch time: 13.529509782791138\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [05:00<00:40, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.174844, Accuracy: 96.200005\n",
      "Per epoch time: 13.509990215301514\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:13<00:27, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.168924, Accuracy: 96.300003\n",
      "Per epoch time: 13.4917471408844\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:27<00:13, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.166775, Accuracy: 96.529999\n",
      "Per epoch time: 13.575206279754639\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:41<00:00, 13.64s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.159954, Accuracy: 96.730003\n",
      "Per epoch time: 13.654709577560425\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  16\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:26, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.585076, Accuracy: 81.309998\n",
      "Per epoch time: 13.503711462020874\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:11, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.449647, Accuracy: 87.959999\n",
      "Per epoch time: 13.4280686378479\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:58, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.418407, Accuracy: 90.190002\n",
      "Per epoch time: 13.510815382003784\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:45, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.385613, Accuracy: 91.409996\n",
      "Per epoch time: 13.534912824630737\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:07<04:31, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.374691, Accuracy: 91.919998\n",
      "Per epoch time: 13.43537449836731\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:18, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.360378, Accuracy: 92.559998\n",
      "Per epoch time: 13.546704769134521\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:04, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.347109, Accuracy: 93.199997\n",
      "Per epoch time: 13.526660442352295\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:51, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.327614, Accuracy: 93.320000\n",
      "Per epoch time: 13.616491794586182\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.306343, Accuracy: 93.760002\n",
      "Per epoch time: 13.468915462493896\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:16<03:26, 13.76s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.293392, Accuracy: 94.059998\n",
      "Per epoch time: 14.006731986999512\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:30<03:11, 13.69s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.283663, Accuracy: 94.320000\n",
      "Per epoch time: 13.435003280639648\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:57, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.269220, Accuracy: 94.590004\n",
      "Per epoch time: 13.439319610595703\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:57<02:44, 13.70s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.257543, Accuracy: 94.700005\n",
      "Per epoch time: 13.716948747634888\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:30, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.244837, Accuracy: 95.029999\n",
      "Per epoch time: 13.453433275222778\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:24<02:16, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.243672, Accuracy: 95.050003\n",
      "Per epoch time: 13.493294477462769\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:38<02:02, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.233646, Accuracy: 95.050003\n",
      "Per epoch time: 13.59044098854065\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:48, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.228421, Accuracy: 95.290001\n",
      "Per epoch time: 13.475458860397339\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:05<01:35, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.218950, Accuracy: 95.220001\n",
      "Per epoch time: 13.584795713424683\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.218108, Accuracy: 95.570000\n",
      "Per epoch time: 13.457394361495972\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:32<01:07, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.214466, Accuracy: 95.430000\n",
      "Per epoch time: 13.425122499465942\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:46<00:54, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.200147, Accuracy: 95.770004\n",
      "Per epoch time: 13.531352043151855\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:59<00:40, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.204214, Accuracy: 95.800003\n",
      "Per epoch time: 13.428201913833618\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:13<00:27, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.202885, Accuracy: 95.840004\n",
      "Per epoch time: 13.469258785247803\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:26<00:13, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.194657, Accuracy: 95.900002\n",
      "Per epoch time: 13.537054300308228\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:40<00:00, 13.62s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.190222, Accuracy: 96.060005\n",
      "Per epoch time: 13.507275581359863\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  17\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:24, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.709981, Accuracy: 76.470001\n",
      "Per epoch time: 13.423254013061523\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:11, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.520467, Accuracy: 84.799995\n",
      "Per epoch time: 13.493827819824219\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:41<05:01, 13.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.453345, Accuracy: 88.200005\n",
      "Per epoch time: 13.821184873580933\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:46, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.418618, Accuracy: 89.820000\n",
      "Per epoch time: 13.45188021659851\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:08<04:32, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.374837, Accuracy: 91.169998\n",
      "Per epoch time: 13.408648014068604\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:17, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.366799, Accuracy: 91.699997\n",
      "Per epoch time: 13.399635076522827\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:03, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.352365, Accuracy: 92.379997\n",
      "Per epoch time: 13.40831208229065\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:50, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.337996, Accuracy: 92.739998\n",
      "Per epoch time: 13.500157117843628\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.325492, Accuracy: 93.169998\n",
      "Per epoch time: 13.559333562850952\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:15<03:23, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.318231, Accuracy: 93.269997\n",
      "Per epoch time: 13.394217491149902\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:09, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.300084, Accuracy: 93.730003\n",
      "Per epoch time: 13.456279754638672\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:42<02:56, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.309427, Accuracy: 93.790001\n",
      "Per epoch time: 13.535520315170288\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:56<02:42, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.285758, Accuracy: 94.160004\n",
      "Per epoch time: 13.47366213798523\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:29, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.288926, Accuracy: 94.330002\n",
      "Per epoch time: 13.439669370651245\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:23<02:15, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.271961, Accuracy: 94.389999\n",
      "Per epoch time: 13.513214349746704\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.260469, Accuracy: 94.489998\n",
      "Per epoch time: 13.62927794456482\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:50<01:48, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.253858, Accuracy: 94.709999\n",
      "Per epoch time: 13.42359471321106\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:35, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.244651, Accuracy: 94.830002\n",
      "Per epoch time: 13.62399959564209\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.240671, Accuracy: 94.910004\n",
      "Per epoch time: 13.459019660949707\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:31<01:07, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.235448, Accuracy: 95.099998\n",
      "Per epoch time: 13.413748502731323\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:45<00:54, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.227069, Accuracy: 95.250000\n",
      "Per epoch time: 13.431731462478638\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:58<00:40, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.226069, Accuracy: 95.120003\n",
      "Per epoch time: 13.443484544754028\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:12<00:27, 13.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.223985, Accuracy: 95.389999\n",
      "Per epoch time: 13.363019704818726\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:25<00:13, 13.49s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.223220, Accuracy: 95.420006\n",
      "Per epoch time: 13.323435068130493\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:39<00:00, 13.56s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.209129, Accuracy: 95.630005\n",
      "Per epoch time: 13.38496470451355\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  18\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:32, 13.85s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.761763, Accuracy: 73.930000\n",
      "Per epoch time: 13.746351718902588\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:15, 13.73s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.451814, Accuracy: 86.559998\n",
      "Per epoch time: 13.56092619895935\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:41<05:00, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.391528, Accuracy: 89.650002\n",
      "Per epoch time: 13.492671728134155\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:45, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.364676, Accuracy: 90.820000\n",
      "Per epoch time: 13.349957466125488\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:08<04:30, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.338284, Accuracy: 91.809998\n",
      "Per epoch time: 13.413397789001465\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:17, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.324185, Accuracy: 92.459999\n",
      "Per epoch time: 13.476611137390137\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:03, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.301255, Accuracy: 93.309998\n",
      "Per epoch time: 13.388915300369263\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:50, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.287197, Accuracy: 93.809998\n",
      "Per epoch time: 13.454684734344482\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:36, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.282525, Accuracy: 94.029999\n",
      "Per epoch time: 13.45086932182312\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:15<03:23, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.265865, Accuracy: 94.389999\n",
      "Per epoch time: 13.484352827072144\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:10, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.255639, Accuracy: 94.690002\n",
      "Per epoch time: 13.547101259231567\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:42<02:56, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.236267, Accuracy: 94.919998\n",
      "Per epoch time: 13.450915336608887\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:56<02:42, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.230555, Accuracy: 95.160004\n",
      "Per epoch time: 13.498037576675415\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:29, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.230623, Accuracy: 95.130005\n",
      "Per epoch time: 13.640835046768188\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:23<02:15, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.224120, Accuracy: 95.240005\n",
      "Per epoch time: 13.411814451217651\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.218475, Accuracy: 95.450005\n",
      "Per epoch time: 13.571282863616943\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:48, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.211708, Accuracy: 95.540001\n",
      "Per epoch time: 13.563158512115479\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:35, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.200676, Accuracy: 95.720001\n",
      "Per epoch time: 13.467416286468506\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.200074, Accuracy: 95.720001\n",
      "Per epoch time: 13.55462384223938\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:32<01:08, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.188905, Accuracy: 95.860001\n",
      "Per epoch time: 13.645745277404785\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:45<00:54, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.186580, Accuracy: 95.910004\n",
      "Per epoch time: 13.609403610229492\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:59<00:40, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.182749, Accuracy: 96.110001\n",
      "Per epoch time: 13.492950916290283\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:12<00:27, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.186811, Accuracy: 96.050003\n",
      "Per epoch time: 13.43963360786438\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:26<00:13, 13.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.184031, Accuracy: 96.120003\n",
      "Per epoch time: 13.760408401489258\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:40<00:00, 13.62s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.183945, Accuracy: 96.139999\n",
      "Per epoch time: 13.604997634887695\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  19\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:27, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.717981, Accuracy: 77.200005\n",
      "Per epoch time: 13.538129329681396\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:11, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.451956, Accuracy: 87.379997\n",
      "Per epoch time: 13.428558588027954\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:58, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.387656, Accuracy: 90.279999\n",
      "Per epoch time: 13.466088056564331\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:44, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.348946, Accuracy: 91.430000\n",
      "Per epoch time: 13.445427417755127\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:07<04:30, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.325804, Accuracy: 92.150002\n",
      "Per epoch time: 13.387367963790894\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:16, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.305050, Accuracy: 92.940002\n",
      "Per epoch time: 13.420367240905762\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:34<04:03, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.293216, Accuracy: 93.199997\n",
      "Per epoch time: 13.446655035018921\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:49, 13.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.289334, Accuracy: 93.589996\n",
      "Per epoch time: 13.376487970352173\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:01<03:36, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.287850, Accuracy: 93.790001\n",
      "Per epoch time: 13.495874404907227\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:15<03:24, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.267184, Accuracy: 94.239998\n",
      "Per epoch time: 13.689830541610718\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:11, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.261432, Accuracy: 94.370003\n",
      "Per epoch time: 13.63310980796814\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:57, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.239675, Accuracy: 94.849998\n",
      "Per epoch time: 13.609504699707031\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:56<02:44, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.239379, Accuracy: 94.840004\n",
      "Per epoch time: 13.582398653030396\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:30, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.238030, Accuracy: 94.989998\n",
      "Per epoch time: 13.558297395706177\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:24<02:16, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.227534, Accuracy: 95.400002\n",
      "Per epoch time: 13.580540418624878\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.223187, Accuracy: 95.310005\n",
      "Per epoch time: 13.557949781417847\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:49, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.218621, Accuracy: 95.560005\n",
      "Per epoch time: 13.536121368408203\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:35, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.217742, Accuracy: 95.570000\n",
      "Per epoch time: 13.497424602508545\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.217140, Accuracy: 95.630005\n",
      "Per epoch time: 13.419957637786865\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:31<01:07, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.205775, Accuracy: 95.700005\n",
      "Per epoch time: 13.43829607963562\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:45<00:54, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.205918, Accuracy: 95.950005\n",
      "Per epoch time: 13.566568851470947\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:59<00:40, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.212714, Accuracy: 95.920006\n",
      "Per epoch time: 13.392812967300415\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:12<00:27, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.201336, Accuracy: 95.810005\n",
      "Per epoch time: 13.383866786956787\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:26<00:13, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.195683, Accuracy: 96.060005\n",
      "Per epoch time: 13.457801103591919\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:39<00:00, 13.59s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.199844, Accuracy: 96.110001\n",
      "Per epoch time: 13.520952939987183\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  20\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:23, 13.46s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.816212, Accuracy: 73.349998\n",
      "Per epoch time: 13.365261316299438\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:26<05:10, 13.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.582047, Accuracy: 82.690002\n",
      "Per epoch time: 13.426620721817017\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:57, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.501700, Accuracy: 87.129997\n",
      "Per epoch time: 13.496504545211792\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:45, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.448662, Accuracy: 89.540001\n",
      "Per epoch time: 13.531976222991943\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:07<04:31, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.416360, Accuracy: 90.370003\n",
      "Per epoch time: 13.498530626296997\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:17, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.389925, Accuracy: 91.180000\n",
      "Per epoch time: 13.373677253723145\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:34<04:04, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.375437, Accuracy: 91.709999\n",
      "Per epoch time: 13.599328517913818\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:50, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.339326, Accuracy: 92.489998\n",
      "Per epoch time: 13.413996458053589\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:01<03:36, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.315558, Accuracy: 93.099998\n",
      "Per epoch time: 13.467801570892334\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:15<03:23, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.331517, Accuracy: 93.019997\n",
      "Per epoch time: 13.474684000015259\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:09, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.313883, Accuracy: 93.269997\n",
      "Per epoch time: 13.49863600730896\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:42<02:56, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.301018, Accuracy: 93.739998\n",
      "Per epoch time: 13.542024612426758\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:56<02:44, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.292982, Accuracy: 94.019997\n",
      "Per epoch time: 13.786482810974121\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:30, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.279410, Accuracy: 94.169998\n",
      "Per epoch time: 13.583697319030762\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:23<02:16, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.291881, Accuracy: 94.080002\n",
      "Per epoch time: 13.450141191482544\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.274172, Accuracy: 94.389999\n",
      "Per epoch time: 13.50666332244873\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:50<01:48, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.264054, Accuracy: 94.559998\n",
      "Per epoch time: 13.455506563186646\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:35, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.252174, Accuracy: 94.779999\n",
      "Per epoch time: 13.445086479187012\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.253708, Accuracy: 94.840004\n",
      "Per epoch time: 13.395265102386475\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:31<01:07, 13.52s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.251350, Accuracy: 94.750000\n",
      "Per epoch time: 13.358250379562378\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:45<00:54, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.240503, Accuracy: 95.139999\n",
      "Per epoch time: 13.502324342727661\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:58<00:40, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.234490, Accuracy: 95.279999\n",
      "Per epoch time: 13.422778606414795\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:12<00:27, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.234804, Accuracy: 95.180000\n",
      "Per epoch time: 13.634153842926025\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:25<00:13, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.225428, Accuracy: 95.470001\n",
      "Per epoch time: 13.43876338005066\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:39<00:00, 13.58s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.227518, Accuracy: 95.480003\n",
      "Per epoch time: 13.47337555885315\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  21\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:26, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.828512, Accuracy: 71.660004\n",
      "Per epoch time: 13.497288227081299\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:13, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.467804, Accuracy: 86.709999\n",
      "Per epoch time: 13.559463262557983\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<05:00, 13.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.440766, Accuracy: 88.730003\n",
      "Per epoch time: 13.664438486099243\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:45, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.421015, Accuracy: 90.130005\n",
      "Per epoch time: 13.391011714935303\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:08<04:32, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.392645, Accuracy: 91.019997\n",
      "Per epoch time: 13.497809648513794\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:19, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.379978, Accuracy: 92.009995\n",
      "Per epoch time: 13.582329750061035\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:07, 13.74s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.360572, Accuracy: 92.389999\n",
      "Per epoch time: 13.867584705352783\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:49<03:52, 13.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.338163, Accuracy: 93.059998\n",
      "Per epoch time: 13.461729526519775\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.334588, Accuracy: 93.229996\n",
      "Per epoch time: 13.411395072937012\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:16<03:24, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.315581, Accuracy: 93.709999\n",
      "Per epoch time: 13.539753437042236\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:10, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.306033, Accuracy: 93.910004\n",
      "Per epoch time: 13.382971286773682\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:56, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.303549, Accuracy: 94.050003\n",
      "Per epoch time: 13.422478199005127\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:56<02:42, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.295257, Accuracy: 94.190002\n",
      "Per epoch time: 13.485835790634155\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:29, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.284557, Accuracy: 94.379997\n",
      "Per epoch time: 13.413917779922485\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:23<02:15, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.273364, Accuracy: 94.480003\n",
      "Per epoch time: 13.392740249633789\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.265276, Accuracy: 94.760002\n",
      "Per epoch time: 13.668819665908813\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:48, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.253757, Accuracy: 95.020004\n",
      "Per epoch time: 13.442835330963135\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:04<01:35, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.247889, Accuracy: 95.070000\n",
      "Per epoch time: 13.461114645004272\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.246631, Accuracy: 95.169998\n",
      "Per epoch time: 13.498782634735107\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:31<01:07, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.241782, Accuracy: 95.070000\n",
      "Per epoch time: 13.413098812103271\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:45<00:54, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.232453, Accuracy: 95.340004\n",
      "Per epoch time: 13.372510194778442\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:58<00:40, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.230123, Accuracy: 95.310005\n",
      "Per epoch time: 13.444440841674805\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:12<00:27, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.222832, Accuracy: 95.630005\n",
      "Per epoch time: 13.479272842407227\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:26<00:13, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.216170, Accuracy: 95.440002\n",
      "Per epoch time: 13.627957582473755\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:39<00:00, 13.60s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.214112, Accuracy: 95.680000\n",
      "Per epoch time: 13.638203620910645\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  22\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:31, 13.82s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.510261, Accuracy: 84.939995\n",
      "Per epoch time: 13.730299711227417\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:14, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.378276, Accuracy: 90.050003\n",
      "Per epoch time: 13.458021402359009\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<05:00, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.353671, Accuracy: 91.720001\n",
      "Per epoch time: 13.511727571487427\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:45, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.331029, Accuracy: 92.760002\n",
      "Per epoch time: 13.4282386302948\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:08<04:31, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.328523, Accuracy: 92.879997\n",
      "Per epoch time: 13.49033498764038\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:18, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.313578, Accuracy: 93.529999\n",
      "Per epoch time: 13.569480895996094\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:04, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.303910, Accuracy: 93.800003\n",
      "Per epoch time: 13.492922306060791\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:51, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.288625, Accuracy: 94.120003\n",
      "Per epoch time: 13.548643350601196\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.286918, Accuracy: 94.260002\n",
      "Per epoch time: 13.513048648834229\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:16<03:23, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.273144, Accuracy: 94.529999\n",
      "Per epoch time: 13.46455693244934\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:10, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.266717, Accuracy: 94.580002\n",
      "Per epoch time: 13.500377178192139\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:56, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.261180, Accuracy: 94.779999\n",
      "Per epoch time: 13.567782163619995\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:56<02:43, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.256583, Accuracy: 94.950005\n",
      "Per epoch time: 13.438682079315186\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:30, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.240493, Accuracy: 95.150002\n",
      "Per epoch time: 13.727335214614868\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:24<02:16, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.237399, Accuracy: 95.190002\n",
      "Per epoch time: 13.528682708740234\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.223265, Accuracy: 95.420006\n",
      "Per epoch time: 13.429547548294067\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:48, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.222317, Accuracy: 95.610001\n",
      "Per epoch time: 13.55490493774414\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:05<01:35, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.208886, Accuracy: 95.590004\n",
      "Per epoch time: 13.501803159713745\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.204646, Accuracy: 95.740005\n",
      "Per epoch time: 13.534470558166504\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:32<01:08, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.204489, Accuracy: 95.900002\n",
      "Per epoch time: 13.609321594238281\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:46<00:54, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.203167, Accuracy: 96.030006\n",
      "Per epoch time: 13.519678592681885\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:59<00:40, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.198873, Accuracy: 96.060005\n",
      "Per epoch time: 13.418787717819214\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:13<00:27, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.190356, Accuracy: 96.120003\n",
      "Per epoch time: 13.646148443222046\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:26<00:13, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.184538, Accuracy: 96.200005\n",
      "Per epoch time: 13.520942211151123\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:40<00:00, 13.62s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.181281, Accuracy: 96.290001\n",
      "Per epoch time: 13.490348100662231\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  23\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:27, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.735863, Accuracy: 74.250000\n",
      "Per epoch time: 13.548787593841553\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:12, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.479357, Accuracy: 85.989998\n",
      "Per epoch time: 13.456655025482178\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:58, 13.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.434761, Accuracy: 88.959999\n",
      "Per epoch time: 13.407610416412354\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:44, 13.54s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.427214, Accuracy: 90.100006\n",
      "Per epoch time: 13.423239469528198\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:07<04:30, 13.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.392207, Accuracy: 90.979996\n",
      "Per epoch time: 13.428330898284912\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:17, 13.56s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.387345, Accuracy: 91.589996\n",
      "Per epoch time: 13.5279541015625\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:34<04:04, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.361940, Accuracy: 92.290001\n",
      "Per epoch time: 13.553618669509888\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:51, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.338526, Accuracy: 92.830002\n",
      "Per epoch time: 13.508796215057373\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.60s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.317562, Accuracy: 93.300003\n",
      "Per epoch time: 13.529906272888184\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:16<03:25, 13.70s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.299391, Accuracy: 93.900002\n",
      "Per epoch time: 13.821441411972046\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:11, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.292117, Accuracy: 93.900002\n",
      "Per epoch time: 13.546656847000122\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:57, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.282918, Accuracy: 94.199997\n",
      "Per epoch time: 13.571808338165283\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:56<02:43, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.279907, Accuracy: 94.160004\n",
      "Per epoch time: 13.475808143615723\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:29, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.272386, Accuracy: 94.570000\n",
      "Per epoch time: 13.473921298980713\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:24<02:16, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.280780, Accuracy: 94.230003\n",
      "Per epoch time: 13.522961854934692\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.249538, Accuracy: 94.900002\n",
      "Per epoch time: 13.558489561080933\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:48, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.242563, Accuracy: 95.120003\n",
      "Per epoch time: 13.511337757110596\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:05<01:35, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.245866, Accuracy: 95.099998\n",
      "Per epoch time: 13.582187414169312\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:22, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.229830, Accuracy: 95.459999\n",
      "Per epoch time: 13.672196626663208\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:32<01:08, 13.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.219721, Accuracy: 95.459999\n",
      "Per epoch time: 13.580277919769287\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:46<00:54, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.213076, Accuracy: 95.639999\n",
      "Per epoch time: 13.459362268447876\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:59<00:40, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.214792, Accuracy: 95.800003\n",
      "Per epoch time: 13.448040246963501\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:13<00:27, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.201578, Accuracy: 95.850006\n",
      "Per epoch time: 13.467355966567993\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:26<00:13, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.199807, Accuracy: 96.040001\n",
      "Per epoch time: 13.571643114089966\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:40<00:00, 13.62s/it]\n",
      "  0%|                                                                                           | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.191908, Accuracy: 96.110001\n",
      "Per epoch time: 13.67914891242981\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "Starting run  24\n",
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|███▎                                                                               | 1/25 [00:13<05:26, 13.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.645570, Accuracy: 80.959999\n",
      "Per epoch time: 13.513692617416382\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|██████▋                                                                            | 2/25 [00:27<05:12, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.479787, Accuracy: 87.559998\n",
      "Per epoch time: 13.474576711654663\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█████████▉                                                                         | 3/25 [00:40<04:59, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.434339, Accuracy: 89.900002\n",
      "Per epoch time: 13.502753973007202\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█████████████▎                                                                     | 4/25 [00:54<04:46, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 0.410017, Accuracy: 91.139999\n",
      "Per epoch time: 13.590678453445435\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|████████████████▌                                                                  | 5/25 [01:07<04:31, 13.59s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 0.389398, Accuracy: 91.759995\n",
      "Per epoch time: 13.423031568527222\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|███████████████████▉                                                               | 6/25 [01:21<04:18, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 0.355658, Accuracy: 92.510002\n",
      "Per epoch time: 13.478837490081787\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 28%|███████████████████████▏                                                           | 7/25 [01:35<04:04, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 0.341926, Accuracy: 92.860001\n",
      "Per epoch time: 13.45629096031189\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 32%|██████████████████████████▌                                                        | 8/25 [01:48<03:50, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 0.324478, Accuracy: 93.400002\n",
      "Per epoch time: 13.468414545059204\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 36%|█████████████████████████████▉                                                     | 9/25 [02:02<03:37, 13.57s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 0.312141, Accuracy: 93.669998\n",
      "Per epoch time: 13.463607788085938\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████████████████████████████████▊                                                 | 10/25 [02:15<03:23, 13.58s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 0.296991, Accuracy: 93.910004\n",
      "Per epoch time: 13.518314838409424\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████████████████████████████████████                                              | 11/25 [02:29<03:10, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.288792, Accuracy: 94.070000\n",
      "Per epoch time: 13.609885692596436\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 48%|███████████████████████████████████████▎                                          | 12/25 [02:43<02:57, 13.69s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 0.287466, Accuracy: 94.230003\n",
      "Per epoch time: 13.778863430023193\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|██████████████████████████████████████████▋                                       | 13/25 [02:57<02:44, 13.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 0.274583, Accuracy: 94.489998\n",
      "Per epoch time: 13.539104700088501\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████████████████████████████████████████████▉                                    | 14/25 [03:10<02:30, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 0.268366, Accuracy: 94.639999\n",
      "Per epoch time: 13.542971134185791\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|█████████████████████████████████████████████████▏                                | 15/25 [03:24<02:16, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 0.253645, Accuracy: 94.910004\n",
      "Per epoch time: 13.58309555053711\n",
      "\n",
      "\n",
      "Starting epoch 16....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 64%|████████████████████████████████████████████████████▍                             | 16/25 [03:37<02:02, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Loss: 0.248312, Accuracy: 94.980003\n",
      "Per epoch time: 13.510403394699097\n",
      "\n",
      "\n",
      "Starting epoch 17....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 68%|███████████████████████████████████████████████████████▊                          | 17/25 [03:51<01:49, 13.66s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Loss: 0.245945, Accuracy: 95.190002\n",
      "Per epoch time: 13.599194765090942\n",
      "\n",
      "\n",
      "Starting epoch 18....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████████████████████████████████████████████████████████                       | 18/25 [04:05<01:35, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Loss: 0.239374, Accuracy: 95.010002\n",
      "Per epoch time: 13.519574165344238\n",
      "\n",
      "\n",
      "Starting epoch 19....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|██████████████████████████████████████████████████████████████▎                   | 19/25 [04:18<01:21, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Loss: 0.240180, Accuracy: 95.279999\n",
      "Per epoch time: 13.495980262756348\n",
      "\n",
      "\n",
      "Starting epoch 20....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|█████████████████████████████████████████████████████████████████▌                | 20/25 [04:32<01:08, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Loss: 0.225661, Accuracy: 95.340004\n",
      "Per epoch time: 13.51291012763977\n",
      "\n",
      "\n",
      "Starting epoch 21....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████████████████████████████████████████████████████████████████▉             | 21/25 [04:46<00:54, 13.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Loss: 0.220542, Accuracy: 95.599998\n",
      "Per epoch time: 13.582812070846558\n",
      "\n",
      "\n",
      "Starting epoch 22....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████████████████████████████████████████████████████████████████████▏         | 22/25 [04:59<00:40, 13.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Loss: 0.211581, Accuracy: 95.760002\n",
      "Per epoch time: 13.58001708984375\n",
      "\n",
      "\n",
      "Starting epoch 23....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 92%|███████████████████████████████████████████████████████████████████████████▍      | 23/25 [05:13<00:27, 13.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Loss: 0.203584, Accuracy: 95.950005\n",
      "Per epoch time: 13.477386474609375\n",
      "\n",
      "\n",
      "Starting epoch 24....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 96%|██████████████████████████████████████████████████████████████████████████████▋   | 24/25 [05:26<00:13, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Loss: 0.199834, Accuracy: 95.880005\n",
      "Per epoch time: 13.510083675384521\n",
      "\n",
      "\n",
      "Starting epoch 25....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 25/25 [05:40<00:00, 13.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Loss: 0.195303, Accuracy: 95.959999\n",
      "Per epoch time: 13.561143636703491\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABBQAAAK+CAYAAAASSE0uAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAewgAAHsIBbtB1PgAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOzdeZRl10Ef6t+uubt6UKtbrbE1WZZaNtiWjYxtbGtMXoLDEF4IDmDjgSEGFiTAgrzkBQwsTEJwYhZTEjC2GRMnTI84EJAsjxhLtoWNQVJrtFrW0LN6rHm/P+6tqlvV4+muqttV9X1r3XXO2Wffs3drSXaf391DqbUGAAAAoImebncAAAAAWH4ECgAAAEBjAgUAAACgMYECAAAA0JhAAQAAAGhMoAAAAAA0JlAAAAAAGhMoAAAAAI0JFAAAAIDGBAoAAABAYwIFAAAAoDGBAgAAANCYQAEAAABoTKAAAAAANCZQAAAAABoTKAAAAACNCRQAAACAxgQKAAAAQGMCBQAAAKAxgQIAAADQ2KIGCqWUraWUf1RK+alSyp+WUvaUUmr78/5FavONpZT/U0p5ppQyUkp5opTyW6WUVy1GewAAALAa9S3y859b5OfPKKUMJfkfSf7RvFtXtT/fWkp5Z631p5eqTwAAALBSLeWUh51J/nwRn//ezIYJ9yT5xiSvTPL2JI+m9Wf9qVLKdy5iHwAAAGBVKLXWxXt4KT+Z5L4k99VanyulXJ3k8fbtD9Ra37JA7dyS5CPtyz9J8o9rrZMd97ck+WySK5PsT3JtrfXAQrQNAAAAq9GijlCotf5ErfV/1VoXe+rDj7aPk0m+tzNMaPdjT5Ifa19uSmvUAgAAAHCWlv0uD6WUdUnuaF/+Ra31qZNU/YMkB9vn37ToHQMAAIAVbNkHCmmtkzDYPv/oySrVWseS/NX0d0op/YvdMQAAAFipVkKgcGPH+YOnqTt9vy/JCxenOwAAALDyLfa2kUthW8f5yaY7TNs573t/d6aNlFKuOE2VgSTbk+xKsjut9RwAAABgsfQmuah9/je11tGlbHwlBArrO84Pn6bukY7zdQ3b2Xn6KgAAANAVNyf5zFI2uBKmPAx1nI+dpm5nWrNmEfoCAAAAq8JKGKEw0nE+cJq6gx3nxxq2s+009y9Pe9HHe++9N5deemnDxwMAAMCZe+aZZ/LKV75y+nL3Ure/EgKFQx3np5vGMNxxfrrpEXOcYjvKJEkpZeb80ksvzRVXnG7JBQAAAFgwS76O30qY8tD5on+6t/jOUQbWRAAAAICztBIChc6dGrafpu70/YkkjyxOdwAAAGDlWwmBwn2ZXYzxlpNVKqUMJHnV9HdqradbwBEAAAA4iWUfKNRaDyW5u315ZynlZNMevinJhvb5Hy56xwAAAGAFO+8DhVLKW0optf1550mq/Xz72Jfkl0spvfOesSXJv29fHkjy64vSWQAAAFglFnWXh1LKa5Nc11G0peP8ulLKWzrr11rffzbt1Fo/XEr5b0nemOTrk/xFKeU9SZ5O8pVJ/k2SK9vV/1Wtdf/ZtAMAAAC0LPa2kd+Z5DtOcu9r2p9O7z+Htt6W1pSGr01yW/vTaSrJT9da/8s5tAEAAABkGUx5OFO11mO11jck+bYkf5FkV1qLNe5M8rtJXltrfWf3eggAAAArR6m1drsPK0J7McidSbJz585cccXJ1oYEAACAc/fUU09l27Zt05fbaq1PLWX7K2aEAgAAALB0BAoAAABAYwIFAAAAoDGBAgAAANCYQAEAAABoTKAAAAAANCZQAAAAABoTKAAAAACNCRQAAACAxgQKAAAAQGMCBQAAAKAxgQIAAADQmEABAAAAaEygAAAAADQmUAAAAAAaEygAAAAAjQkUAAAAgMYECgAAAEBjAgUAAACgMYECAAAA0JhAAQAAAGhMoAAAAAA0JlAAAAAAGhMoAAAAAI0JFAAAAIDGBAoAAABAYwIFAAAAoDGBAgAAANCYQAEAAABoTKAAAAAANCZQAAAAABoTKAAAAACN9XW7AwAAANBNtdZMTNWMTUxldGIqY+3P6MRkLt44lA1D/d3u4nlJoAAAAEBXTE7VjE5MznmRH52Y7DifexybnMzo+FTGJmfLO783dlz9E5fPfm+yXWcqtZ64j7/4z27K1730sqX9B7NMCBQAAABWkampmvGpqYxP1oxPv3SPt17WR8Y7r6cyOj556uvOEGB8KqOnrDs/OJjK5NRJ3uLPI2MTU93uwnlLoAAAAHCOJqdqxtsv2OOTrc9Y+7xVVmfKxianMt5R1vqc+HxscioTndcTNRNTs+fT5ROTtfXcE17PffZyeIk/n4xNChRORqAAAAAsW7XWjE5M5djYZI6OT+bY2ESOjk12XE+2rscnZ36Nnz62zmvGJifbx7n3ZwOAelzZ3PDAS/pKNi5QOCmBAgAAsKgmp2qOjk3MvNy3XvAncmxsqlU+3lHeDgSOjk1mZHxu/ZmgYM79iXiXX3n6ekoG+noy0NeTwfZxoLcng329c8oHZ857M9A7r37fievPPq83g/09J/3eYLvNnp7S7X8c5y2BAgAArBK11oxPthbBGxmfOuFxdHwqI+OtRfHO5Nj5vfnPG5lovfibg758TL/ID857IR+c83Lfe9zL/OBxdeZ+98TPmfvdzpf/Xi/xy4JAAQAAumR6uP70i/nIeGto/sz1xGRGxiZbx/HWsP7p89H5ddvXoxOteyd78fdr/tLr7Snp7y3p7229OPf3Tn/KcecD7ft9PSX97V/I+3tL+npnz/t7e9rXx3+/v7cn/X096e8ps+e9JQPt70yft54x26fpEQB9vT3d/sfFMiJQAACAtqmpmpHpX+knZl/UO1/IZ4+d96frzy+ffumffbmfDQVa5Sy8gd6erBnozdqB3tljf+/My/pA+0V7cOYFvGSgt7d9nL0/eyzHfXeg4+W/dT43EBiYCQP82s7KJVAAAOC8NjVVc3R8MkdGJ9qfyRwZmzhuuP3ICV7yO4fej3beO0FoML21HYuvlGRtf2/WDPRlbceL/5r+6fO+9v3ejvt9Hfc7yvtnnzE00Ju1/b1+ZYclIlAAAGDBTA/hPzw6kaPtF/8joxM5MjYbCBwdm2zdH2uHAycq67h3bHyy23+sFa+vp2SwrydD/b0zx4F51/OPQ/2tOe/zj4Md10P9Jw4EBvt6Uopf7WG5EygAAKxyoxOTOTzSeoE/NDo+8yJ/qB0AHB6ZyOHp0QHtF/2jYxPtAGByTnhwdGzS9nnnqJRkqOOFfE1/bwbbL/BDfa1f56fPB9v3p+vOHOe92B937O/NUN/s0S/6wNkQKAAALDOdowCOjLZe7A+PtF72D7WDgcOj4zncDgYOj0zk8Fi7znT9ju+OTwoATmX6BX+w/RI//dLe+VK+puNFfs1AZ92Oe3Ne/Gev10yfz4QAfr0HlgeBAgDAEpiaqjO/7s/82j/9Yj82MfPyPz8g6Cw/NF02MpGJVTwKoK+nzMyjn34Rn/nVfd4v7/Nf4gePu3f8r/pzn9daWM8LPsDxBAoAACdQa83I+NxRAEdO8vLfOk4eFxJ0hgdHx1bnOgClJMMDfRke7G0fWwvoDQ+2zoenzwd6s7ajbO1AX9YN9mXtYG/rODD7/YE+w/MBzgcCBQBgxam15ujYZA6OjOfQyEQOjYzn4MhEDh6bvp4um72evTeeQ6Ordy2AnpKsG2y9zA8P9mXdUN/Mdeslf24YsHawbzYw6DifDgSG+v26D7BSCRQAgPPK9PoA0y/7pwsBDk6HACMTM/cOj06sqjCgt6dkeKA364f6M9z+RX94sC/rh/pmftVfP9QOCDo+M9dDrRBg/WC/AACAMyZQAAAWVK01h9vz/Q+OjOfgsekX//GZcGCmfGR85rwzFFgNiwQO9vXMvNS3Xuxnf/lfNzC3bHqUwPDA3BED00GBRfwA6AaBAgAwx9RUzaHRzhBgYs5ogTlhQGdA0BEMrMTBAdOjAOaGALND/Tt/8Z9eF+BEdafL+m3TB8AyJ1AAgBVqcqrm+WPj2XdkNPuOjGffkbHsOzKW/UfHsvfwWA4cGzs+GDg2nsNjE6krLBCYng6wfqgvG9a0jjPXM8fZe+sG504dWDdoFAAAzCdQAIBlYHqRwZlA4MhY9rcDgs6QYP/R2bIDx8ZXRDAw2NeT9UP92bCmFQJs6AgBpoOBDR0BwXTd6TrrBvvSZzQAACw4gQIAdMHE5FT2Hx2fEwScKCTY13E9OjHV7W6flelRANO//m/oeOHfsGZuQNA5emA6JLBFIACcnwQKALAAxiensv9IKxTYe3gse4+MZu/hVhCw98ho9hyeGw48f2y8210+Iz0l7Zf+k4UBs0HAhpnj7GiCdYN96e0xTQAAViKBAgCcwORUnRkhsOdwRzhweHQmNNh3ZCx72sHB+R4QrB/sy6bhgVzY/mxaO5ALh/tng4GThATDA73WDQAATkigAMCqMNVeoHB65MDemdEEo+2goBUc7GuX7z86dt6uP9DfW9qBQDscGB7I5nZIsHndwJx7Fw4P5IK1/Rns6+12twGAFUagAMCyVWvNgaPj2X14NLsPtT57Os6ny/e01yiYPE/3Mty4pr89aqA/Fw4P5sLh/lOGBOsG+4waAAC6TqAAwHml1pojY5OzocBJQoLdh0az98hoxifPr5CglLRCgPbL/5Z1g7lwuBUKtMoGjxs90G8HAgBgGRIoALAkRsYnZ4KBPYfHOgKCkY7goFV+bHyy292dY+Oa/mxeN5Atw3PDgc1zwoLBmZEEFiEEAFYDgQIA52RsYiq7Do3kmedbn2efP5Znnh85bmTBwZGJbnd1xvqhvjmBwJZ2IDA/HNjcXp/ACAIAgOMJFAA4qdGJyTz3/Gieef5Ynj04kqcPzAYGzx5sBQh7Do+eF4sXblrbn4vWD2bLusFctH4wF00f1w9m87rBbG5PP9g0bIFCAICFIFAAWKWOjU22Q4FjeXZmdEHrevp875GxrvZxeKB3JhToDAm2dIQFF60fzObhwQz0GUUAALCUBAoAK9CR0Yk5AcGzz4/kmYMjM8HBM88fy4Gj413p20BvTzsUGDguKJj+bFnX+gwP+r8pAIDzlb+pASxD45NTeWr/sTyx50ge23MkT+w5kif3HZ0JELqxXsFgX08uu2BNLtkwlEs2DmXrhrlBwdb1g7lo3VA2rLHlIQDASiBQADhPTU7VPH3gWJ7YeySP72l9nmgfn9p/LBNTS7dwwdqB3ly6cSiXblyTSzYO5dKNQ7PHDWty2QVD2bimX1AAALCKCBQAuqjWmucOjs4GBntng4Mv7T2ascmpRe/D+qG+dkCwJpduGJoXGKzJpRcMZf2gUQUAAMwlUABYZLXW7D0yNmd6Qis4OJon9hzJsfHJRWv7grX9uWTD0Gxg0DGyYLpsnXUKAAA4C/4WCbBAnj86nsf3Hsnjew7PhAVP7D2Sx3cfyaHRxVnTYNPa/ly9ZTjXbBnO1ZuHc/kFs6HBJRuHsnbA/8wDALA4/E0ToIGpqZqn9h/LjucO5aHnDuXR3Ydn1jXYv0i7Jqwf7JsNDbYM55ota3PNlnW5ZvNwNq7tX5Q2AQDgdAQKACcwvbbBQ88dyo5nW+HBw88dyo7nDi/KFIU1/b25avPaXHtRa6TB1VuGc207QNg8PGD9AgAAzjsCBWDV23t4NjjYsevwTIBwaIG3Xhzo7cmVm9fmmo4pCtPnF28YFBoAALCsCBSAVeP5Y+Mzowx2PHcoDz17KA/vOpQ9h8cWrI3enpJtm9Z0TE+YDQ8uu2BNenuEBgAArAwCBWDFOTo2kUd2Hc5Dzx7Kjo4A4ZnnRxasjQvW9uf6i9fn+ovX5Zot62amJ1yxaU36e3sWrB0AADhfCRSAZWt0YjKP7T7SDg0O5aFnW8HBzv1HU+vCtDE80JvrL1mfGy5enxde3Dpef8m6XLTOFAUAAFY3gQKwLDx/bDyf33kgf73zQB589mAeevZQnth7NJNTC5McDPb15IUXr8v1W9fPBAjXX7I+l20cEhwAAMAJCBSA887E5FR2PHc49+/cn/ufPJD7n9yfR3cfWZBn9/WUXHvRcK6/eDY0uP7i9bnywrXWNwAAgAYECkDX7To0kvufbI0+uP/J/fnCU8/n6Ni5bc1YSnL15uFcf/G62ekKl6zP1ZuHM9BnjQMAADhXAgVgSY1OTOZvnz44M/Lg/icP5MsHjp3TMy+/YE1uuGR9XtgOD66/eH2u27ouQ/29C9RrAABgPoECsGhqrXlq/7F8rh0c3L/zQP7u6eczPnl26x4M9PXkKy/fmJdcsTHbL2mNOnjh1nVZP9S/wD0HAABOR6AALJjDoxP5ws5WcNCawrA/ew6PnfXzrrxwbW668oLctO2C3HTlptx46QbTFQAA4DwhUADOytRUzaO7D7dHHrRGIOx47lDOdtOFdYN9eem2jblp26a8bNsFedmVF2TLusGF7TQAALBgBArAGdl3ZCx/PbPrwoF8fueBHBqdOKtnlZK8cOu63LRtU2sEwpWbct3WdXZZAACAZUSgAJzQsbHJfOqxPfnwg7vyiYf35Im9R8/6WRcOD7SnLbTCg5dcsdG6BwAAsMwJFIAZO/cdzT0P7cqHH9yVTz26N6MTU42f0ddT8qLLNsyse3DTlRfkygvXphSjDwAAYCURKMAqNj45lc9+aX/uebAVIjy863DjZ1y2cWgmOLjpygvy4ss22q4RAABWAYECrDJ7Do/mIw/tzj0P7srHHt6dQyNnvg7CUH9PXnL5BTPhwcu2bcolG4cWsbcAAMD5SqAAK9zUVM0Xn34+H35wV+55aHe+8NSB1DPciaGnJK+4alNu2741r7vuomy/dH36e23bCAAACBRgRTo0Mp6PP7wn97RDhD2HR8/4u5vW9ufWG7bmtu1b8/oXbskFawcWsacAAMByJVCAFaDWmkd3H5lZC+G+J/ZlYuoMhyEkefFlG3L79q259Yatedm2C2zfCAAAnJZAAZapkfHJ/NVje2dGITy578y3dVw70JvXXrclt29vjUS4eIN1EAAAgGYECrCMPH3gWO55aFfueXBXPvnI3hwbnzzj716zZTi33bA1t2/fmpuv2ZTBPjsxAAAAZ0+gAOexicmp3L/zQGtBxQd35cFnD53xdwd6e/LV116Y29rrIVyzZXgRewoAAKw2AgU4z0xN1Xz4wV35488/nY/t2J3nj42f8Xcv3jA4sxbCa6/bkuFB/4kDAACLw9sGnCcmJqfyob95Jr9yz6N56LkzG4nQU5KbrtyU2264KLdt35oXXbohpVhQEQAAWHwCBeiy0YnJ/P5nv5z//NFHz2hhxY1r+nPL9Rfl9u1b8/rrL8qFw7Z1BAAAlp5AAbrkyOhEfu/eJ/NrH38szx0cPWXd7Zesz+3bWwsqvmzbBenr7VmiXgIAAJyYQAGW2PNHx/OBTz2R933y8ew/evL1Ea6/eF3e9Oqrc8f2rbnsgjVL10EAAIAzIFCAJbLr0Eje+4nH89uf+lKOjJ18u8eXXrEx33fbdbnzxovT02M9BAAA4Py0ZIFCKeXKJD+Q5A1JrkwymuSRJB9M8iu11tNPHj99Gy9J8v1Jbk1yeZLJJDuTfCjJL9VanzzXNqCpp/YfzX/56GP575/ZmbGJqZPWe/W1m/N9t12Xr7lus4UVAQCA896SBAqllDck+Z0kGzuK1ya5uf35zlLK19ZaHzuHNn4yyb9NMv9N7EXtz/eUUt5Sa/3Ds20Dmnhk16H86kceyx//9ZczMVVPWu/OG7fmHbdel1dctWkJewcAAHBuFj1QKKW8NK1RCGuTHE7ys0nuSbImyRuTfFeSG5J8qJRyc6318Fm08a+S/Hj78pkk/yHJX7avX5PkR5NckuT3Sim311r/8vinwML4m6eez6985JH82d8+m3qSHKGnJP/oJZflHbe+IDdeumFpOwgAALAAlmKEwnvSChMmkvz9WuunOu59uJTycJKfS7I9yQ8l+akmDy+lXJ7kne3Lp5PcXGt9uqPKp0spH0xyb5LLkvxKKeXltdaTjz2Hs/Dpx/bmlz/yaD62Y/dJ6/T3lvzfL78i33PLC3LNluEl7B0AAMDCWtRAoZRyc1rrGSTJe+eFCdPeneStSW5M8i9KKT9baz350vfHe2OSwfb5T8wLE5IktdYvl1J+IsmvJXlpkn+Y1roKcE5qrfnIjt35lXseyX1P7D9pvaH+nnzrK6/Kd73+mly60Y4NAADA8rfYIxS+seP8fSeqUGudKqX8ZlpTITalFUD8RYM2bu44/9NT1PuzjvN/EoEC52ByqubPvvhsfvmeR/J3zxw8ab31Q315y2uuzltec3U2rxs8aT0AAIDlZrEDhde1j0eSfPYU9T7acf7aNAsULuw4f+4U9Trv3dLg+TBjbGIqf/TXX85//sijeWzPkZPW2zw8kLe/7pp8+6uuyoah/iXsIQAAwNJY7EDhxvbxkVrrxCnqPXiC75ypzre6jUn2nqRe5w4TV5dS1jbZqrKUcsVpqlxyps9i+RkZn8x/u/fJ/NePPZannx85ab3LNg7le255Qf7pV23LmoHeJewhAADA0lq0QKGUMpRkS/vyqVPVrbXuL6UcSTKcZFvDph7I7NSKW5L8wUnqvb6ze0muSLKjQTs7G/aLFeDgyHh++6++lN/4xOPZc3jspPWu3TKcd9z6gnzDyy7PQF/PEvYQAACgOxZzhML6jvMz2QpyOlBY17CdP07y/7TPf7yU8r9rrXN+Qm6HGz8+73vrAyex9/Bo3vfJJ/KBTz2RQyMnH1zzoks35Ptuuy7/4CsuSW9PWboOAgAAdNliBgpDHecn/2l31mj72GgJ/Frrp0sp/1+Sr09rB4ePllL+dZLpHSVeneRd7XtjSQbOpp2cfuTEJUnua/hMzjPPPH8s//Vjj+X37n0yI+Mn31n0q67alO+7/brcev1FKUWQAAAArD6LGSh0jhIYOGmtWdNL4B87i7a+I60dHl6V5JVJ7jpBnfuSfDGtLSqT5FCTBmqtp5y24aVyeTs0Mp5/96cP5oOf2ZnxyXrSeq+//qJ8/23X5ZXXXHjSOgAAAKvBYgYKnS/sZzKNYbh9PJPpEXPUWg+UUm5J8r1JvivJizpuP5vk15L8TJLf6Sjf37QdVqY9h0fzlvfdmy9++cTbP5aS/IMXX5LvvfW6fOUVG09YBwAAYLVZtECh1jpSStmT1sKMp9whoZSyKbOBwlktflhrHUvyniTvKaVsTLI1rXDi2Vprbbfzknb1QznNQpGsDk/tP5o3v/feE24B2dtT8o0vuzzvuPXaXLfVkhsAAACdFnvbyAeSvC7JdaWUvlNsHbl93nfOSa31+STPd5aVUi5Ocl378r5a68knyLMqPPzcobzpvffm2YNzt4Ec6OvJG2/elu963bXZduHaLvUOAADg/LbYgcIn0goUhpO8IsmnT1Lvlo7zTy5SX/5ZWttFJskHF6kNlon7n9yft77/vhw4Oj6n/IpNa/Jbb//qXLNl+CTfBAAAIEl6Fvn5f9Rx/tYTVSil9CR5c/vyQJJ7FroTpZQNSX6so43fXeg2WD4+/vDufNuvf/q4MOGGi9fn99/xGmECAADAGVjUQKHWem+Sj7cv315KefUJqv1wkhvb579Qa53zlldKeUsppbY/7zxRO6WUS0sp/Se5tz7J76e1rWOS/EittdEOD6wcH/rCM3nb++/L0bHJOeUvv/KC/PfveVUu3jB0km8CAADQabGnPCTJD6Y1jWFNkj8vpbwrrVEIa5K8Mcl3t+vtSPLus2zj25L8SCnlA0k+muSZJBvS2kbye5Nc2a73vlrre8+yDZa53/n0l/L//tEXU+ftCnnL9RflV7/95Vk7sBT/OQAAAKwMi/4GVWu9v5TyLUl+O62X/HedoNqOJG84x5EDFyf50fZnvom0wop/fQ7PZ5mqteZXPvJo/sP/eei4e1/30svy7m9+aQb6Fnv2DwAAwMqyJD/J1lr/pL1l4w8meUNa20iOJXkkyf9I8ku11qPn0MQfJBlKcnuSF6S1ZeRoWltD/nmS99Za//Ycns8yNTVV8zP/+4G89xOPH3fvTa+6Kj/59S9OT085wTcBAAA4lVLnj//mrJRSrkiyM0l27tyZK664oss9YnxyKj/2+1/IH3zuy8fd+4E7Xph/eecLU4owAQAAWJ6eeuqpbNu2bfpyW631qaVs36RxVqSR8cl8/+9+Lnc9sOu4ez/xdS/KW7/mmi70CgAAYOUQKLDiHBwZz3d+4DO59/F9c8r7ekp+/ptfmm+86fIu9QwAAGDlECiwouw+NJrv+I1783fPHJxTPtjXk1/99pfn9u0Xd6lnAAAAK4tAgRVj576jedN7P50n9s5d33P9UF9+4y035+arL+xSzwAAAFYegQIrwkPPHsqbf+PTee7g6JzyLesG81tvf2VuvHRDl3oGAACwMgkUWPY++6X9edv778vzx8bnlG+7cE1+++1fnas2D3epZwAAACuXQIFl7aM7duef/9Znc2x8ck759kvW5zff9sps3TDUpZ4BAACsbAIFlq0/+fzT+aEP/nXGJ+uc8q+6alPe+x03Z+Pa/i71DAAAYOUTKLAs/dZffSk//sdfTJ2bJeTWGy7Kr37bK7JmoLc7HQMAAFglBAosK7XW/OKHH8l//Isdx937hpddlp//5pemv7enCz0DAABYXQQKLBtTUzU//aG/y/s++cRx977j1VflJ77uxenpKUvfMQAAgFVIoMCyMD45lR/9n1/IH97/5ePu/cs7r88P3HFdShEmAAAALBWBAue9Y2OT+b7f/Vw+/OCuOeWlJD/59S/Om199dXc6BgAAsIoJFDivPX9sPN/5gfty3xP755T39ZS8+5++NN/wssu71DMAAIDVTaDAeWvXoZG8+b335sFnD80pH+rvya9++yty2w1bu9QzAAAABAqcl57cezRv+o1P50t7j84p3zDUl/e99ea84qoLu9QzAAAAEoEC56EHnz2YN7333uw+NDqnfOv6wfzm21+Z7Zds6FLPAAAAmCZQ4Lzy2S/ty1vfd18OjkzMKb9q89r81tu+OlduXtulngEAANBJoMB5454Hd+Udv/PZjIxPzSm/8Y+Bpj8AACAASURBVNIN+cDbbs7W9UNd6hkAAADzCRQ4L/zxX385P/zBz2diqs4pv/nqTfn177g5G9f0d6lnAAAAnIhAga77wF8+kXf+yd+mzs0Scvv2rfnlb3151gz0dqdjAAAAnJRAga6pteYX7n4477nr4ePu/eObLs/P/ZOXpL+3pws9AwAA4HQECnTNf/nYYycME976NVfn377hRenpKV3oFQAAAGdCoEBXHBmdyHvu2nFc+Q//vevz/bdfl1KECQAAAOczgQJd8fGH98zZzaGU5Ke+4Svypldd1cVeAQAAcKZMUKcr7n7guTnXr752szABAABgGREosOQmp2o+/OCuOWV33nhxl3oDAADA2RAosOT+eueB7D0yNqdMoAAAALC8CBRYcvOnO7xw67pcuXltl3oDAADA2RAosOTufmDudIc7jE4AAABYdgQKLKmd+47moecOzSm788atXeoNAAAAZ0ugwJKaP93hwuGB3HTlpi71BgAAgLMlUGBJ3TVvusNtN2xNb0/pUm8AAAA4WwIFlsyhkfF8+vG9c8pMdwAAAFieBAosmY/t2JPxyTpzPdDbk9ddf1EXewQAAMDZEiiwZOavn/DV116YdYN9XeoNAAAA50KgwJKYnKq556G56yfcabtIAACAZUugwJL43JP7s//o+JyyO6yfAAAAsGwJFFgSd/3d3OkO2y9Znys2re1SbwAAADhXAgWWxF3z1k8w3QEAAGB5Eyiw6J7YcySP7j4yp8x0BwAAgOVNoMCimz86Ycu6wbz0igu61BsAAAAWgkCBRXf3A3N3d7h9+0Xp6Sld6g0AAAALQaDAonr+6HjufWLfnDLrJwAAACx/AgUW1Ud27MrkVJ25HujryWtfuKWL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\n",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 351,
       "width": 522
      },
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "JLdim_list=[3]\n",
    "#print(batch_size,len(train_ds))\n",
    "for JL_dim in JLdim_list:\n",
    "    print('Starting JLdim ',JL_dim)\n",
    "    avg_accuracy_list=np.zeros(epochs)\n",
    "    \n",
    "    for run in range(num_runs):\n",
    "        print('Starting run ',run)\n",
    "        \n",
    "\n",
    "        model = get_MNIST_model()\n",
    "        n_var = len(model.trainable_variables)\n",
    "\n",
    "\n",
    "        loss_obj = tf.keras.losses.CategoricalCrossentropy(from_logits=True, reduction=tf.keras.losses.Reduction.NONE)\n",
    "        train_loss = tf.keras.metrics.Mean(name='train_loss')\n",
    "        train_accuracy = tf.keras.metrics.CategoricalAccuracy(name='train_accuracy')\n",
    "\n",
    "        accuracy_list=[]\n",
    "        epochtime_list=[]\n",
    "        epochJLtime_list=[]\n",
    "        #epsilon_list=[]\n",
    "\n",
    "        step=0\n",
    "        for i in tqdm(range(epochs)):\n",
    "\n",
    "            print(f'Starting epoch {i+1}....')\n",
    "    #         privacy_engine.add_epochs(1)\n",
    "    #         eps=privacy_engine.calculate_eps()\n",
    "    #         print('epsilon: ',eps)\n",
    "    #         epsilon_list.append(eps)\n",
    "\n",
    "\n",
    "\n",
    "            epochJL_time=0\n",
    "            epoch_start_time=time.time()\n",
    "            start_epoch_time=time.time()\n",
    "            for images,labels in train_ds:\n",
    "   \n",
    "                n_images = images.shape[0]\n",
    "\n",
    "                # Compute the mask\n",
    "                JL_time=time.time()\n",
    "                grad_norm = approximate_grad_norm(images, labels, model,loss_obj, JL_dim)\n",
    "                epochJL_time+=(time.time()-JL_time)\n",
    "                mask = tf.math.minimum(1.0, clipping_norm / grad_norm)\n",
    "\n",
    "\n",
    "                # Compute the gradient\n",
    "                with tf.GradientTape() as tape:\n",
    "                    predictions = model(images, training=True)\n",
    "                    loss_ind = loss_obj(labels, predictions)\n",
    "                    loss = tf.reduce_sum(mask * loss_ind) / batch_size\n",
    "                gradients = tape.gradient(loss, model.trainable_variables)\n",
    "\n",
    "                # Add the noise into the gradient\n",
    "                if sigma > 0.0:\n",
    "                    noise_level = sigma * clipping_norm/ batch_size\n",
    "                    for k in range(n_var):\n",
    "                        gradients[k] += noise_level * (tf.random.normal(gradients[k].shape, dtype=tf.float32))\n",
    "\n",
    "                # Run the gradient descent\n",
    "                k = 0\n",
    "                for p in model.trainable_variables:\n",
    "                    p.assign(p - lr * gradients[k])\n",
    "                    k = k + 1\n",
    "\n",
    "\n",
    "            epoch_time = time.time()-epoch_start_time\n",
    "            epochtime_list.append(epoch_time)\n",
    "            epochJLtime_list.append(epochJL_time)\n",
    "            # Record the result\n",
    "            for images, labels in test_ds:\n",
    "                predictions = model(images, training=False)\n",
    "                loss = loss_obj(labels, predictions)\n",
    "                train_loss(loss)\n",
    "                train_accuracy(labels, predictions)\n",
    "\n",
    "\n",
    "            print('Epoch %i, Loss: %f, Accuracy: %f' % \n",
    "                  (i + 1, train_loss.result(), train_accuracy.result() * 100))\n",
    "            accuracy_list.append(train_accuracy.result().numpy())\n",
    "            \n",
    "\n",
    "            train_loss.reset_states()\n",
    "            train_accuracy.reset_states()\n",
    "            print('Per epoch time:', epoch_time)\n",
    "#             print('Total per epoch JL time: ',epochJL_time)\n",
    "#             print('Total per epoch JL time per JL projection: ',epochJL_time/JL_dim)\n",
    "            print('\\n')\n",
    "\n",
    "        avg_accuracy_list+=np.array(accuracy_list)/num_runs\n",
    "\n",
    "\n",
    "\n",
    "        tf.keras.backend.clear_session()\n",
    "        print('\\n\\n\\n\\n\\n')\n",
    "        \n",
    "    record_dict = {'accuracy':avg_accuracy_list}\n",
    "    plt.plot(avg_accuracy_list)\n",
    "    plt.ylim(0.5,1)\n",
    "    plt.show()\n",
    "    with open(f'pickles/DPJL{JL_dim}_MNIST{batch_size}_approx.pickle','wb') as handle:\n",
    "        pickle.dump(record_dict,handle)\n",
    "\n",
    "    print('\\n\\n\\n\\n\\n')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "DPJLembedding.ipynb",
   "provenance": [],
   "toc_visible": true
  },
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.12"
  },
  "toc-autonumbering": true,
  "toc-showcode": true,
  "toc-showmarkdowntxt": false
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
