{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "olympic-maximum",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import torch.nn as nn\n",
    "import matplotlib.pyplot as plt\n",
    "from torchvision import transforms\n",
    "from torchvision.datasets import MNIST\n",
    "from copy import deepcopy\n",
    "from utils import *\n",
    "from models import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "fixed-decline",
   "metadata": {},
   "outputs": [],
   "source": [
    "device = torch.device('cuda', 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "refined-store",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load data\n",
    "class Flatten(object):\n",
    "    def __call__(self, pic):\n",
    "        return torch.flatten(pic)\n",
    "    \n",
    "mnist_dataset = MNIST('/tmp/mnist/', download=True, train=True,\n",
    "                      transform=transforms.Compose([transforms.ToTensor(), Flatten()]))\n",
    "images = mnist_dataset.data\n",
    "targets = mnist_dataset.targets\n",
    "np.random.seed(0)\n",
    "val_inds = np.sort(np.random.choice(len(images), size=10000, replace=False))\n",
    "train_inds = np.setdiff1d(np.arange(len(images)), val_inds)\n",
    "\n",
    "# Training dataset\n",
    "train_dataset = torch.utils.data.Subset(mnist_dataset, train_inds)\n",
    "\n",
    "# Validation dataset\n",
    "val_dataset = torch.utils.data.Subset(mnist_dataset, val_inds)\n",
    "\n",
    "# Test dataset\n",
    "test_dataset = MNIST('/tmp/mnist/', download=True, train=False,\n",
    "                     transform=transforms.Compose([transforms.ToTensor(), Flatten()]))\n",
    "\n",
    "# Set input/output dimensions\n",
    "d_in = 784\n",
    "d_out = 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "earlier-coffee",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Number of features to select\n",
    "max_features = (5, 10, 15, 20, 25)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "perceived-blind",
   "metadata": {},
   "source": [
    "# Pretrain model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "separate-going",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------Epoch 1--------\n",
      "Val loss = -0.4089\n",
      "\n",
      "--------Epoch 2--------\n",
      "Val loss = -0.4398\n",
      "\n",
      "--------Epoch 3--------\n",
      "Val loss = -0.4538\n",
      "\n",
      "--------Epoch 4--------\n",
      "Val loss = -0.4682\n",
      "\n",
      "--------Epoch 5--------\n",
      "Val loss = -0.4695\n",
      "\n",
      "--------Epoch 6--------\n",
      "Val loss = -0.4751\n",
      "\n",
      "--------Epoch 7--------\n",
      "Val loss = -0.4846\n",
      "\n",
      "--------Epoch 8--------\n",
      "Val loss = -0.4864\n",
      "\n",
      "--------Epoch 9--------\n",
      "Val loss = -0.4987\n",
      "\n",
      "--------Epoch 10--------\n",
      "Val loss = -0.4901\n",
      "\n",
      "--------Epoch 11--------\n",
      "Val loss = -0.4922\n",
      "\n",
      "--------Epoch 12--------\n",
      "Val loss = -0.4948\n",
      "\n",
      "--------Epoch 13--------\n",
      "Val loss = -0.4967\n",
      "\n",
      "--------Epoch 14--------\n",
      "Val loss = -0.5090\n",
      "\n",
      "--------Epoch 15--------\n",
      "Val loss = -0.5125\n",
      "\n",
      "--------Epoch 16--------\n",
      "Val loss = -0.5155\n",
      "\n",
      "--------Epoch 17--------\n",
      "Val loss = -0.5184\n",
      "\n",
      "--------Epoch 18--------\n",
      "Val loss = -0.5199\n",
      "\n",
      "--------Epoch 19--------\n",
      "Val loss = -0.5167\n",
      "\n",
      "--------Epoch 20--------\n",
      "Val loss = -0.5226\n",
      "\n",
      "--------Epoch 21--------\n",
      "Val loss = -0.5269\n",
      "\n",
      "--------Epoch 22--------\n",
      "Val loss = -0.5188\n",
      "\n",
      "--------Epoch 23--------\n",
      "Val loss = -0.5211\n",
      "\n",
      "--------Epoch 24--------\n",
      "Val loss = -0.5249\n",
      "\n",
      "--------Epoch 25--------\n",
      "Val loss = -0.5223\n",
      "\n",
      "--------Epoch 26--------\n",
      "Val loss = -0.5320\n",
      "\n",
      "--------Epoch 27--------\n",
      "Val loss = -0.5324\n",
      "\n",
      "--------Epoch 28--------\n",
      "Val loss = -0.5270\n",
      "\n",
      "--------Epoch 29--------\n",
      "Val loss = -0.5400\n",
      "\n",
      "--------Epoch 30--------\n",
      "Val loss = -0.5423\n",
      "\n",
      "--------Epoch 31--------\n",
      "Val loss = -0.5414\n",
      "\n",
      "--------Epoch 32--------\n",
      "Val loss = -0.5264\n",
      "\n",
      "--------Epoch 33--------\n",
      "Val loss = -0.5460\n",
      "\n",
      "--------Epoch 34--------\n",
      "Val loss = -0.5250\n",
      "\n",
      "--------Epoch 35--------\n",
      "Val loss = -0.5367\n",
      "\n",
      "--------Epoch 36--------\n",
      "Val loss = -0.5445\n",
      "\n",
      "--------Epoch 37--------\n",
      "Val loss = -0.5380\n",
      "\n",
      "--------Epoch 38--------\n",
      "Val loss = -0.5491\n",
      "\n",
      "--------Epoch 39--------\n",
      "Val loss = -0.5442\n",
      "\n",
      "--------Epoch 40--------\n",
      "Val loss = -0.5429\n",
      "\n",
      "--------Epoch 41--------\n",
      "Val loss = -0.5468\n",
      "\n",
      "--------Epoch 42--------\n",
      "Val loss = -0.5442\n",
      "\n",
      "--------Epoch 43--------\n",
      "Val loss = -0.5473\n",
      "\n",
      "--------Epoch 44--------\n",
      "Val loss = -0.5477\n",
      "\n",
      "--------Epoch 45--------\n",
      "Val loss = -0.5474\n",
      "\n",
      "--------Epoch 46--------\n",
      "Val loss = -0.5427\n",
      "\n",
      "--------Epoch 47--------\n",
      "Val loss = -0.5439\n",
      "\n",
      "--------Epoch 48--------\n",
      "Val loss = -0.5505\n",
      "\n",
      "--------Epoch 49--------\n",
      "Val loss = -0.5504\n",
      "\n",
      "--------Epoch 50--------\n",
      "Val loss = -0.5450\n",
      "\n",
      "--------Epoch 51--------\n",
      "Val loss = -0.5455\n",
      "\n",
      "--------Epoch 52--------\n",
      "Val loss = -0.5563\n",
      "\n",
      "--------Epoch 53--------\n",
      "Val loss = -0.5467\n",
      "\n",
      "--------Epoch 54--------\n",
      "Val loss = -0.5559\n",
      "\n",
      "--------Epoch 55--------\n",
      "Val loss = -0.5430\n",
      "\n",
      "--------Epoch 56--------\n",
      "Val loss = -0.5490\n",
      "\n",
      "--------Epoch 57--------\n",
      "Val loss = -0.5471\n",
      "\n",
      "--------Epoch 58--------\n",
      "Val loss = -0.5507\n",
      "\n",
      "--------Epoch 59--------\n",
      "Val loss = -0.5570\n",
      "\n",
      "--------Epoch 60--------\n",
      "Val loss = -0.5508\n",
      "\n",
      "--------Epoch 61--------\n",
      "Val loss = -0.5571\n",
      "\n",
      "--------Epoch 62--------\n",
      "Val loss = -0.5476\n",
      "\n",
      "--------Epoch 63--------\n",
      "Val loss = -0.5616\n",
      "\n",
      "--------Epoch 64--------\n",
      "Val loss = -0.5616\n",
      "\n",
      "--------Epoch 65--------\n",
      "Val loss = -0.5601\n",
      "\n",
      "--------Epoch 66--------\n",
      "Val loss = -0.5592\n",
      "\n",
      "--------Epoch 67--------\n",
      "Val loss = -0.5577\n",
      "\n",
      "--------Epoch 68--------\n",
      "Val loss = -0.5646\n",
      "\n",
      "--------Epoch 69--------\n",
      "Val loss = -0.5527\n",
      "\n",
      "--------Epoch 70--------\n",
      "Val loss = -0.5545\n",
      "\n",
      "--------Epoch 71--------\n",
      "Val loss = -0.5560\n",
      "\n",
      "--------Epoch 72--------\n",
      "Val loss = -0.5627\n",
      "\n",
      "--------Epoch 73--------\n",
      "Val loss = -0.5583\n",
      "\n",
      "--------Epoch 74--------\n",
      "Val loss = -0.5599\n",
      "\n",
      "--------Epoch 75--------\n",
      "Val loss = -0.5529\n",
      "\n",
      "--------Epoch 76--------\n",
      "Val loss = -0.5662\n",
      "\n",
      "--------Epoch 77--------\n",
      "Val loss = -0.5620\n",
      "\n",
      "--------Epoch 78--------\n",
      "Val loss = -0.5555\n",
      "\n",
      "--------Epoch 79--------\n",
      "Val loss = -0.5570\n",
      "\n",
      "--------Epoch 80--------\n",
      "Val loss = -0.5682\n",
      "\n",
      "--------Epoch 81--------\n",
      "Val loss = -0.5630\n",
      "\n",
      "--------Epoch 82--------\n",
      "Val loss = -0.5633\n",
      "\n",
      "--------Epoch 83--------\n",
      "Val loss = -0.5594\n",
      "\n",
      "--------Epoch 84--------\n",
      "Val loss = -0.5629\n",
      "\n",
      "--------Epoch 85--------\n",
      "Val loss = -0.5627\n",
      "\n",
      "--------Epoch 86--------\n",
      "Val loss = -0.5630\n",
      "\n",
      "--------Epoch 87--------\n",
      "Val loss = -0.5687\n",
      "\n",
      "--------Epoch 88--------\n",
      "Val loss = -0.5568\n",
      "\n",
      "--------Epoch 89--------\n",
      "Val loss = -0.5674\n",
      "\n",
      "--------Epoch 90--------\n",
      "Val loss = -0.5625\n",
      "\n",
      "--------Epoch 91--------\n",
      "Val loss = -0.5545\n",
      "\n",
      "--------Epoch 92--------\n",
      "Val loss = -0.5735\n",
      "\n",
      "--------Epoch 93--------\n",
      "Val loss = -0.5573\n",
      "\n",
      "--------Epoch 94--------\n",
      "Val loss = -0.5624\n",
      "\n",
      "--------Epoch 95--------\n",
      "Val loss = -0.5710\n",
      "\n",
      "--------Epoch 96--------\n",
      "Val loss = -0.5646\n",
      "\n",
      "--------Epoch 97--------\n",
      "Val loss = -0.5649\n",
      "\n",
      "--------Epoch 98--------\n",
      "Val loss = -0.5703\n",
      "\n",
      "--------Epoch 99--------\n",
      "Val loss = -0.5646\n",
      "\n",
      "--------Epoch 100--------\n",
      "Val loss = -0.5617\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Set up model\n",
    "model = nn.Sequential(\n",
    "    nn.Linear(d_in * 2, 512),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(512, 512),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(512, d_out))\n",
    "mask_layer = MaskLayer(append=True)\n",
    "pretrain = Pretrainer(model, mask_layer).to(device)\n",
    "\n",
    "# Pretrain\n",
    "pretrain.fit(train_dataset,\n",
    "             val_dataset,\n",
    "             mbsize=128,\n",
    "             lr=1e-3,\n",
    "             nepochs=100,\n",
    "             max_features=max(max_features),\n",
    "             loss_fn=nn.CrossEntropyLoss(),\n",
    "             val_loss_fn=NegAccuracy())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ethical-terry",
   "metadata": {},
   "source": [
    "# Weight tying"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "identical-single",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------Epoch 1--------\n",
      "Val loss = -0.5144\n",
      "\n",
      "--------Epoch 2--------\n",
      "Val loss = -0.4729\n",
      "\n",
      "--------Epoch 3--------\n",
      "Val loss = -0.4391\n",
      "\n",
      "--------Epoch 4--------\n",
      "Val loss = -0.4408\n",
      "\n",
      "--------Epoch 5--------\n",
      "Val loss = -0.4170\n",
      "\n",
      "--------Epoch 6--------\n",
      "Val loss = -0.3645\n",
      "\n",
      "--------Epoch 7--------\n",
      "Val loss = -0.3467\n",
      "\n",
      "--------Epoch 8--------\n",
      "Val loss = -0.3673\n",
      "\n",
      "--------Epoch 9--------\n",
      "Val loss = -0.3311\n",
      "\n",
      "--------Epoch 10--------\n",
      "Val loss = -0.3285\n",
      "\n",
      "--------Epoch 11--------\n",
      "Val loss = -0.3277\n",
      "\n",
      "--------Epoch 12--------\n",
      "Val loss = -0.3341\n",
      "\n",
      "--------Epoch 13--------\n",
      "Val loss = -0.3222\n",
      "\n",
      "--------Epoch 14--------\n",
      "Val loss = -0.3212\n",
      "\n",
      "--------Epoch 15--------\n",
      "Val loss = -0.3236\n",
      "\n",
      "--------Epoch 16--------\n",
      "Val loss = -0.3233\n",
      "\n",
      "--------Epoch 17--------\n",
      "Val loss = -0.3147\n",
      "\n",
      "--------Epoch 18--------\n",
      "Val loss = -0.3282\n",
      "\n",
      "--------Epoch 19--------\n",
      "Val loss = -0.3038\n",
      "\n",
      "--------Epoch 20--------\n",
      "Val loss = -0.2972\n",
      "\n",
      "--------Epoch 21--------\n",
      "Val loss = -0.3050\n",
      "\n",
      "--------Epoch 22--------\n",
      "Val loss = -0.2888\n",
      "\n",
      "--------Epoch 23--------\n",
      "Val loss = -0.2988\n",
      "\n",
      "--------Epoch 24--------\n",
      "Val loss = -0.2844\n",
      "\n",
      "--------Epoch 25--------\n",
      "Val loss = -0.2956\n",
      "\n",
      "--------Epoch 26--------\n",
      "Val loss = -0.2855\n",
      "\n",
      "--------Epoch 27--------\n",
      "Val loss = -0.2979\n",
      "\n",
      "--------Epoch 28--------\n",
      "Val loss = -0.3065\n",
      "\n",
      "--------Epoch 29--------\n",
      "Val loss = -0.2948\n",
      "\n",
      "--------Epoch 30--------\n",
      "Val loss = -0.2840\n",
      "\n",
      "--------Epoch 31--------\n",
      "Val loss = -0.2896\n",
      "\n",
      "--------Epoch 32--------\n",
      "Val loss = -0.2963\n",
      "\n",
      "--------Epoch 33--------\n",
      "Val loss = -0.3076\n",
      "\n",
      "--------Epoch 34--------\n",
      "Val loss = -0.3095\n",
      "\n",
      "--------Epoch 35--------\n",
      "Val loss = -0.2997\n",
      "\n",
      "--------Epoch 36--------\n",
      "Val loss = -0.3034\n",
      "\n",
      "--------Epoch 37--------\n",
      "Val loss = -0.2974\n",
      "\n",
      "--------Epoch 38--------\n",
      "Val loss = -0.3023\n",
      "\n",
      "--------Epoch 39--------\n",
      "Val loss = -0.3015\n",
      "\n",
      "--------Epoch 40--------\n",
      "Val loss = -0.2987\n",
      "\n",
      "--------Epoch 41--------\n",
      "Val loss = -0.2990\n",
      "\n",
      "--------Epoch 42--------\n",
      "Val loss = -0.3047\n",
      "\n",
      "--------Epoch 43--------\n",
      "Val loss = -0.3052\n",
      "\n",
      "--------Epoch 44--------\n",
      "Val loss = -0.3177\n",
      "\n",
      "--------Epoch 45--------\n",
      "Val loss = -0.3119\n",
      "\n",
      "--------Epoch 46--------\n",
      "Val loss = -0.3080\n",
      "\n",
      "--------Epoch 47--------\n",
      "Val loss = -0.3122\n",
      "\n",
      "--------Epoch 48--------\n",
      "Val loss = -0.3049\n",
      "\n",
      "--------Epoch 49--------\n",
      "Val loss = -0.3127\n",
      "\n",
      "--------Epoch 50--------\n",
      "Val loss = -0.3249\n",
      "\n",
      "--------Epoch 51--------\n",
      "Val loss = -0.3150\n",
      "\n",
      "--------Epoch 52--------\n",
      "Val loss = -0.3165\n",
      "\n",
      "--------Epoch 53--------\n",
      "Val loss = -0.3187\n",
      "\n",
      "--------Epoch 54--------\n",
      "Val loss = -0.3171\n",
      "\n",
      "--------Epoch 55--------\n",
      "Val loss = -0.3282\n",
      "\n",
      "--------Epoch 56--------\n",
      "Val loss = -0.3224\n",
      "\n",
      "--------Epoch 57--------\n",
      "Val loss = -0.3299\n",
      "\n",
      "--------Epoch 58--------\n",
      "Val loss = -0.3315\n",
      "\n",
      "--------Epoch 59--------\n",
      "Val loss = -0.3323\n",
      "\n",
      "--------Epoch 60--------\n",
      "Val loss = -0.3257\n",
      "\n",
      "--------Epoch 61--------\n",
      "Val loss = -0.3338\n",
      "\n",
      "--------Epoch 62--------\n",
      "Val loss = -0.3325\n",
      "\n",
      "--------Epoch 63--------\n",
      "Val loss = -0.3319\n",
      "\n",
      "--------Epoch 64--------\n",
      "Val loss = -0.3393\n",
      "\n",
      "--------Epoch 65--------\n",
      "Val loss = -0.3393\n",
      "\n",
      "--------Epoch 66--------\n",
      "Val loss = -0.3404\n",
      "\n",
      "--------Epoch 67--------\n",
      "Val loss = -0.3498\n",
      "\n",
      "--------Epoch 68--------\n",
      "Val loss = -0.3381\n",
      "\n",
      "--------Epoch 69--------\n",
      "Val loss = -0.3454\n",
      "\n",
      "--------Epoch 70--------\n",
      "Val loss = -0.3570\n",
      "\n",
      "--------Epoch 71--------\n",
      "Val loss = -0.3535\n",
      "\n",
      "--------Epoch 72--------\n",
      "Val loss = -0.3584\n",
      "\n",
      "--------Epoch 73--------\n",
      "Val loss = -0.3573\n",
      "\n",
      "--------Epoch 74--------\n",
      "Val loss = -0.3576\n",
      "\n",
      "--------Epoch 75--------\n",
      "Val loss = -0.3708\n",
      "\n",
      "--------Epoch 76--------\n",
      "Val loss = -0.3685\n",
      "\n",
      "--------Epoch 77--------\n",
      "Val loss = -0.3714\n",
      "\n",
      "--------Epoch 78--------\n",
      "Val loss = -0.3821\n",
      "\n",
      "--------Epoch 79--------\n",
      "Val loss = -0.3862\n",
      "\n",
      "--------Epoch 80--------\n",
      "Val loss = -0.3915\n",
      "\n",
      "--------Epoch 81--------\n",
      "Val loss = -0.3918\n",
      "\n",
      "--------Epoch 82--------\n",
      "Val loss = -0.3933\n",
      "\n",
      "--------Epoch 83--------\n",
      "Val loss = -0.3866\n",
      "\n",
      "--------Epoch 84--------\n",
      "Val loss = -0.3934\n",
      "\n",
      "--------Epoch 85--------\n",
      "Val loss = -0.4030\n",
      "\n",
      "--------Epoch 86--------\n",
      "Val loss = -0.4112\n",
      "\n",
      "--------Epoch 87--------\n",
      "Val loss = -0.4077\n",
      "\n",
      "--------Epoch 88--------\n",
      "Val loss = -0.4172\n",
      "\n",
      "--------Epoch 89--------\n",
      "Val loss = -0.4141\n",
      "\n",
      "--------Epoch 90--------\n",
      "Val loss = -0.4309\n",
      "\n",
      "--------Epoch 91--------\n",
      "Val loss = -0.4222\n",
      "\n",
      "--------Epoch 92--------\n",
      "Val loss = -0.4325\n",
      "\n",
      "--------Epoch 93--------\n",
      "Val loss = -0.4348\n",
      "\n",
      "--------Epoch 94--------\n",
      "Val loss = -0.4379\n",
      "\n",
      "--------Epoch 95--------\n",
      "Val loss = -0.4466\n",
      "\n",
      "--------Epoch 96--------\n",
      "Val loss = -0.4543\n",
      "\n",
      "--------Epoch 97--------\n",
      "Val loss = -0.4547\n",
      "\n",
      "--------Epoch 98--------\n",
      "Val loss = -0.4578\n",
      "\n",
      "--------Epoch 99--------\n",
      "Val loss = -0.4654\n",
      "\n",
      "--------Epoch 100--------\n",
      "Val loss = -0.4645\n",
      "\n",
      "--------Epoch 101--------\n",
      "Val loss = -0.4816\n",
      "\n",
      "--------Epoch 102--------\n",
      "Val loss = -0.4792\n",
      "\n",
      "--------Epoch 103--------\n",
      "Val loss = -0.4857\n",
      "\n",
      "--------Epoch 104--------\n",
      "Val loss = -0.4805\n",
      "\n",
      "--------Epoch 105--------\n",
      "Val loss = -0.4959\n",
      "\n",
      "--------Epoch 106--------\n",
      "Val loss = -0.4989\n",
      "\n",
      "--------Epoch 107--------\n",
      "Val loss = -0.5107\n",
      "\n",
      "--------Epoch 108--------\n",
      "Val loss = -0.5220\n",
      "\n",
      "--------Epoch 109--------\n",
      "Val loss = -0.5163\n",
      "\n",
      "--------Epoch 110--------\n",
      "Val loss = -0.5257\n",
      "\n",
      "--------Epoch 111--------\n",
      "Val loss = -0.5279\n",
      "\n",
      "--------Epoch 112--------\n",
      "Val loss = -0.5386\n",
      "\n",
      "--------Epoch 113--------\n",
      "Val loss = -0.5332\n",
      "\n",
      "--------Epoch 114--------\n",
      "Val loss = -0.5472\n",
      "\n",
      "--------Epoch 115--------\n",
      "Val loss = -0.5466\n",
      "\n",
      "--------Epoch 116--------\n",
      "Val loss = -0.5565\n",
      "\n",
      "--------Epoch 117--------\n",
      "Val loss = -0.5626\n",
      "\n",
      "--------Epoch 118--------\n",
      "Val loss = -0.5649\n",
      "\n",
      "--------Epoch 119--------\n",
      "Val loss = -0.5678\n",
      "\n",
      "--------Epoch 120--------\n",
      "Val loss = -0.5677\n",
      "\n",
      "--------Epoch 121--------\n",
      "Val loss = -0.5792\n",
      "\n",
      "--------Epoch 122--------\n",
      "Val loss = -0.5783\n",
      "\n",
      "--------Epoch 123--------\n",
      "Val loss = -0.5853\n",
      "\n",
      "--------Epoch 124--------\n",
      "Val loss = -0.5871\n",
      "\n",
      "--------Epoch 125--------\n",
      "Val loss = -0.5898\n",
      "\n",
      "--------Epoch 126--------\n",
      "Val loss = -0.5990\n",
      "\n",
      "--------Epoch 127--------\n",
      "Val loss = -0.6021\n",
      "\n",
      "--------Epoch 128--------\n",
      "Val loss = -0.6046\n",
      "\n",
      "--------Epoch 129--------\n",
      "Val loss = -0.6025\n",
      "\n",
      "--------Epoch 130--------\n",
      "Val loss = -0.6026\n",
      "\n",
      "--------Epoch 131--------\n",
      "Val loss = -0.6064\n",
      "\n",
      "--------Epoch 132--------\n",
      "Val loss = -0.6092\n",
      "\n",
      "--------Epoch 133--------\n",
      "Val loss = -0.6121\n",
      "\n",
      "--------Epoch 134--------\n",
      "Val loss = -0.6167\n",
      "\n",
      "--------Epoch 135--------\n",
      "Val loss = -0.6240\n",
      "\n",
      "--------Epoch 136--------\n",
      "Val loss = -0.6266\n",
      "\n",
      "--------Epoch 137--------\n",
      "Val loss = -0.6261\n",
      "\n",
      "--------Epoch 138--------\n",
      "Val loss = -0.6318\n",
      "\n",
      "--------Epoch 139--------\n",
      "Val loss = -0.6337\n",
      "\n",
      "--------Epoch 140--------\n",
      "Val loss = -0.6271\n",
      "\n",
      "--------Epoch 141--------\n",
      "Val loss = -0.6362\n",
      "\n",
      "--------Epoch 142--------\n",
      "Val loss = -0.6278\n",
      "\n",
      "--------Epoch 143--------\n",
      "Val loss = -0.6491\n",
      "\n",
      "--------Epoch 144--------\n",
      "Val loss = -0.6441\n",
      "\n",
      "--------Epoch 145--------\n",
      "Val loss = -0.6457\n",
      "\n",
      "--------Epoch 146--------\n",
      "Val loss = -0.6447\n",
      "\n",
      "--------Epoch 147--------\n",
      "Val loss = -0.6480\n",
      "\n",
      "--------Epoch 148--------\n",
      "Val loss = -0.6505\n",
      "\n",
      "--------Epoch 149--------\n",
      "Val loss = -0.6603\n",
      "\n",
      "--------Epoch 150--------\n",
      "Val loss = -0.6610\n",
      "\n",
      "--------Epoch 151--------\n",
      "Val loss = -0.6571\n",
      "\n",
      "--------Epoch 152--------\n",
      "Val loss = -0.6624\n",
      "\n",
      "--------Epoch 153--------\n",
      "Val loss = -0.6651\n",
      "\n",
      "--------Epoch 154--------\n",
      "Val loss = -0.6651\n",
      "\n",
      "--------Epoch 155--------\n",
      "Val loss = -0.6631\n",
      "\n",
      "--------Epoch 156--------\n",
      "Val loss = -0.6653\n",
      "\n",
      "--------Epoch 157--------\n",
      "Val loss = -0.6538\n",
      "\n",
      "--------Epoch 158--------\n",
      "Val loss = -0.6616\n",
      "\n",
      "--------Epoch 159--------\n",
      "Val loss = -0.6687\n",
      "\n",
      "--------Epoch 160--------\n",
      "Val loss = -0.6609\n",
      "\n",
      "--------Epoch 161--------\n",
      "Val loss = -0.6689\n",
      "\n",
      "--------Epoch 162--------\n",
      "Val loss = -0.6702\n",
      "\n",
      "--------Epoch 163--------\n",
      "Val loss = -0.6625\n",
      "\n",
      "--------Epoch 164--------\n",
      "Val loss = -0.6696\n",
      "\n",
      "--------Epoch 165--------\n",
      "Val loss = -0.6601\n",
      "\n",
      "--------Epoch 166--------\n",
      "Val loss = -0.6684\n",
      "\n",
      "--------Epoch 167--------\n",
      "Val loss = -0.6721\n",
      "\n",
      "--------Epoch 168--------\n",
      "Val loss = -0.6772\n",
      "\n",
      "--------Epoch 169--------\n",
      "Val loss = -0.6720\n",
      "\n",
      "--------Epoch 170--------\n",
      "Val loss = -0.6773\n",
      "\n",
      "--------Epoch 171--------\n",
      "Val loss = -0.6681\n",
      "\n",
      "--------Epoch 172--------\n",
      "Val loss = -0.6749\n",
      "\n",
      "--------Epoch 173--------\n",
      "Val loss = -0.6778\n",
      "\n",
      "--------Epoch 174--------\n",
      "Val loss = -0.6875\n",
      "\n",
      "--------Epoch 175--------\n",
      "Val loss = -0.6783\n",
      "\n",
      "--------Epoch 176--------\n",
      "Val loss = -0.6869\n",
      "\n",
      "--------Epoch 177--------\n",
      "Val loss = -0.6866\n",
      "\n",
      "--------Epoch 178--------\n",
      "Val loss = -0.6814\n",
      "\n",
      "--------Epoch 179--------\n",
      "Val loss = -0.6793\n",
      "\n",
      "--------Epoch 180--------\n",
      "Val loss = -0.6751\n",
      "\n",
      "--------Epoch 181--------\n",
      "Val loss = -0.6819\n",
      "\n",
      "--------Epoch 182--------\n",
      "Val loss = -0.6801\n",
      "\n",
      "--------Epoch 183--------\n",
      "Val loss = -0.6794\n",
      "\n",
      "--------Epoch 184--------\n",
      "Val loss = -0.6782\n",
      "\n",
      "--------Epoch 185--------\n",
      "Val loss = -0.6878\n",
      "\n",
      "--------Epoch 186--------\n",
      "Val loss = -0.6885\n",
      "\n",
      "--------Epoch 187--------\n",
      "Val loss = -0.6836\n",
      "\n",
      "--------Epoch 188--------\n",
      "Val loss = -0.6845\n",
      "\n",
      "--------Epoch 189--------\n",
      "Val loss = -0.6847\n",
      "\n",
      "--------Epoch 190--------\n",
      "Val loss = -0.6903\n",
      "\n",
      "--------Epoch 191--------\n",
      "Val loss = -0.6824\n",
      "\n",
      "--------Epoch 192--------\n",
      "Val loss = -0.6914\n",
      "\n",
      "--------Epoch 193--------\n",
      "Val loss = -0.6957\n",
      "\n",
      "--------Epoch 194--------\n",
      "Val loss = -0.6895\n",
      "\n",
      "--------Epoch 195--------\n",
      "Val loss = -0.6815\n",
      "\n",
      "--------Epoch 196--------\n",
      "Val loss = -0.6925\n",
      "\n",
      "--------Epoch 197--------\n",
      "Val loss = -0.6832\n",
      "\n",
      "--------Epoch 198--------\n",
      "Val loss = -0.6856\n",
      "\n",
      "--------Epoch 199--------\n",
      "Val loss = -0.6946\n",
      "\n",
      "--------Epoch 200--------\n",
      "Val loss = -0.6949\n",
      "\n",
      "--------Epoch 201--------\n",
      "Val loss = -0.6901\n",
      "\n",
      "--------Epoch 202--------\n",
      "Val loss = -0.6859\n",
      "\n",
      "--------Epoch 203--------\n",
      "Val loss = -0.6938\n",
      "\n",
      "--------Epoch 204--------\n",
      "Val loss = -0.6981\n",
      "\n",
      "--------Epoch 205--------\n",
      "Val loss = -0.6968\n",
      "\n",
      "--------Epoch 206--------\n",
      "Val loss = -0.6967\n",
      "\n",
      "--------Epoch 207--------\n",
      "Val loss = -0.6951\n",
      "\n",
      "--------Epoch 208--------\n",
      "Val loss = -0.6887\n",
      "\n",
      "--------Epoch 209--------\n",
      "Val loss = -0.6881\n",
      "\n",
      "--------Epoch 210--------\n",
      "Val loss = -0.6882\n",
      "\n",
      "--------Epoch 211--------\n",
      "Val loss = -0.6900\n",
      "\n",
      "--------Epoch 212--------\n",
      "Val loss = -0.6920\n",
      "\n",
      "--------Epoch 213--------\n",
      "Val loss = -0.6870\n",
      "\n",
      "--------Epoch 214--------\n",
      "Val loss = -0.6929\n",
      "\n",
      "--------Epoch 215--------\n",
      "Val loss = -0.6963\n",
      "\n",
      "--------Epoch 216--------\n",
      "Val loss = -0.6918\n",
      "\n",
      "--------Epoch 217--------\n",
      "Val loss = -0.6861\n",
      "\n",
      "--------Epoch 218--------\n",
      "Val loss = -0.6916\n",
      "\n",
      "--------Epoch 219--------\n",
      "Val loss = -0.6940\n",
      "\n",
      "--------Epoch 220--------\n",
      "Val loss = -0.6965\n",
      "\n",
      "--------Epoch 221--------\n",
      "Val loss = -0.6967\n",
      "\n",
      "--------Epoch 222--------\n",
      "Val loss = -0.7044\n",
      "\n",
      "--------Epoch 223--------\n",
      "Val loss = -0.7064\n",
      "\n",
      "--------Epoch 224--------\n",
      "Val loss = -0.7060\n",
      "\n",
      "--------Epoch 225--------\n",
      "Val loss = -0.7013\n",
      "\n",
      "--------Epoch 226--------\n",
      "Val loss = -0.6768\n",
      "\n",
      "--------Epoch 227--------\n",
      "Val loss = -0.6861\n",
      "\n",
      "--------Epoch 228--------\n",
      "Val loss = -0.6900\n",
      "\n",
      "--------Epoch 229--------\n",
      "Val loss = -0.6855\n",
      "\n",
      "--------Epoch 230--------\n",
      "Val loss = -0.6981\n",
      "\n",
      "--------Epoch 231--------\n",
      "Val loss = -0.6886\n",
      "\n",
      "--------Epoch 232--------\n",
      "Val loss = -0.6987\n",
      "\n",
      "--------Epoch 233--------\n",
      "Val loss = -0.6930\n",
      "\n",
      "--------Epoch 234--------\n",
      "Val loss = -0.6978\n",
      "\n",
      "--------Epoch 235--------\n",
      "Val loss = -0.6924\n",
      "\n",
      "--------Epoch 236--------\n",
      "Val loss = -0.6968\n",
      "\n",
      "--------Epoch 237--------\n",
      "Val loss = -0.6964\n",
      "\n",
      "--------Epoch 238--------\n",
      "Val loss = -0.7005\n",
      "\n",
      "--------Epoch 239--------\n",
      "Val loss = -0.7037\n",
      "\n",
      "--------Epoch 240--------\n",
      "Val loss = -0.6991\n",
      "\n",
      "--------Epoch 241--------\n",
      "Val loss = -0.6988\n",
      "\n",
      "--------Epoch 242--------\n",
      "Val loss = -0.7007\n",
      "\n",
      "--------Epoch 243--------\n",
      "Val loss = -0.7006\n",
      "\n",
      "--------Epoch 244--------\n",
      "Val loss = -0.7038\n",
      "\n",
      "--------Epoch 245--------\n",
      "Val loss = -0.7061\n",
      "\n",
      "--------Epoch 246--------\n",
      "Val loss = -0.7029\n",
      "\n",
      "--------Epoch 247--------\n",
      "Val loss = -0.7002\n",
      "\n",
      "--------Epoch 248--------\n",
      "Val loss = -0.7028\n",
      "\n",
      "--------Epoch 249--------\n",
      "Val loss = -0.6987\n",
      "\n",
      "--------Epoch 250--------\n",
      "Val loss = -0.7017\n",
      "\n",
      "Acc = 70.63\n",
      "--------Epoch 1--------\n",
      "Val loss = -0.5772\n",
      "\n",
      "--------Epoch 2--------\n",
      "Val loss = -0.5233\n",
      "\n",
      "--------Epoch 3--------\n",
      "Val loss = -0.5008\n",
      "\n",
      "--------Epoch 4--------\n",
      "Val loss = -0.4695\n",
      "\n",
      "--------Epoch 5--------\n",
      "Val loss = -0.4665\n",
      "\n",
      "--------Epoch 6--------\n",
      "Val loss = -0.4628\n",
      "\n",
      "--------Epoch 7--------\n",
      "Val loss = -0.4529\n",
      "\n",
      "--------Epoch 8--------\n",
      "Val loss = -0.4456\n",
      "\n",
      "--------Epoch 9--------\n",
      "Val loss = -0.4530\n",
      "\n",
      "--------Epoch 10--------\n",
      "Val loss = -0.4309\n",
      "\n",
      "--------Epoch 11--------\n",
      "Val loss = -0.4500\n",
      "\n",
      "--------Epoch 12--------\n",
      "Val loss = -0.4347\n",
      "\n",
      "--------Epoch 13--------\n",
      "Val loss = -0.4421\n",
      "\n",
      "--------Epoch 14--------\n",
      "Val loss = -0.4552\n",
      "\n",
      "--------Epoch 15--------\n",
      "Val loss = -0.4594\n",
      "\n",
      "--------Epoch 16--------\n",
      "Val loss = -0.4712\n",
      "\n",
      "--------Epoch 17--------\n",
      "Val loss = -0.4629\n",
      "\n",
      "--------Epoch 18--------\n",
      "Val loss = -0.4617\n",
      "\n",
      "--------Epoch 19--------\n",
      "Val loss = -0.4800\n",
      "\n",
      "--------Epoch 20--------\n",
      "Val loss = -0.4679\n",
      "\n",
      "--------Epoch 21--------\n",
      "Val loss = -0.4684\n",
      "\n",
      "--------Epoch 22--------\n",
      "Val loss = -0.4601\n",
      "\n",
      "--------Epoch 23--------\n",
      "Val loss = -0.4491\n",
      "\n",
      "--------Epoch 24--------\n",
      "Val loss = -0.4555\n",
      "\n",
      "--------Epoch 25--------\n",
      "Val loss = -0.4615\n",
      "\n",
      "--------Epoch 26--------\n",
      "Val loss = -0.4709\n",
      "\n",
      "--------Epoch 27--------\n",
      "Val loss = -0.4562\n",
      "\n",
      "--------Epoch 28--------\n",
      "Val loss = -0.4556\n",
      "\n",
      "--------Epoch 29--------\n",
      "Val loss = -0.4703\n",
      "\n",
      "--------Epoch 30--------\n",
      "Val loss = -0.4532\n",
      "\n",
      "--------Epoch 31--------\n",
      "Val loss = -0.4739\n",
      "\n",
      "--------Epoch 32--------\n",
      "Val loss = -0.4630\n",
      "\n",
      "--------Epoch 33--------\n",
      "Val loss = -0.4605\n",
      "\n",
      "--------Epoch 34--------\n",
      "Val loss = -0.4449\n",
      "\n",
      "--------Epoch 35--------\n",
      "Val loss = -0.4788\n",
      "\n",
      "--------Epoch 36--------\n",
      "Val loss = -0.4672\n",
      "\n",
      "--------Epoch 37--------\n",
      "Val loss = -0.4760\n",
      "\n",
      "--------Epoch 38--------\n",
      "Val loss = -0.4750\n",
      "\n",
      "--------Epoch 39--------\n",
      "Val loss = -0.4695\n",
      "\n",
      "--------Epoch 40--------\n",
      "Val loss = -0.4623\n",
      "\n",
      "--------Epoch 41--------\n",
      "Val loss = -0.4658\n",
      "\n",
      "--------Epoch 42--------\n",
      "Val loss = -0.4726\n",
      "\n",
      "--------Epoch 43--------\n",
      "Val loss = -0.4843\n",
      "\n",
      "--------Epoch 44--------\n",
      "Val loss = -0.4833\n",
      "\n",
      "--------Epoch 45--------\n",
      "Val loss = -0.4861\n",
      "\n",
      "--------Epoch 46--------\n",
      "Val loss = -0.4781\n",
      "\n",
      "--------Epoch 47--------\n",
      "Val loss = -0.4755\n",
      "\n",
      "--------Epoch 48--------\n",
      "Val loss = -0.4857\n",
      "\n",
      "--------Epoch 49--------\n",
      "Val loss = -0.4859\n",
      "\n",
      "--------Epoch 50--------\n",
      "Val loss = -0.4949\n",
      "\n",
      "--------Epoch 51--------\n",
      "Val loss = -0.4902\n",
      "\n",
      "--------Epoch 52--------\n",
      "Val loss = -0.4938\n",
      "\n",
      "--------Epoch 53--------\n",
      "Val loss = -0.5025\n",
      "\n",
      "--------Epoch 54--------\n",
      "Val loss = -0.5082\n",
      "\n",
      "--------Epoch 55--------\n",
      "Val loss = -0.5024\n",
      "\n",
      "--------Epoch 56--------\n",
      "Val loss = -0.5190\n",
      "\n",
      "--------Epoch 57--------\n",
      "Val loss = -0.5090\n",
      "\n",
      "--------Epoch 58--------\n",
      "Val loss = -0.5188\n",
      "\n",
      "--------Epoch 59--------\n",
      "Val loss = -0.5199\n",
      "\n",
      "--------Epoch 60--------\n",
      "Val loss = -0.5167\n",
      "\n",
      "--------Epoch 61--------\n",
      "Val loss = -0.5283\n",
      "\n",
      "--------Epoch 62--------\n",
      "Val loss = -0.5387\n",
      "\n",
      "--------Epoch 63--------\n",
      "Val loss = -0.5291\n",
      "\n",
      "--------Epoch 64--------\n",
      "Val loss = -0.5395\n",
      "\n",
      "--------Epoch 65--------\n",
      "Val loss = -0.5441\n",
      "\n",
      "--------Epoch 66--------\n",
      "Val loss = -0.5437\n",
      "\n",
      "--------Epoch 67--------\n",
      "Val loss = -0.5490\n",
      "\n",
      "--------Epoch 68--------\n",
      "Val loss = -0.5618\n",
      "\n",
      "--------Epoch 69--------\n",
      "Val loss = -0.5604\n",
      "\n",
      "--------Epoch 70--------\n",
      "Val loss = -0.5538\n",
      "\n",
      "--------Epoch 71--------\n",
      "Val loss = -0.5687\n",
      "\n",
      "--------Epoch 72--------\n",
      "Val loss = -0.5640\n",
      "\n",
      "--------Epoch 73--------\n",
      "Val loss = -0.5812\n",
      "\n",
      "--------Epoch 74--------\n",
      "Val loss = -0.5850\n",
      "\n",
      "--------Epoch 75--------\n",
      "Val loss = -0.5934\n",
      "\n",
      "--------Epoch 76--------\n",
      "Val loss = -0.5921\n",
      "\n",
      "--------Epoch 77--------\n",
      "Val loss = -0.5914\n",
      "\n",
      "--------Epoch 78--------\n",
      "Val loss = -0.6073\n",
      "\n",
      "--------Epoch 79--------\n",
      "Val loss = -0.6179\n",
      "\n",
      "--------Epoch 80--------\n",
      "Val loss = -0.6181\n",
      "\n",
      "--------Epoch 81--------\n",
      "Val loss = -0.6331\n",
      "\n",
      "--------Epoch 82--------\n",
      "Val loss = -0.6349\n",
      "\n",
      "--------Epoch 83--------\n",
      "Val loss = -0.6379\n",
      "\n",
      "--------Epoch 84--------\n",
      "Val loss = -0.6492\n",
      "\n",
      "--------Epoch 85--------\n",
      "Val loss = -0.6526\n",
      "\n",
      "--------Epoch 86--------\n",
      "Val loss = -0.6702\n",
      "\n",
      "--------Epoch 87--------\n",
      "Val loss = -0.6709\n",
      "\n",
      "--------Epoch 88--------\n",
      "Val loss = -0.6814\n",
      "\n",
      "--------Epoch 89--------\n",
      "Val loss = -0.6792\n",
      "\n",
      "--------Epoch 90--------\n",
      "Val loss = -0.6933\n",
      "\n",
      "--------Epoch 91--------\n",
      "Val loss = -0.6966\n",
      "\n",
      "--------Epoch 92--------\n",
      "Val loss = -0.7057\n",
      "\n",
      "--------Epoch 93--------\n",
      "Val loss = -0.7069\n",
      "\n",
      "--------Epoch 94--------\n",
      "Val loss = -0.7107\n",
      "\n",
      "--------Epoch 95--------\n",
      "Val loss = -0.7234\n",
      "\n",
      "--------Epoch 96--------\n",
      "Val loss = -0.7251\n",
      "\n",
      "--------Epoch 97--------\n",
      "Val loss = -0.7376\n",
      "\n",
      "--------Epoch 98--------\n",
      "Val loss = -0.7477\n",
      "\n",
      "--------Epoch 99--------\n",
      "Val loss = -0.7492\n",
      "\n",
      "--------Epoch 100--------\n",
      "Val loss = -0.7531\n",
      "\n",
      "--------Epoch 101--------\n",
      "Val loss = -0.7622\n",
      "\n",
      "--------Epoch 102--------\n",
      "Val loss = -0.7659\n",
      "\n",
      "--------Epoch 103--------\n",
      "Val loss = -0.7663\n",
      "\n",
      "--------Epoch 104--------\n",
      "Val loss = -0.7714\n",
      "\n",
      "--------Epoch 105--------\n",
      "Val loss = -0.7758\n",
      "\n",
      "--------Epoch 106--------\n",
      "Val loss = -0.7745\n",
      "\n",
      "--------Epoch 107--------\n",
      "Val loss = -0.7771\n",
      "\n",
      "--------Epoch 108--------\n",
      "Val loss = -0.7802\n",
      "\n",
      "--------Epoch 109--------\n",
      "Val loss = -0.7920\n",
      "\n",
      "--------Epoch 110--------\n",
      "Val loss = -0.7979\n",
      "\n",
      "--------Epoch 111--------\n",
      "Val loss = -0.7982\n",
      "\n",
      "--------Epoch 112--------\n",
      "Val loss = -0.8014\n",
      "\n",
      "--------Epoch 113--------\n",
      "Val loss = -0.8092\n",
      "\n",
      "--------Epoch 114--------\n",
      "Val loss = -0.8106\n",
      "\n",
      "--------Epoch 115--------\n",
      "Val loss = -0.8104\n",
      "\n",
      "--------Epoch 116--------\n",
      "Val loss = -0.8092\n",
      "\n",
      "--------Epoch 117--------\n",
      "Val loss = -0.8157\n",
      "\n",
      "--------Epoch 118--------\n",
      "Val loss = -0.8167\n",
      "\n",
      "--------Epoch 119--------\n",
      "Val loss = -0.8214\n",
      "\n",
      "--------Epoch 120--------\n",
      "Val loss = -0.8248\n",
      "\n",
      "--------Epoch 121--------\n",
      "Val loss = -0.8221\n",
      "\n",
      "--------Epoch 122--------\n",
      "Val loss = -0.8230\n",
      "\n",
      "--------Epoch 123--------\n",
      "Val loss = -0.8263\n",
      "\n",
      "--------Epoch 124--------\n",
      "Val loss = -0.8265\n",
      "\n",
      "--------Epoch 125--------\n",
      "Val loss = -0.8304\n",
      "\n",
      "--------Epoch 126--------\n",
      "Val loss = -0.8378\n",
      "\n",
      "--------Epoch 127--------\n",
      "Val loss = -0.8300\n",
      "\n",
      "--------Epoch 128--------\n",
      "Val loss = -0.8353\n",
      "\n",
      "--------Epoch 129--------\n",
      "Val loss = -0.8394\n",
      "\n",
      "--------Epoch 130--------\n",
      "Val loss = -0.8461\n",
      "\n",
      "--------Epoch 131--------\n",
      "Val loss = -0.8401\n",
      "\n",
      "--------Epoch 132--------\n",
      "Val loss = -0.8407\n",
      "\n",
      "--------Epoch 133--------\n",
      "Val loss = -0.8381\n",
      "\n",
      "--------Epoch 134--------\n",
      "Val loss = -0.8478\n",
      "\n",
      "--------Epoch 135--------\n",
      "Val loss = -0.8466\n",
      "\n",
      "--------Epoch 136--------\n",
      "Val loss = -0.8463\n",
      "\n",
      "--------Epoch 137--------\n",
      "Val loss = -0.8497\n",
      "\n",
      "--------Epoch 138--------\n",
      "Val loss = -0.8490\n",
      "\n",
      "--------Epoch 139--------\n",
      "Val loss = -0.8461\n",
      "\n",
      "--------Epoch 140--------\n",
      "Val loss = -0.8479\n",
      "\n",
      "--------Epoch 141--------\n",
      "Val loss = -0.8483\n",
      "\n",
      "--------Epoch 142--------\n",
      "Val loss = -0.8511\n",
      "\n",
      "--------Epoch 143--------\n",
      "Val loss = -0.8522\n",
      "\n",
      "--------Epoch 144--------\n",
      "Val loss = -0.8543\n",
      "\n",
      "--------Epoch 145--------\n",
      "Val loss = -0.8509\n",
      "\n",
      "--------Epoch 146--------\n",
      "Val loss = -0.8541\n",
      "\n",
      "--------Epoch 147--------\n",
      "Val loss = -0.8564\n",
      "\n",
      "--------Epoch 148--------\n",
      "Val loss = -0.8536\n",
      "\n",
      "--------Epoch 149--------\n",
      "Val loss = -0.8586\n",
      "\n",
      "--------Epoch 150--------\n",
      "Val loss = -0.8501\n",
      "\n",
      "--------Epoch 151--------\n",
      "Val loss = -0.8562\n",
      "\n",
      "--------Epoch 152--------\n",
      "Val loss = -0.8550\n",
      "\n",
      "--------Epoch 153--------\n",
      "Val loss = -0.8577\n",
      "\n",
      "--------Epoch 154--------\n",
      "Val loss = -0.8623\n",
      "\n",
      "--------Epoch 155--------\n",
      "Val loss = -0.8584\n",
      "\n",
      "--------Epoch 156--------\n",
      "Val loss = -0.8577\n",
      "\n",
      "--------Epoch 157--------\n",
      "Val loss = -0.8594\n",
      "\n",
      "--------Epoch 158--------\n",
      "Val loss = -0.8575\n",
      "\n",
      "--------Epoch 159--------\n",
      "Val loss = -0.8615\n",
      "\n",
      "--------Epoch 160--------\n",
      "Val loss = -0.8600\n",
      "\n",
      "--------Epoch 161--------\n",
      "Val loss = -0.8615\n",
      "\n",
      "--------Epoch 162--------\n",
      "Val loss = -0.8605\n",
      "\n",
      "--------Epoch 163--------\n",
      "Val loss = -0.8610\n",
      "\n",
      "--------Epoch 164--------\n",
      "Val loss = -0.8599\n",
      "\n",
      "--------Epoch 165--------\n",
      "Val loss = -0.8594\n",
      "\n",
      "--------Epoch 166--------\n",
      "Val loss = -0.8584\n",
      "\n",
      "--------Epoch 167--------\n",
      "Val loss = -0.8615\n",
      "\n",
      "--------Epoch 168--------\n",
      "Val loss = -0.8608\n",
      "\n",
      "--------Epoch 169--------\n",
      "Val loss = -0.8571\n",
      "\n",
      "--------Epoch 170--------\n",
      "Val loss = -0.8646\n",
      "\n",
      "--------Epoch 171--------\n",
      "Val loss = -0.8645\n",
      "\n",
      "--------Epoch 172--------\n",
      "Val loss = -0.8644\n",
      "\n",
      "--------Epoch 173--------\n",
      "Val loss = -0.8658\n",
      "\n",
      "--------Epoch 174--------\n",
      "Val loss = -0.8616\n",
      "\n",
      "--------Epoch 175--------\n",
      "Val loss = -0.8609\n",
      "\n",
      "--------Epoch 176--------\n",
      "Val loss = -0.8562\n",
      "\n",
      "--------Epoch 177--------\n",
      "Val loss = -0.8641\n",
      "\n",
      "--------Epoch 178--------\n",
      "Val loss = -0.8652\n",
      "\n",
      "--------Epoch 179--------\n",
      "Val loss = -0.8624\n",
      "\n",
      "--------Epoch 180--------\n",
      "Val loss = -0.8634\n",
      "\n",
      "--------Epoch 181--------\n",
      "Val loss = -0.8655\n",
      "\n",
      "--------Epoch 182--------\n",
      "Val loss = -0.8648\n",
      "\n",
      "--------Epoch 183--------\n",
      "Val loss = -0.8622\n",
      "\n",
      "--------Epoch 184--------\n",
      "Val loss = -0.8608\n",
      "\n",
      "--------Epoch 185--------\n",
      "Val loss = -0.8682\n",
      "\n",
      "--------Epoch 186--------\n",
      "Val loss = -0.8626\n",
      "\n",
      "--------Epoch 187--------\n",
      "Val loss = -0.8617\n",
      "\n",
      "--------Epoch 188--------\n",
      "Val loss = -0.8664\n",
      "\n",
      "--------Epoch 189--------\n",
      "Val loss = -0.8693\n",
      "\n",
      "--------Epoch 190--------\n",
      "Val loss = -0.8596\n",
      "\n",
      "--------Epoch 191--------\n",
      "Val loss = -0.8675\n",
      "\n",
      "--------Epoch 192--------\n",
      "Val loss = -0.8651\n",
      "\n",
      "--------Epoch 193--------\n",
      "Val loss = -0.8614\n",
      "\n",
      "--------Epoch 194--------\n",
      "Val loss = -0.8651\n",
      "\n",
      "--------Epoch 195--------\n",
      "Val loss = -0.8645\n",
      "\n",
      "--------Epoch 196--------\n",
      "Val loss = -0.8615\n",
      "\n",
      "--------Epoch 197--------\n",
      "Val loss = -0.8661\n",
      "\n",
      "--------Epoch 198--------\n",
      "Val loss = -0.8616\n",
      "\n",
      "--------Epoch 199--------\n",
      "Val loss = -0.8642\n",
      "\n",
      "--------Epoch 200--------\n",
      "Val loss = -0.8559\n",
      "\n",
      "--------Epoch 201--------\n",
      "Val loss = -0.8603\n",
      "\n",
      "--------Epoch 202--------\n",
      "Val loss = -0.8625\n",
      "\n",
      "--------Epoch 203--------\n",
      "Val loss = -0.8609\n",
      "\n",
      "--------Epoch 204--------\n",
      "Val loss = -0.8671\n",
      "\n",
      "--------Epoch 205--------\n",
      "Val loss = -0.8623\n",
      "\n",
      "--------Epoch 206--------\n",
      "Val loss = -0.8662\n",
      "\n",
      "--------Epoch 207--------\n",
      "Val loss = -0.8685\n",
      "\n",
      "--------Epoch 208--------\n",
      "Val loss = -0.8636\n",
      "\n",
      "--------Epoch 209--------\n",
      "Val loss = -0.8620\n",
      "\n",
      "--------Epoch 210--------\n",
      "Val loss = -0.8628\n",
      "\n",
      "--------Epoch 211--------\n",
      "Val loss = -0.8636\n",
      "\n",
      "--------Epoch 212--------\n",
      "Val loss = -0.8662\n",
      "\n",
      "--------Epoch 213--------\n",
      "Val loss = -0.8628\n",
      "\n",
      "--------Epoch 214--------\n",
      "Val loss = -0.8655\n",
      "\n",
      "--------Epoch 215--------\n",
      "Val loss = -0.8593\n",
      "\n",
      "--------Epoch 216--------\n",
      "Val loss = -0.8629\n",
      "\n",
      "--------Epoch 217--------\n",
      "Val loss = -0.8663\n",
      "\n",
      "--------Epoch 218--------\n",
      "Val loss = -0.8670\n",
      "\n",
      "--------Epoch 219--------\n",
      "Val loss = -0.8636\n",
      "\n",
      "--------Epoch 220--------\n",
      "Val loss = -0.8647\n",
      "\n",
      "--------Epoch 221--------\n",
      "Val loss = -0.8671\n",
      "\n",
      "--------Epoch 222--------\n",
      "Val loss = -0.8618\n",
      "\n",
      "--------Epoch 223--------\n",
      "Val loss = -0.8588\n",
      "\n",
      "--------Epoch 224--------\n",
      "Val loss = -0.8572\n",
      "\n",
      "--------Epoch 225--------\n",
      "Val loss = -0.8626\n",
      "\n",
      "--------Epoch 226--------\n",
      "Val loss = -0.8614\n",
      "\n",
      "--------Epoch 227--------\n",
      "Val loss = -0.8589\n",
      "\n",
      "--------Epoch 228--------\n",
      "Val loss = -0.8624\n",
      "\n",
      "--------Epoch 229--------\n",
      "Val loss = -0.8602\n",
      "\n",
      "--------Epoch 230--------\n",
      "Val loss = -0.8614\n",
      "\n",
      "--------Epoch 231--------\n",
      "Val loss = -0.8621\n",
      "\n",
      "--------Epoch 232--------\n",
      "Val loss = -0.8621\n",
      "\n",
      "--------Epoch 233--------\n",
      "Val loss = -0.8584\n",
      "\n",
      "--------Epoch 234--------\n",
      "Val loss = -0.8626\n",
      "\n",
      "--------Epoch 235--------\n",
      "Val loss = -0.8633\n",
      "\n",
      "--------Epoch 236--------\n",
      "Val loss = -0.8592\n",
      "\n",
      "--------Epoch 237--------\n",
      "Val loss = -0.8625\n",
      "\n",
      "--------Epoch 238--------\n",
      "Val loss = -0.8593\n",
      "\n",
      "--------Epoch 239--------\n",
      "Val loss = -0.8596\n",
      "\n",
      "--------Epoch 240--------\n",
      "Val loss = -0.8558\n",
      "\n",
      "--------Epoch 241--------\n",
      "Val loss = -0.8588\n",
      "\n",
      "--------Epoch 242--------\n",
      "Val loss = -0.8609\n",
      "\n",
      "--------Epoch 243--------\n",
      "Val loss = -0.8436\n",
      "\n",
      "--------Epoch 244--------\n",
      "Val loss = -0.8649\n",
      "\n",
      "--------Epoch 245--------\n",
      "Val loss = -0.8563\n",
      "\n",
      "--------Epoch 246--------\n",
      "Val loss = -0.8575\n",
      "\n",
      "--------Epoch 247--------\n",
      "Val loss = -0.8602\n",
      "\n",
      "--------Epoch 248--------\n",
      "Val loss = -0.8567\n",
      "\n",
      "--------Epoch 249--------\n",
      "Val loss = -0.8581\n",
      "\n",
      "--------Epoch 250--------\n",
      "Val loss = -0.8595\n",
      "\n",
      "Acc = 87.54\n",
      "--------Epoch 1--------\n",
      "Val loss = -0.7439\n",
      "\n",
      "--------Epoch 2--------\n",
      "Val loss = -0.7105\n",
      "\n",
      "--------Epoch 3--------\n",
      "Val loss = -0.6665\n",
      "\n",
      "--------Epoch 4--------\n",
      "Val loss = -0.6375\n",
      "\n",
      "--------Epoch 5--------\n",
      "Val loss = -0.6159\n",
      "\n",
      "--------Epoch 6--------\n",
      "Val loss = -0.6370\n",
      "\n",
      "--------Epoch 7--------\n",
      "Val loss = -0.6317\n",
      "\n",
      "--------Epoch 8--------\n",
      "Val loss = -0.5907\n",
      "\n",
      "--------Epoch 9--------\n",
      "Val loss = -0.5916\n",
      "\n",
      "--------Epoch 10--------\n",
      "Val loss = -0.5796\n",
      "\n",
      "--------Epoch 11--------\n",
      "Val loss = -0.5842\n",
      "\n",
      "--------Epoch 12--------\n",
      "Val loss = -0.5821\n",
      "\n",
      "--------Epoch 13--------\n",
      "Val loss = -0.5848\n",
      "\n",
      "--------Epoch 14--------\n",
      "Val loss = -0.5976\n",
      "\n",
      "--------Epoch 15--------\n",
      "Val loss = -0.5607\n",
      "\n",
      "--------Epoch 16--------\n",
      "Val loss = -0.5872\n",
      "\n",
      "--------Epoch 17--------\n",
      "Val loss = -0.5673\n",
      "\n",
      "--------Epoch 18--------\n",
      "Val loss = -0.5939\n",
      "\n",
      "--------Epoch 19--------\n",
      "Val loss = -0.5749\n",
      "\n",
      "--------Epoch 20--------\n",
      "Val loss = -0.5805\n",
      "\n",
      "--------Epoch 21--------\n",
      "Val loss = -0.5892\n",
      "\n",
      "--------Epoch 22--------\n",
      "Val loss = -0.6043\n",
      "\n",
      "--------Epoch 23--------\n",
      "Val loss = -0.5992\n",
      "\n",
      "--------Epoch 24--------\n",
      "Val loss = -0.5956\n",
      "\n",
      "--------Epoch 25--------\n",
      "Val loss = -0.5925\n",
      "\n",
      "--------Epoch 26--------\n",
      "Val loss = -0.5853\n",
      "\n",
      "--------Epoch 27--------\n",
      "Val loss = -0.5976\n",
      "\n",
      "--------Epoch 28--------\n",
      "Val loss = -0.6056\n",
      "\n",
      "--------Epoch 29--------\n",
      "Val loss = -0.6064\n",
      "\n",
      "--------Epoch 30--------\n",
      "Val loss = -0.5851\n",
      "\n",
      "--------Epoch 31--------\n",
      "Val loss = -0.5972\n",
      "\n",
      "--------Epoch 32--------\n",
      "Val loss = -0.5977\n",
      "\n",
      "--------Epoch 33--------\n",
      "Val loss = -0.6080\n",
      "\n",
      "--------Epoch 34--------\n",
      "Val loss = -0.6040\n",
      "\n",
      "--------Epoch 35--------\n",
      "Val loss = -0.5934\n",
      "\n",
      "--------Epoch 36--------\n",
      "Val loss = -0.6060\n",
      "\n",
      "--------Epoch 37--------\n",
      "Val loss = -0.6029\n",
      "\n",
      "--------Epoch 38--------\n",
      "Val loss = -0.6155\n",
      "\n",
      "--------Epoch 39--------\n",
      "Val loss = -0.6047\n",
      "\n",
      "--------Epoch 40--------\n",
      "Val loss = -0.6316\n",
      "\n",
      "--------Epoch 41--------\n",
      "Val loss = -0.5971\n",
      "\n",
      "--------Epoch 42--------\n",
      "Val loss = -0.6158\n",
      "\n",
      "--------Epoch 43--------\n",
      "Val loss = -0.6232\n",
      "\n",
      "--------Epoch 44--------\n",
      "Val loss = -0.6244\n",
      "\n",
      "--------Epoch 45--------\n",
      "Val loss = -0.6298\n",
      "\n",
      "--------Epoch 46--------\n",
      "Val loss = -0.6310\n",
      "\n",
      "--------Epoch 47--------\n",
      "Val loss = -0.6303\n",
      "\n",
      "--------Epoch 48--------\n",
      "Val loss = -0.6365\n",
      "\n",
      "--------Epoch 49--------\n",
      "Val loss = -0.6429\n",
      "\n",
      "--------Epoch 50--------\n",
      "Val loss = -0.6343\n",
      "\n",
      "--------Epoch 51--------\n",
      "Val loss = -0.6475\n",
      "\n",
      "--------Epoch 52--------\n",
      "Val loss = -0.6461\n",
      "\n",
      "--------Epoch 53--------\n",
      "Val loss = -0.6437\n",
      "\n",
      "--------Epoch 54--------\n",
      "Val loss = -0.6578\n",
      "\n",
      "--------Epoch 55--------\n",
      "Val loss = -0.6619\n",
      "\n",
      "--------Epoch 56--------\n",
      "Val loss = -0.6551\n",
      "\n",
      "--------Epoch 57--------\n",
      "Val loss = -0.6503\n",
      "\n",
      "--------Epoch 58--------\n",
      "Val loss = -0.6735\n",
      "\n",
      "--------Epoch 59--------\n",
      "Val loss = -0.6712\n",
      "\n",
      "--------Epoch 60--------\n",
      "Val loss = -0.6708\n",
      "\n",
      "--------Epoch 61--------\n",
      "Val loss = -0.6810\n",
      "\n",
      "--------Epoch 62--------\n",
      "Val loss = -0.6875\n",
      "\n",
      "--------Epoch 63--------\n",
      "Val loss = -0.6812\n",
      "\n",
      "--------Epoch 64--------\n",
      "Val loss = -0.6922\n",
      "\n",
      "--------Epoch 65--------\n",
      "Val loss = -0.6944\n",
      "\n",
      "--------Epoch 66--------\n",
      "Val loss = -0.6983\n",
      "\n",
      "--------Epoch 67--------\n",
      "Val loss = -0.7055\n",
      "\n",
      "--------Epoch 68--------\n",
      "Val loss = -0.7103\n",
      "\n",
      "--------Epoch 69--------\n",
      "Val loss = -0.7055\n",
      "\n",
      "--------Epoch 70--------\n",
      "Val loss = -0.7168\n",
      "\n",
      "--------Epoch 71--------\n",
      "Val loss = -0.7181\n",
      "\n",
      "--------Epoch 72--------\n",
      "Val loss = -0.7283\n",
      "\n",
      "--------Epoch 73--------\n",
      "Val loss = -0.7347\n",
      "\n",
      "--------Epoch 74--------\n",
      "Val loss = -0.7453\n",
      "\n",
      "--------Epoch 75--------\n",
      "Val loss = -0.7467\n",
      "\n",
      "--------Epoch 76--------\n",
      "Val loss = -0.7540\n",
      "\n",
      "--------Epoch 77--------\n",
      "Val loss = -0.7558\n",
      "\n",
      "--------Epoch 78--------\n",
      "Val loss = -0.7609\n",
      "\n",
      "--------Epoch 79--------\n",
      "Val loss = -0.7686\n",
      "\n",
      "--------Epoch 80--------\n",
      "Val loss = -0.7729\n",
      "\n",
      "--------Epoch 81--------\n",
      "Val loss = -0.7819\n",
      "\n",
      "--------Epoch 82--------\n",
      "Val loss = -0.7780\n",
      "\n",
      "--------Epoch 83--------\n",
      "Val loss = -0.7980\n",
      "\n",
      "--------Epoch 84--------\n",
      "Val loss = -0.7942\n",
      "\n",
      "--------Epoch 85--------\n",
      "Val loss = -0.8151\n",
      "\n",
      "--------Epoch 86--------\n",
      "Val loss = -0.8110\n",
      "\n",
      "--------Epoch 87--------\n",
      "Val loss = -0.8178\n",
      "\n",
      "--------Epoch 88--------\n",
      "Val loss = -0.8216\n",
      "\n",
      "--------Epoch 89--------\n",
      "Val loss = -0.8257\n",
      "\n",
      "--------Epoch 90--------\n",
      "Val loss = -0.8309\n",
      "\n",
      "--------Epoch 91--------\n",
      "Val loss = -0.8353\n",
      "\n",
      "--------Epoch 92--------\n",
      "Val loss = -0.8397\n",
      "\n",
      "--------Epoch 93--------\n",
      "Val loss = -0.8484\n",
      "\n",
      "--------Epoch 94--------\n",
      "Val loss = -0.8502\n",
      "\n",
      "--------Epoch 95--------\n",
      "Val loss = -0.8471\n",
      "\n",
      "--------Epoch 96--------\n",
      "Val loss = -0.8569\n",
      "\n",
      "--------Epoch 97--------\n",
      "Val loss = -0.8614\n",
      "\n",
      "--------Epoch 98--------\n",
      "Val loss = -0.8584\n",
      "\n",
      "--------Epoch 99--------\n",
      "Val loss = -0.8704\n",
      "\n",
      "--------Epoch 100--------\n",
      "Val loss = -0.8681\n",
      "\n",
      "--------Epoch 101--------\n",
      "Val loss = -0.8754\n",
      "\n",
      "--------Epoch 102--------\n",
      "Val loss = -0.8757\n",
      "\n",
      "--------Epoch 103--------\n",
      "Val loss = -0.8795\n",
      "\n",
      "--------Epoch 104--------\n",
      "Val loss = -0.8833\n",
      "\n",
      "--------Epoch 105--------\n",
      "Val loss = -0.8857\n",
      "\n",
      "--------Epoch 106--------\n",
      "Val loss = -0.8806\n",
      "\n",
      "--------Epoch 107--------\n",
      "Val loss = -0.8854\n",
      "\n",
      "--------Epoch 108--------\n",
      "Val loss = -0.8879\n",
      "\n",
      "--------Epoch 109--------\n",
      "Val loss = -0.8882\n",
      "\n",
      "--------Epoch 110--------\n",
      "Val loss = -0.8941\n",
      "\n",
      "--------Epoch 111--------\n",
      "Val loss = -0.8929\n",
      "\n",
      "--------Epoch 112--------\n",
      "Val loss = -0.8954\n",
      "\n",
      "--------Epoch 113--------\n",
      "Val loss = -0.9010\n",
      "\n",
      "--------Epoch 114--------\n",
      "Val loss = -0.9009\n",
      "\n",
      "--------Epoch 115--------\n",
      "Val loss = -0.8966\n",
      "\n",
      "--------Epoch 116--------\n",
      "Val loss = -0.9040\n",
      "\n",
      "--------Epoch 117--------\n",
      "Val loss = -0.9029\n",
      "\n",
      "--------Epoch 118--------\n",
      "Val loss = -0.9032\n",
      "\n",
      "--------Epoch 119--------\n",
      "Val loss = -0.9044\n",
      "\n",
      "--------Epoch 120--------\n",
      "Val loss = -0.9044\n",
      "\n",
      "--------Epoch 121--------\n",
      "Val loss = -0.9088\n",
      "\n",
      "--------Epoch 122--------\n",
      "Val loss = -0.9085\n",
      "\n",
      "--------Epoch 123--------\n",
      "Val loss = -0.9059\n",
      "\n",
      "--------Epoch 124--------\n",
      "Val loss = -0.9087\n",
      "\n",
      "--------Epoch 125--------\n",
      "Val loss = -0.9078\n",
      "\n",
      "--------Epoch 126--------\n",
      "Val loss = -0.9088\n",
      "\n",
      "--------Epoch 127--------\n",
      "Val loss = -0.9121\n",
      "\n",
      "--------Epoch 128--------\n",
      "Val loss = -0.9080\n",
      "\n",
      "--------Epoch 129--------\n",
      "Val loss = -0.9084\n",
      "\n",
      "--------Epoch 130--------\n",
      "Val loss = -0.9140\n",
      "\n",
      "--------Epoch 131--------\n",
      "Val loss = -0.9129\n",
      "\n",
      "--------Epoch 132--------\n",
      "Val loss = -0.9138\n",
      "\n",
      "--------Epoch 133--------\n",
      "Val loss = -0.9103\n",
      "\n",
      "--------Epoch 134--------\n",
      "Val loss = -0.9127\n",
      "\n",
      "--------Epoch 135--------\n",
      "Val loss = -0.9190\n",
      "\n",
      "--------Epoch 136--------\n",
      "Val loss = -0.9154\n",
      "\n",
      "--------Epoch 137--------\n",
      "Val loss = -0.9184\n",
      "\n",
      "--------Epoch 138--------\n",
      "Val loss = -0.9123\n",
      "\n",
      "--------Epoch 139--------\n",
      "Val loss = -0.9169\n",
      "\n",
      "--------Epoch 140--------\n",
      "Val loss = -0.9178\n",
      "\n",
      "--------Epoch 141--------\n",
      "Val loss = -0.9169\n",
      "\n",
      "--------Epoch 142--------\n",
      "Val loss = -0.9173\n",
      "\n",
      "--------Epoch 143--------\n",
      "Val loss = -0.9156\n",
      "\n",
      "--------Epoch 144--------\n",
      "Val loss = -0.9161\n",
      "\n",
      "--------Epoch 145--------\n",
      "Val loss = -0.9193\n",
      "\n",
      "--------Epoch 146--------\n",
      "Val loss = -0.9186\n",
      "\n",
      "--------Epoch 147--------\n",
      "Val loss = -0.9180\n",
      "\n",
      "--------Epoch 148--------\n",
      "Val loss = -0.9206\n",
      "\n",
      "--------Epoch 149--------\n",
      "Val loss = -0.9189\n",
      "\n",
      "--------Epoch 150--------\n",
      "Val loss = -0.9195\n",
      "\n",
      "--------Epoch 151--------\n",
      "Val loss = -0.9183\n",
      "\n",
      "--------Epoch 152--------\n",
      "Val loss = -0.9187\n",
      "\n",
      "--------Epoch 153--------\n",
      "Val loss = -0.9184\n",
      "\n",
      "--------Epoch 154--------\n",
      "Val loss = -0.9225\n",
      "\n",
      "--------Epoch 155--------\n",
      "Val loss = -0.9174\n",
      "\n",
      "--------Epoch 156--------\n",
      "Val loss = -0.9172\n",
      "\n",
      "--------Epoch 157--------\n",
      "Val loss = -0.9197\n",
      "\n",
      "--------Epoch 158--------\n",
      "Val loss = -0.9168\n",
      "\n",
      "--------Epoch 159--------\n",
      "Val loss = -0.9199\n",
      "\n",
      "--------Epoch 160--------\n",
      "Val loss = -0.9190\n",
      "\n",
      "--------Epoch 161--------\n",
      "Val loss = -0.9221\n",
      "\n",
      "--------Epoch 162--------\n",
      "Val loss = -0.9177\n",
      "\n",
      "--------Epoch 163--------\n",
      "Val loss = -0.9204\n",
      "\n",
      "--------Epoch 164--------\n",
      "Val loss = -0.9224\n",
      "\n",
      "--------Epoch 165--------\n",
      "Val loss = -0.9228\n",
      "\n",
      "--------Epoch 166--------\n",
      "Val loss = -0.9193\n",
      "\n",
      "--------Epoch 167--------\n",
      "Val loss = -0.9215\n",
      "\n",
      "--------Epoch 168--------\n",
      "Val loss = -0.9235\n",
      "\n",
      "--------Epoch 169--------\n",
      "Val loss = -0.9199\n",
      "\n",
      "--------Epoch 170--------\n",
      "Val loss = -0.9193\n",
      "\n",
      "--------Epoch 171--------\n",
      "Val loss = -0.9207\n",
      "\n",
      "--------Epoch 172--------\n",
      "Val loss = -0.9197\n",
      "\n",
      "--------Epoch 173--------\n",
      "Val loss = -0.9224\n",
      "\n",
      "--------Epoch 174--------\n",
      "Val loss = -0.9204\n",
      "\n",
      "--------Epoch 175--------\n",
      "Val loss = -0.9212\n",
      "\n",
      "--------Epoch 176--------\n",
      "Val loss = -0.9247\n",
      "\n",
      "--------Epoch 177--------\n",
      "Val loss = -0.9228\n",
      "\n",
      "--------Epoch 178--------\n",
      "Val loss = -0.9184\n",
      "\n",
      "--------Epoch 179--------\n",
      "Val loss = -0.9230\n",
      "\n",
      "--------Epoch 180--------\n",
      "Val loss = -0.9203\n",
      "\n",
      "--------Epoch 181--------\n",
      "Val loss = -0.9204\n",
      "\n",
      "--------Epoch 182--------\n",
      "Val loss = -0.9218\n",
      "\n",
      "--------Epoch 183--------\n",
      "Val loss = -0.9191\n",
      "\n",
      "--------Epoch 184--------\n",
      "Val loss = -0.9227\n",
      "\n",
      "--------Epoch 185--------\n",
      "Val loss = -0.9199\n",
      "\n",
      "--------Epoch 186--------\n",
      "Val loss = -0.9245\n",
      "\n",
      "--------Epoch 187--------\n",
      "Val loss = -0.9192\n",
      "\n",
      "--------Epoch 188--------\n",
      "Val loss = -0.9224\n",
      "\n",
      "--------Epoch 189--------\n",
      "Val loss = -0.9231\n",
      "\n",
      "--------Epoch 190--------\n",
      "Val loss = -0.9228\n",
      "\n",
      "--------Epoch 191--------\n",
      "Val loss = -0.9210\n",
      "\n",
      "--------Epoch 192--------\n",
      "Val loss = -0.9248\n",
      "\n",
      "--------Epoch 193--------\n",
      "Val loss = -0.9207\n",
      "\n",
      "--------Epoch 194--------\n",
      "Val loss = -0.9242\n",
      "\n",
      "--------Epoch 195--------\n",
      "Val loss = -0.9207\n",
      "\n",
      "--------Epoch 196--------\n",
      "Val loss = -0.9243\n",
      "\n",
      "--------Epoch 197--------\n",
      "Val loss = -0.9201\n",
      "\n",
      "--------Epoch 198--------\n",
      "Val loss = -0.9183\n",
      "\n",
      "--------Epoch 199--------\n",
      "Val loss = -0.9176\n",
      "\n",
      "--------Epoch 200--------\n",
      "Val loss = -0.9205\n",
      "\n",
      "--------Epoch 201--------\n",
      "Val loss = -0.9147\n",
      "\n",
      "--------Epoch 202--------\n",
      "Val loss = -0.9209\n",
      "\n",
      "--------Epoch 203--------\n",
      "Val loss = -0.9174\n",
      "\n",
      "--------Epoch 204--------\n",
      "Val loss = -0.9233\n",
      "\n",
      "--------Epoch 205--------\n",
      "Val loss = -0.9220\n",
      "\n",
      "--------Epoch 206--------\n",
      "Val loss = -0.9169\n",
      "\n",
      "--------Epoch 207--------\n",
      "Val loss = -0.9211\n",
      "\n",
      "--------Epoch 208--------\n",
      "Val loss = -0.9208\n",
      "\n",
      "--------Epoch 209--------\n",
      "Val loss = -0.9193\n",
      "\n",
      "--------Epoch 210--------\n",
      "Val loss = -0.9202\n",
      "\n",
      "--------Epoch 211--------\n",
      "Val loss = -0.9199\n",
      "\n",
      "--------Epoch 212--------\n",
      "Val loss = -0.9266\n",
      "\n",
      "--------Epoch 213--------\n",
      "Val loss = -0.9158\n",
      "\n",
      "--------Epoch 214--------\n",
      "Val loss = -0.9196\n",
      "\n",
      "--------Epoch 215--------\n",
      "Val loss = -0.9179\n",
      "\n",
      "--------Epoch 216--------\n",
      "Val loss = -0.9171\n",
      "\n",
      "--------Epoch 217--------\n",
      "Val loss = -0.9209\n",
      "\n",
      "--------Epoch 218--------\n",
      "Val loss = -0.9162\n",
      "\n",
      "--------Epoch 219--------\n",
      "Val loss = -0.9195\n",
      "\n",
      "--------Epoch 220--------\n",
      "Val loss = -0.9195\n",
      "\n",
      "--------Epoch 221--------\n",
      "Val loss = -0.9201\n",
      "\n",
      "--------Epoch 222--------\n",
      "Val loss = -0.9164\n",
      "\n",
      "--------Epoch 223--------\n",
      "Val loss = -0.9200\n",
      "\n",
      "--------Epoch 224--------\n",
      "Val loss = -0.9153\n",
      "\n",
      "--------Epoch 225--------\n",
      "Val loss = -0.9179\n",
      "\n",
      "--------Epoch 226--------\n",
      "Val loss = -0.9176\n",
      "\n",
      "--------Epoch 227--------\n",
      "Val loss = -0.9232\n",
      "\n",
      "--------Epoch 228--------\n",
      "Val loss = -0.9191\n",
      "\n",
      "--------Epoch 229--------\n",
      "Val loss = -0.9166\n",
      "\n",
      "--------Epoch 230--------\n",
      "Val loss = -0.9206\n",
      "\n",
      "--------Epoch 231--------\n",
      "Val loss = -0.9195\n",
      "\n",
      "--------Epoch 232--------\n",
      "Val loss = -0.9207\n",
      "\n",
      "--------Epoch 233--------\n",
      "Val loss = -0.9204\n",
      "\n",
      "--------Epoch 234--------\n",
      "Val loss = -0.9173\n",
      "\n",
      "--------Epoch 235--------\n",
      "Val loss = -0.9169\n",
      "\n",
      "--------Epoch 236--------\n",
      "Val loss = -0.9168\n",
      "\n",
      "--------Epoch 237--------\n",
      "Val loss = -0.9176\n",
      "\n",
      "--------Epoch 238--------\n",
      "Val loss = -0.9193\n",
      "\n",
      "--------Epoch 239--------\n",
      "Val loss = -0.9204\n",
      "\n",
      "--------Epoch 240--------\n",
      "Val loss = -0.9141\n",
      "\n",
      "--------Epoch 241--------\n",
      "Val loss = -0.9162\n",
      "\n",
      "--------Epoch 242--------\n",
      "Val loss = -0.9160\n",
      "\n",
      "--------Epoch 243--------\n",
      "Val loss = -0.9152\n",
      "\n",
      "--------Epoch 244--------\n",
      "Val loss = -0.9124\n",
      "\n",
      "--------Epoch 245--------\n",
      "Val loss = -0.9178\n",
      "\n",
      "--------Epoch 246--------\n",
      "Val loss = -0.9155\n",
      "\n",
      "--------Epoch 247--------\n",
      "Val loss = -0.9119\n",
      "\n",
      "--------Epoch 248--------\n",
      "Val loss = -0.9147\n",
      "\n",
      "--------Epoch 249--------\n",
      "Val loss = -0.9136\n",
      "\n",
      "--------Epoch 250--------\n",
      "Val loss = -0.9143\n",
      "\n",
      "Acc = 92.39\n",
      "--------Epoch 1--------\n",
      "Val loss = -0.8496\n",
      "\n",
      "--------Epoch 2--------\n",
      "Val loss = -0.8157\n",
      "\n",
      "--------Epoch 3--------\n",
      "Val loss = -0.7967\n",
      "\n",
      "--------Epoch 4--------\n",
      "Val loss = -0.7575\n",
      "\n",
      "--------Epoch 5--------\n",
      "Val loss = -0.7503\n",
      "\n",
      "--------Epoch 6--------\n",
      "Val loss = -0.7141\n",
      "\n",
      "--------Epoch 7--------\n",
      "Val loss = -0.7321\n",
      "\n",
      "--------Epoch 8--------\n",
      "Val loss = -0.7080\n",
      "\n",
      "--------Epoch 9--------\n",
      "Val loss = -0.6970\n",
      "\n",
      "--------Epoch 10--------\n",
      "Val loss = -0.6969\n",
      "\n",
      "--------Epoch 11--------\n",
      "Val loss = -0.6960\n",
      "\n",
      "--------Epoch 12--------\n",
      "Val loss = -0.6981\n",
      "\n",
      "--------Epoch 13--------\n",
      "Val loss = -0.6981\n",
      "\n",
      "--------Epoch 14--------\n",
      "Val loss = -0.6956\n",
      "\n",
      "--------Epoch 15--------\n",
      "Val loss = -0.6840\n",
      "\n",
      "--------Epoch 16--------\n",
      "Val loss = -0.6972\n",
      "\n",
      "--------Epoch 17--------\n",
      "Val loss = -0.7098\n",
      "\n",
      "--------Epoch 18--------\n",
      "Val loss = -0.7033\n",
      "\n",
      "--------Epoch 19--------\n",
      "Val loss = -0.6947\n",
      "\n",
      "--------Epoch 20--------\n",
      "Val loss = -0.7098\n",
      "\n",
      "--------Epoch 21--------\n",
      "Val loss = -0.7053\n",
      "\n",
      "--------Epoch 22--------\n",
      "Val loss = -0.7048\n",
      "\n",
      "--------Epoch 23--------\n",
      "Val loss = -0.6959\n",
      "\n",
      "--------Epoch 24--------\n",
      "Val loss = -0.7180\n",
      "\n",
      "--------Epoch 25--------\n",
      "Val loss = -0.7223\n",
      "\n",
      "--------Epoch 26--------\n",
      "Val loss = -0.7359\n",
      "\n",
      "--------Epoch 27--------\n",
      "Val loss = -0.7220\n",
      "\n",
      "--------Epoch 28--------\n",
      "Val loss = -0.7178\n",
      "\n",
      "--------Epoch 29--------\n",
      "Val loss = -0.7266\n",
      "\n",
      "--------Epoch 30--------\n",
      "Val loss = -0.7174\n",
      "\n",
      "--------Epoch 31--------\n",
      "Val loss = -0.7056\n",
      "\n",
      "--------Epoch 32--------\n",
      "Val loss = -0.7179\n",
      "\n",
      "--------Epoch 33--------\n",
      "Val loss = -0.7113\n",
      "\n",
      "--------Epoch 34--------\n",
      "Val loss = -0.7356\n",
      "\n",
      "--------Epoch 35--------\n",
      "Val loss = -0.7303\n",
      "\n",
      "--------Epoch 36--------\n",
      "Val loss = -0.7419\n",
      "\n",
      "--------Epoch 37--------\n",
      "Val loss = -0.7487\n",
      "\n",
      "--------Epoch 38--------\n",
      "Val loss = -0.7341\n",
      "\n",
      "--------Epoch 39--------\n",
      "Val loss = -0.7394\n",
      "\n",
      "--------Epoch 40--------\n",
      "Val loss = -0.7340\n",
      "\n",
      "--------Epoch 41--------\n",
      "Val loss = -0.7335\n",
      "\n",
      "--------Epoch 42--------\n",
      "Val loss = -0.7477\n",
      "\n",
      "--------Epoch 43--------\n",
      "Val loss = -0.7380\n",
      "\n",
      "--------Epoch 44--------\n",
      "Val loss = -0.7426\n",
      "\n",
      "--------Epoch 45--------\n",
      "Val loss = -0.7564\n",
      "\n",
      "--------Epoch 46--------\n",
      "Val loss = -0.7421\n",
      "\n",
      "--------Epoch 47--------\n",
      "Val loss = -0.7580\n",
      "\n",
      "--------Epoch 48--------\n",
      "Val loss = -0.7484\n",
      "\n",
      "--------Epoch 49--------\n",
      "Val loss = -0.7592\n",
      "\n",
      "--------Epoch 50--------\n",
      "Val loss = -0.7579\n",
      "\n",
      "--------Epoch 51--------\n",
      "Val loss = -0.7759\n",
      "\n",
      "--------Epoch 52--------\n",
      "Val loss = -0.7755\n",
      "\n",
      "--------Epoch 53--------\n",
      "Val loss = -0.7788\n",
      "\n",
      "--------Epoch 54--------\n",
      "Val loss = -0.7742\n",
      "\n",
      "--------Epoch 55--------\n",
      "Val loss = -0.7812\n",
      "\n",
      "--------Epoch 56--------\n",
      "Val loss = -0.7893\n",
      "\n",
      "--------Epoch 57--------\n",
      "Val loss = -0.7842\n",
      "\n",
      "--------Epoch 58--------\n",
      "Val loss = -0.7877\n",
      "\n",
      "--------Epoch 59--------\n",
      "Val loss = -0.7911\n",
      "\n",
      "--------Epoch 60--------\n",
      "Val loss = -0.7984\n",
      "\n",
      "--------Epoch 61--------\n",
      "Val loss = -0.7909\n",
      "\n",
      "--------Epoch 62--------\n",
      "Val loss = -0.7953\n",
      "\n",
      "--------Epoch 63--------\n",
      "Val loss = -0.8030\n",
      "\n",
      "--------Epoch 64--------\n",
      "Val loss = -0.8134\n",
      "\n",
      "--------Epoch 65--------\n",
      "Val loss = -0.8054\n",
      "\n",
      "--------Epoch 66--------\n",
      "Val loss = -0.8110\n",
      "\n",
      "--------Epoch 67--------\n",
      "Val loss = -0.8174\n",
      "\n",
      "--------Epoch 68--------\n",
      "Val loss = -0.8248\n",
      "\n",
      "--------Epoch 69--------\n",
      "Val loss = -0.8228\n",
      "\n",
      "--------Epoch 70--------\n",
      "Val loss = -0.8226\n",
      "\n",
      "--------Epoch 71--------\n",
      "Val loss = -0.8206\n",
      "\n",
      "--------Epoch 72--------\n",
      "Val loss = -0.8324\n",
      "\n",
      "--------Epoch 73--------\n",
      "Val loss = -0.8395\n",
      "\n",
      "--------Epoch 74--------\n",
      "Val loss = -0.8457\n",
      "\n",
      "--------Epoch 75--------\n",
      "Val loss = -0.8449\n",
      "\n",
      "--------Epoch 76--------\n",
      "Val loss = -0.8506\n",
      "\n",
      "--------Epoch 77--------\n",
      "Val loss = -0.8548\n",
      "\n",
      "--------Epoch 78--------\n",
      "Val loss = -0.8640\n",
      "\n",
      "--------Epoch 79--------\n",
      "Val loss = -0.8664\n",
      "\n",
      "--------Epoch 80--------\n",
      "Val loss = -0.8701\n",
      "\n",
      "--------Epoch 81--------\n",
      "Val loss = -0.8690\n",
      "\n",
      "--------Epoch 82--------\n",
      "Val loss = -0.8754\n",
      "\n",
      "--------Epoch 83--------\n",
      "Val loss = -0.8811\n",
      "\n",
      "--------Epoch 84--------\n",
      "Val loss = -0.8845\n",
      "\n",
      "--------Epoch 85--------\n",
      "Val loss = -0.8932\n",
      "\n",
      "--------Epoch 86--------\n",
      "Val loss = -0.8955\n",
      "\n",
      "--------Epoch 87--------\n",
      "Val loss = -0.8926\n",
      "\n",
      "--------Epoch 88--------\n",
      "Val loss = -0.8942\n",
      "\n",
      "--------Epoch 89--------\n",
      "Val loss = -0.8989\n",
      "\n",
      "--------Epoch 90--------\n",
      "Val loss = -0.9050\n",
      "\n",
      "--------Epoch 91--------\n",
      "Val loss = -0.9083\n",
      "\n",
      "--------Epoch 92--------\n",
      "Val loss = -0.9102\n",
      "\n",
      "--------Epoch 93--------\n",
      "Val loss = -0.9111\n",
      "\n",
      "--------Epoch 94--------\n",
      "Val loss = -0.9128\n",
      "\n",
      "--------Epoch 95--------\n",
      "Val loss = -0.9162\n",
      "\n",
      "--------Epoch 96--------\n",
      "Val loss = -0.9179\n",
      "\n",
      "--------Epoch 97--------\n",
      "Val loss = -0.9190\n",
      "\n",
      "--------Epoch 98--------\n",
      "Val loss = -0.9234\n",
      "\n",
      "--------Epoch 99--------\n",
      "Val loss = -0.9212\n",
      "\n",
      "--------Epoch 100--------\n",
      "Val loss = -0.9248\n",
      "\n",
      "--------Epoch 101--------\n",
      "Val loss = -0.9218\n",
      "\n",
      "--------Epoch 102--------\n",
      "Val loss = -0.9232\n",
      "\n",
      "--------Epoch 103--------\n",
      "Val loss = -0.9248\n",
      "\n",
      "--------Epoch 104--------\n",
      "Val loss = -0.9357\n",
      "\n",
      "--------Epoch 105--------\n",
      "Val loss = -0.9302\n",
      "\n",
      "--------Epoch 106--------\n",
      "Val loss = -0.9320\n",
      "\n",
      "--------Epoch 107--------\n",
      "Val loss = -0.9335\n",
      "\n",
      "--------Epoch 108--------\n",
      "Val loss = -0.9320\n",
      "\n",
      "--------Epoch 109--------\n",
      "Val loss = -0.9338\n",
      "\n",
      "--------Epoch 110--------\n",
      "Val loss = -0.9344\n",
      "\n",
      "--------Epoch 111--------\n",
      "Val loss = -0.9347\n",
      "\n",
      "--------Epoch 112--------\n",
      "Val loss = -0.9354\n",
      "\n",
      "--------Epoch 113--------\n",
      "Val loss = -0.9392\n",
      "\n",
      "--------Epoch 114--------\n",
      "Val loss = -0.9380\n",
      "\n",
      "--------Epoch 115--------\n",
      "Val loss = -0.9358\n",
      "\n",
      "--------Epoch 116--------\n",
      "Val loss = -0.9390\n",
      "\n",
      "--------Epoch 117--------\n",
      "Val loss = -0.9387\n",
      "\n",
      "--------Epoch 118--------\n",
      "Val loss = -0.9393\n",
      "\n",
      "--------Epoch 119--------\n",
      "Val loss = -0.9396\n",
      "\n",
      "--------Epoch 120--------\n",
      "Val loss = -0.9430\n",
      "\n",
      "--------Epoch 121--------\n",
      "Val loss = -0.9413\n",
      "\n",
      "--------Epoch 122--------\n",
      "Val loss = -0.9422\n",
      "\n",
      "--------Epoch 123--------\n",
      "Val loss = -0.9417\n",
      "\n",
      "--------Epoch 124--------\n",
      "Val loss = -0.9415\n",
      "\n",
      "--------Epoch 125--------\n",
      "Val loss = -0.9437\n",
      "\n",
      "--------Epoch 126--------\n",
      "Val loss = -0.9421\n",
      "\n",
      "--------Epoch 127--------\n",
      "Val loss = -0.9425\n",
      "\n",
      "--------Epoch 128--------\n",
      "Val loss = -0.9439\n",
      "\n",
      "--------Epoch 129--------\n",
      "Val loss = -0.9444\n",
      "\n",
      "--------Epoch 130--------\n",
      "Val loss = -0.9437\n",
      "\n",
      "--------Epoch 131--------\n",
      "Val loss = -0.9455\n",
      "\n",
      "--------Epoch 132--------\n",
      "Val loss = -0.9455\n",
      "\n",
      "--------Epoch 133--------\n",
      "Val loss = -0.9431\n",
      "\n",
      "--------Epoch 134--------\n",
      "Val loss = -0.9409\n",
      "\n",
      "--------Epoch 135--------\n",
      "Val loss = -0.9430\n",
      "\n",
      "--------Epoch 136--------\n",
      "Val loss = -0.9415\n",
      "\n",
      "--------Epoch 137--------\n",
      "Val loss = -0.9441\n",
      "\n",
      "--------Epoch 138--------\n",
      "Val loss = -0.9449\n",
      "\n",
      "--------Epoch 139--------\n",
      "Val loss = -0.9425\n",
      "\n",
      "--------Epoch 140--------\n",
      "Val loss = -0.9450\n",
      "\n",
      "--------Epoch 141--------\n",
      "Val loss = -0.9463\n",
      "\n",
      "--------Epoch 142--------\n",
      "Val loss = -0.9448\n",
      "\n",
      "--------Epoch 143--------\n",
      "Val loss = -0.9481\n",
      "\n",
      "--------Epoch 144--------\n",
      "Val loss = -0.9458\n",
      "\n",
      "--------Epoch 145--------\n",
      "Val loss = -0.9476\n",
      "\n",
      "--------Epoch 146--------\n",
      "Val loss = -0.9436\n",
      "\n",
      "--------Epoch 147--------\n",
      "Val loss = -0.9441\n",
      "\n",
      "--------Epoch 148--------\n",
      "Val loss = -0.9473\n",
      "\n",
      "--------Epoch 149--------\n",
      "Val loss = -0.9461\n",
      "\n",
      "--------Epoch 150--------\n",
      "Val loss = -0.9467\n",
      "\n",
      "--------Epoch 151--------\n",
      "Val loss = -0.9447\n",
      "\n",
      "--------Epoch 152--------\n",
      "Val loss = -0.9452\n",
      "\n",
      "--------Epoch 153--------\n",
      "Val loss = -0.9439\n",
      "\n",
      "--------Epoch 154--------\n",
      "Val loss = -0.9433\n",
      "\n",
      "--------Epoch 155--------\n",
      "Val loss = -0.9459\n",
      "\n",
      "--------Epoch 156--------\n",
      "Val loss = -0.9448\n",
      "\n",
      "--------Epoch 157--------\n",
      "Val loss = -0.9450\n",
      "\n",
      "--------Epoch 158--------\n",
      "Val loss = -0.9442\n",
      "\n",
      "--------Epoch 159--------\n",
      "Val loss = -0.9460\n",
      "\n",
      "--------Epoch 160--------\n",
      "Val loss = -0.9449\n",
      "\n",
      "--------Epoch 161--------\n",
      "Val loss = -0.9471\n",
      "\n",
      "--------Epoch 162--------\n",
      "Val loss = -0.9448\n",
      "\n",
      "--------Epoch 163--------\n",
      "Val loss = -0.9460\n",
      "\n",
      "--------Epoch 164--------\n",
      "Val loss = -0.9444\n",
      "\n",
      "--------Epoch 165--------\n",
      "Val loss = -0.9452\n",
      "\n",
      "--------Epoch 166--------\n",
      "Val loss = -0.9427\n",
      "\n",
      "--------Epoch 167--------\n",
      "Val loss = -0.9477\n",
      "\n",
      "--------Epoch 168--------\n",
      "Val loss = -0.9477\n",
      "\n",
      "--------Epoch 169--------\n",
      "Val loss = -0.9440\n",
      "\n",
      "--------Epoch 170--------\n",
      "Val loss = -0.9446\n",
      "\n",
      "--------Epoch 171--------\n",
      "Val loss = -0.9483\n",
      "\n",
      "--------Epoch 172--------\n",
      "Val loss = -0.9453\n",
      "\n",
      "--------Epoch 173--------\n",
      "Val loss = -0.9472\n",
      "\n",
      "--------Epoch 174--------\n",
      "Val loss = -0.9464\n",
      "\n",
      "--------Epoch 175--------\n",
      "Val loss = -0.9430\n",
      "\n",
      "--------Epoch 176--------\n",
      "Val loss = -0.9432\n",
      "\n",
      "--------Epoch 177--------\n",
      "Val loss = -0.9426\n",
      "\n",
      "--------Epoch 178--------\n",
      "Val loss = -0.9439\n",
      "\n",
      "--------Epoch 179--------\n",
      "Val loss = -0.9455\n",
      "\n",
      "--------Epoch 180--------\n",
      "Val loss = -0.9464\n",
      "\n",
      "--------Epoch 181--------\n",
      "Val loss = -0.9464\n",
      "\n",
      "--------Epoch 182--------\n",
      "Val loss = -0.9454\n",
      "\n",
      "--------Epoch 183--------\n",
      "Val loss = -0.9444\n",
      "\n",
      "--------Epoch 184--------\n",
      "Val loss = -0.9440\n",
      "\n",
      "--------Epoch 185--------\n",
      "Val loss = -0.9446\n",
      "\n",
      "--------Epoch 186--------\n",
      "Val loss = -0.9417\n",
      "\n",
      "--------Epoch 187--------\n",
      "Val loss = -0.9441\n",
      "\n",
      "--------Epoch 188--------\n",
      "Val loss = -0.9441\n",
      "\n",
      "--------Epoch 189--------\n",
      "Val loss = -0.9445\n",
      "\n",
      "--------Epoch 190--------\n",
      "Val loss = -0.9449\n",
      "\n",
      "--------Epoch 191--------\n",
      "Val loss = -0.9448\n",
      "\n",
      "--------Epoch 192--------\n",
      "Val loss = -0.9450\n",
      "\n",
      "--------Epoch 193--------\n",
      "Val loss = -0.9403\n",
      "\n",
      "--------Epoch 194--------\n",
      "Val loss = -0.9442\n",
      "\n",
      "--------Epoch 195--------\n",
      "Val loss = -0.9440\n",
      "\n",
      "--------Epoch 196--------\n",
      "Val loss = -0.9434\n",
      "\n",
      "--------Epoch 197--------\n",
      "Val loss = -0.9461\n",
      "\n",
      "--------Epoch 198--------\n",
      "Val loss = -0.9453\n",
      "\n",
      "--------Epoch 199--------\n",
      "Val loss = -0.9439\n",
      "\n",
      "--------Epoch 200--------\n",
      "Val loss = -0.9437\n",
      "\n",
      "--------Epoch 201--------\n",
      "Val loss = -0.9428\n",
      "\n",
      "--------Epoch 202--------\n",
      "Val loss = -0.9427\n",
      "\n",
      "--------Epoch 203--------\n",
      "Val loss = -0.9446\n",
      "\n",
      "--------Epoch 204--------\n",
      "Val loss = -0.9440\n",
      "\n",
      "--------Epoch 205--------\n",
      "Val loss = -0.9419\n",
      "\n",
      "--------Epoch 206--------\n",
      "Val loss = -0.9417\n",
      "\n",
      "--------Epoch 207--------\n",
      "Val loss = -0.9438\n",
      "\n",
      "--------Epoch 208--------\n",
      "Val loss = -0.9446\n",
      "\n",
      "--------Epoch 209--------\n",
      "Val loss = -0.9411\n",
      "\n",
      "--------Epoch 210--------\n",
      "Val loss = -0.9419\n",
      "\n",
      "--------Epoch 211--------\n",
      "Val loss = -0.9413\n",
      "\n",
      "--------Epoch 212--------\n",
      "Val loss = -0.9422\n",
      "\n",
      "--------Epoch 213--------\n",
      "Val loss = -0.9406\n",
      "\n",
      "--------Epoch 214--------\n",
      "Val loss = -0.9416\n",
      "\n",
      "--------Epoch 215--------\n",
      "Val loss = -0.9412\n",
      "\n",
      "--------Epoch 216--------\n",
      "Val loss = -0.9399\n",
      "\n",
      "--------Epoch 217--------\n",
      "Val loss = -0.9412\n",
      "\n",
      "--------Epoch 218--------\n",
      "Val loss = -0.9396\n",
      "\n",
      "--------Epoch 219--------\n",
      "Val loss = -0.9407\n",
      "\n",
      "--------Epoch 220--------\n",
      "Val loss = -0.9457\n",
      "\n",
      "--------Epoch 221--------\n",
      "Val loss = -0.9470\n",
      "\n",
      "--------Epoch 222--------\n",
      "Val loss = -0.9424\n",
      "\n",
      "--------Epoch 223--------\n",
      "Val loss = -0.9447\n",
      "\n",
      "--------Epoch 224--------\n",
      "Val loss = -0.9427\n",
      "\n",
      "--------Epoch 225--------\n",
      "Val loss = -0.9379\n",
      "\n",
      "--------Epoch 226--------\n",
      "Val loss = -0.9383\n",
      "\n",
      "--------Epoch 227--------\n",
      "Val loss = -0.9402\n",
      "\n",
      "--------Epoch 228--------\n",
      "Val loss = -0.9378\n",
      "\n",
      "--------Epoch 229--------\n",
      "Val loss = -0.9407\n",
      "\n",
      "--------Epoch 230--------\n",
      "Val loss = -0.9380\n",
      "\n",
      "--------Epoch 231--------\n",
      "Val loss = -0.9388\n",
      "\n",
      "--------Epoch 232--------\n",
      "Val loss = -0.9376\n",
      "\n",
      "--------Epoch 233--------\n",
      "Val loss = -0.9414\n",
      "\n",
      "--------Epoch 234--------\n",
      "Val loss = -0.9381\n",
      "\n",
      "--------Epoch 235--------\n",
      "Val loss = -0.9393\n",
      "\n",
      "--------Epoch 236--------\n",
      "Val loss = -0.9409\n",
      "\n",
      "--------Epoch 237--------\n",
      "Val loss = -0.9359\n",
      "\n",
      "--------Epoch 238--------\n",
      "Val loss = -0.9403\n",
      "\n",
      "--------Epoch 239--------\n",
      "Val loss = -0.9376\n",
      "\n",
      "--------Epoch 240--------\n",
      "Val loss = -0.9409\n",
      "\n",
      "--------Epoch 241--------\n",
      "Val loss = -0.9391\n",
      "\n",
      "--------Epoch 242--------\n",
      "Val loss = -0.9412\n",
      "\n",
      "--------Epoch 243--------\n",
      "Val loss = -0.9352\n",
      "\n",
      "--------Epoch 244--------\n",
      "Val loss = -0.9370\n",
      "\n",
      "--------Epoch 245--------\n",
      "Val loss = -0.9360\n",
      "\n",
      "--------Epoch 246--------\n",
      "Val loss = -0.9346\n",
      "\n",
      "--------Epoch 247--------\n",
      "Val loss = -0.9336\n",
      "\n",
      "--------Epoch 248--------\n",
      "Val loss = -0.9381\n",
      "\n",
      "--------Epoch 249--------\n",
      "Val loss = -0.9404\n",
      "\n",
      "--------Epoch 250--------\n",
      "Val loss = -0.9356\n",
      "\n",
      "Acc = 95.19\n",
      "--------Epoch 1--------\n",
      "Val loss = -0.8833\n",
      "\n",
      "--------Epoch 2--------\n",
      "Val loss = -0.8428\n",
      "\n",
      "--------Epoch 3--------\n",
      "Val loss = -0.8189\n",
      "\n",
      "--------Epoch 4--------\n",
      "Val loss = -0.7962\n",
      "\n",
      "--------Epoch 5--------\n",
      "Val loss = -0.8087\n",
      "\n",
      "--------Epoch 6--------\n",
      "Val loss = -0.7875\n",
      "\n",
      "--------Epoch 7--------\n",
      "Val loss = -0.7811\n",
      "\n",
      "--------Epoch 8--------\n",
      "Val loss = -0.7754\n",
      "\n",
      "--------Epoch 9--------\n",
      "Val loss = -0.7663\n",
      "\n",
      "--------Epoch 10--------\n",
      "Val loss = -0.7431\n",
      "\n",
      "--------Epoch 11--------\n",
      "Val loss = -0.7574\n",
      "\n",
      "--------Epoch 12--------\n",
      "Val loss = -0.7487\n",
      "\n",
      "--------Epoch 13--------\n",
      "Val loss = -0.7535\n",
      "\n",
      "--------Epoch 14--------\n",
      "Val loss = -0.7518\n",
      "\n",
      "--------Epoch 15--------\n",
      "Val loss = -0.7568\n",
      "\n",
      "--------Epoch 16--------\n",
      "Val loss = -0.7453\n",
      "\n",
      "--------Epoch 17--------\n",
      "Val loss = -0.7549\n",
      "\n",
      "--------Epoch 18--------\n",
      "Val loss = -0.7487\n",
      "\n",
      "--------Epoch 19--------\n",
      "Val loss = -0.7686\n",
      "\n",
      "--------Epoch 20--------\n",
      "Val loss = -0.7623\n",
      "\n",
      "--------Epoch 21--------\n",
      "Val loss = -0.7545\n",
      "\n",
      "--------Epoch 22--------\n",
      "Val loss = -0.7719\n",
      "\n",
      "--------Epoch 23--------\n",
      "Val loss = -0.7730\n",
      "\n",
      "--------Epoch 24--------\n",
      "Val loss = -0.7856\n",
      "\n",
      "--------Epoch 25--------\n",
      "Val loss = -0.7682\n",
      "\n",
      "--------Epoch 26--------\n",
      "Val loss = -0.7893\n",
      "\n",
      "--------Epoch 27--------\n",
      "Val loss = -0.7961\n",
      "\n",
      "--------Epoch 28--------\n",
      "Val loss = -0.7970\n",
      "\n",
      "--------Epoch 29--------\n",
      "Val loss = -0.8012\n",
      "\n",
      "--------Epoch 30--------\n",
      "Val loss = -0.8126\n",
      "\n",
      "--------Epoch 31--------\n",
      "Val loss = -0.8049\n",
      "\n",
      "--------Epoch 32--------\n",
      "Val loss = -0.7918\n",
      "\n",
      "--------Epoch 33--------\n",
      "Val loss = -0.7892\n",
      "\n",
      "--------Epoch 34--------\n",
      "Val loss = -0.8045\n",
      "\n",
      "--------Epoch 35--------\n",
      "Val loss = -0.8231\n",
      "\n",
      "--------Epoch 36--------\n",
      "Val loss = -0.8084\n",
      "\n",
      "--------Epoch 37--------\n",
      "Val loss = -0.8129\n",
      "\n",
      "--------Epoch 38--------\n",
      "Val loss = -0.8147\n",
      "\n",
      "--------Epoch 39--------\n",
      "Val loss = -0.8088\n",
      "\n",
      "--------Epoch 40--------\n",
      "Val loss = -0.8289\n",
      "\n",
      "--------Epoch 41--------\n",
      "Val loss = -0.8212\n",
      "\n",
      "--------Epoch 42--------\n",
      "Val loss = -0.8305\n",
      "\n",
      "--------Epoch 43--------\n",
      "Val loss = -0.8332\n",
      "\n",
      "--------Epoch 44--------\n",
      "Val loss = -0.8298\n",
      "\n",
      "--------Epoch 45--------\n",
      "Val loss = -0.8402\n",
      "\n",
      "--------Epoch 46--------\n",
      "Val loss = -0.8374\n",
      "\n",
      "--------Epoch 47--------\n",
      "Val loss = -0.8291\n",
      "\n",
      "--------Epoch 48--------\n",
      "Val loss = -0.8462\n",
      "\n",
      "--------Epoch 49--------\n",
      "Val loss = -0.8355\n",
      "\n",
      "--------Epoch 50--------\n",
      "Val loss = -0.8465\n",
      "\n",
      "--------Epoch 51--------\n",
      "Val loss = -0.8424\n",
      "\n",
      "--------Epoch 52--------\n",
      "Val loss = -0.8439\n",
      "\n",
      "--------Epoch 53--------\n",
      "Val loss = -0.8498\n",
      "\n",
      "--------Epoch 54--------\n",
      "Val loss = -0.8581\n",
      "\n",
      "--------Epoch 55--------\n",
      "Val loss = -0.8630\n",
      "\n",
      "--------Epoch 56--------\n",
      "Val loss = -0.8549\n",
      "\n",
      "--------Epoch 57--------\n",
      "Val loss = -0.8671\n",
      "\n",
      "--------Epoch 58--------\n",
      "Val loss = -0.8615\n",
      "\n",
      "--------Epoch 59--------\n",
      "Val loss = -0.8701\n",
      "\n",
      "--------Epoch 60--------\n",
      "Val loss = -0.8701\n",
      "\n",
      "--------Epoch 61--------\n",
      "Val loss = -0.8736\n",
      "\n",
      "--------Epoch 62--------\n",
      "Val loss = -0.8768\n",
      "\n",
      "--------Epoch 63--------\n",
      "Val loss = -0.8744\n",
      "\n",
      "--------Epoch 64--------\n",
      "Val loss = -0.8807\n",
      "\n",
      "--------Epoch 65--------\n",
      "Val loss = -0.8832\n",
      "\n",
      "--------Epoch 66--------\n",
      "Val loss = -0.8817\n",
      "\n",
      "--------Epoch 67--------\n",
      "Val loss = -0.8925\n",
      "\n",
      "--------Epoch 68--------\n",
      "Val loss = -0.8905\n",
      "\n",
      "--------Epoch 69--------\n",
      "Val loss = -0.8956\n",
      "\n",
      "--------Epoch 70--------\n",
      "Val loss = -0.8992\n",
      "\n",
      "--------Epoch 71--------\n",
      "Val loss = -0.8971\n",
      "\n",
      "--------Epoch 72--------\n",
      "Val loss = -0.8955\n",
      "\n",
      "--------Epoch 73--------\n",
      "Val loss = -0.9033\n",
      "\n",
      "--------Epoch 74--------\n",
      "Val loss = -0.9073\n",
      "\n",
      "--------Epoch 75--------\n",
      "Val loss = -0.9027\n",
      "\n",
      "--------Epoch 76--------\n",
      "Val loss = -0.9094\n",
      "\n",
      "--------Epoch 77--------\n",
      "Val loss = -0.9130\n",
      "\n",
      "--------Epoch 78--------\n",
      "Val loss = -0.9135\n",
      "\n",
      "--------Epoch 79--------\n",
      "Val loss = -0.9196\n",
      "\n",
      "--------Epoch 80--------\n",
      "Val loss = -0.9212\n",
      "\n",
      "--------Epoch 81--------\n",
      "Val loss = -0.9225\n",
      "\n",
      "--------Epoch 82--------\n",
      "Val loss = -0.9247\n",
      "\n",
      "--------Epoch 83--------\n",
      "Val loss = -0.9259\n",
      "\n",
      "--------Epoch 84--------\n",
      "Val loss = -0.9244\n",
      "\n",
      "--------Epoch 85--------\n",
      "Val loss = -0.9344\n",
      "\n",
      "--------Epoch 86--------\n",
      "Val loss = -0.9322\n",
      "\n",
      "--------Epoch 87--------\n",
      "Val loss = -0.9303\n",
      "\n",
      "--------Epoch 88--------\n",
      "Val loss = -0.9339\n",
      "\n",
      "--------Epoch 89--------\n",
      "Val loss = -0.9362\n",
      "\n",
      "--------Epoch 90--------\n",
      "Val loss = -0.9398\n",
      "\n",
      "--------Epoch 91--------\n",
      "Val loss = -0.9389\n",
      "\n",
      "--------Epoch 92--------\n",
      "Val loss = -0.9431\n",
      "\n",
      "--------Epoch 93--------\n",
      "Val loss = -0.9447\n",
      "\n",
      "--------Epoch 94--------\n",
      "Val loss = -0.9468\n",
      "\n",
      "--------Epoch 95--------\n",
      "Val loss = -0.9451\n",
      "\n",
      "--------Epoch 96--------\n",
      "Val loss = -0.9471\n",
      "\n",
      "--------Epoch 97--------\n",
      "Val loss = -0.9453\n",
      "\n",
      "--------Epoch 98--------\n",
      "Val loss = -0.9502\n",
      "\n",
      "--------Epoch 99--------\n",
      "Val loss = -0.9504\n",
      "\n",
      "--------Epoch 100--------\n",
      "Val loss = -0.9460\n",
      "\n",
      "--------Epoch 101--------\n",
      "Val loss = -0.9487\n",
      "\n",
      "--------Epoch 102--------\n",
      "Val loss = -0.9468\n",
      "\n",
      "--------Epoch 103--------\n",
      "Val loss = -0.9504\n",
      "\n",
      "--------Epoch 104--------\n",
      "Val loss = -0.9538\n",
      "\n",
      "--------Epoch 105--------\n",
      "Val loss = -0.9535\n",
      "\n",
      "--------Epoch 106--------\n",
      "Val loss = -0.9555\n",
      "\n",
      "--------Epoch 107--------\n",
      "Val loss = -0.9554\n",
      "\n",
      "--------Epoch 108--------\n",
      "Val loss = -0.9543\n",
      "\n",
      "--------Epoch 109--------\n",
      "Val loss = -0.9525\n",
      "\n",
      "--------Epoch 110--------\n",
      "Val loss = -0.9557\n",
      "\n",
      "--------Epoch 111--------\n",
      "Val loss = -0.9556\n",
      "\n",
      "--------Epoch 112--------\n",
      "Val loss = -0.9548\n",
      "\n",
      "--------Epoch 113--------\n",
      "Val loss = -0.9524\n",
      "\n",
      "--------Epoch 114--------\n",
      "Val loss = -0.9566\n",
      "\n",
      "--------Epoch 115--------\n",
      "Val loss = -0.9556\n",
      "\n",
      "--------Epoch 116--------\n",
      "Val loss = -0.9547\n",
      "\n",
      "--------Epoch 117--------\n",
      "Val loss = -0.9582\n",
      "\n",
      "--------Epoch 118--------\n",
      "Val loss = -0.9547\n",
      "\n",
      "--------Epoch 119--------\n",
      "Val loss = -0.9547\n",
      "\n",
      "--------Epoch 120--------\n",
      "Val loss = -0.9570\n",
      "\n",
      "--------Epoch 121--------\n",
      "Val loss = -0.9563\n",
      "\n",
      "--------Epoch 122--------\n",
      "Val loss = -0.9578\n",
      "\n",
      "--------Epoch 123--------\n",
      "Val loss = -0.9589\n",
      "\n",
      "--------Epoch 124--------\n",
      "Val loss = -0.9584\n",
      "\n",
      "--------Epoch 125--------\n",
      "Val loss = -0.9562\n",
      "\n",
      "--------Epoch 126--------\n",
      "Val loss = -0.9578\n",
      "\n",
      "--------Epoch 127--------\n",
      "Val loss = -0.9579\n",
      "\n",
      "--------Epoch 128--------\n",
      "Val loss = -0.9571\n",
      "\n",
      "--------Epoch 129--------\n",
      "Val loss = -0.9579\n",
      "\n",
      "--------Epoch 130--------\n",
      "Val loss = -0.9579\n",
      "\n",
      "--------Epoch 131--------\n",
      "Val loss = -0.9575\n",
      "\n",
      "--------Epoch 132--------\n",
      "Val loss = -0.9576\n",
      "\n",
      "--------Epoch 133--------\n",
      "Val loss = -0.9582\n",
      "\n",
      "--------Epoch 134--------\n",
      "Val loss = -0.9583\n",
      "\n",
      "--------Epoch 135--------\n",
      "Val loss = -0.9582\n",
      "\n",
      "--------Epoch 136--------\n",
      "Val loss = -0.9579\n",
      "\n",
      "--------Epoch 137--------\n",
      "Val loss = -0.9591\n",
      "\n",
      "--------Epoch 138--------\n",
      "Val loss = -0.9597\n",
      "\n",
      "--------Epoch 139--------\n",
      "Val loss = -0.9581\n",
      "\n",
      "--------Epoch 140--------\n",
      "Val loss = -0.9626\n",
      "\n",
      "--------Epoch 141--------\n",
      "Val loss = -0.9593\n",
      "\n",
      "--------Epoch 142--------\n",
      "Val loss = -0.9602\n",
      "\n",
      "--------Epoch 143--------\n",
      "Val loss = -0.9580\n",
      "\n",
      "--------Epoch 144--------\n",
      "Val loss = -0.9582\n",
      "\n",
      "--------Epoch 145--------\n",
      "Val loss = -0.9594\n",
      "\n",
      "--------Epoch 146--------\n",
      "Val loss = -0.9594\n",
      "\n",
      "--------Epoch 147--------\n",
      "Val loss = -0.9583\n",
      "\n",
      "--------Epoch 148--------\n",
      "Val loss = -0.9580\n",
      "\n",
      "--------Epoch 149--------\n",
      "Val loss = -0.9606\n",
      "\n",
      "--------Epoch 150--------\n",
      "Val loss = -0.9608\n",
      "\n",
      "--------Epoch 151--------\n",
      "Val loss = -0.9592\n",
      "\n",
      "--------Epoch 152--------\n",
      "Val loss = -0.9606\n",
      "\n",
      "--------Epoch 153--------\n",
      "Val loss = -0.9584\n",
      "\n",
      "--------Epoch 154--------\n",
      "Val loss = -0.9607\n",
      "\n",
      "--------Epoch 155--------\n",
      "Val loss = -0.9586\n",
      "\n",
      "--------Epoch 156--------\n",
      "Val loss = -0.9570\n",
      "\n",
      "--------Epoch 157--------\n",
      "Val loss = -0.9564\n",
      "\n",
      "--------Epoch 158--------\n",
      "Val loss = -0.9552\n",
      "\n",
      "--------Epoch 159--------\n",
      "Val loss = -0.9593\n",
      "\n",
      "--------Epoch 160--------\n",
      "Val loss = -0.9603\n",
      "\n",
      "--------Epoch 161--------\n",
      "Val loss = -0.9565\n",
      "\n",
      "--------Epoch 162--------\n",
      "Val loss = -0.9573\n",
      "\n",
      "--------Epoch 163--------\n",
      "Val loss = -0.9598\n",
      "\n",
      "--------Epoch 164--------\n",
      "Val loss = -0.9573\n",
      "\n",
      "--------Epoch 165--------\n",
      "Val loss = -0.9590\n",
      "\n",
      "--------Epoch 166--------\n",
      "Val loss = -0.9572\n",
      "\n",
      "--------Epoch 167--------\n",
      "Val loss = -0.9569\n",
      "\n",
      "--------Epoch 168--------\n",
      "Val loss = -0.9597\n",
      "\n",
      "--------Epoch 169--------\n",
      "Val loss = -0.9565\n",
      "\n",
      "--------Epoch 170--------\n",
      "Val loss = -0.9580\n",
      "\n",
      "--------Epoch 171--------\n",
      "Val loss = -0.9578\n",
      "\n",
      "--------Epoch 172--------\n",
      "Val loss = -0.9571\n",
      "\n",
      "--------Epoch 173--------\n",
      "Val loss = -0.9578\n",
      "\n",
      "--------Epoch 174--------\n",
      "Val loss = -0.9590\n",
      "\n",
      "--------Epoch 175--------\n",
      "Val loss = -0.9554\n",
      "\n",
      "--------Epoch 176--------\n",
      "Val loss = -0.9539\n",
      "\n",
      "--------Epoch 177--------\n",
      "Val loss = -0.9566\n",
      "\n",
      "--------Epoch 178--------\n",
      "Val loss = -0.9531\n",
      "\n",
      "--------Epoch 179--------\n",
      "Val loss = -0.9557\n",
      "\n",
      "--------Epoch 180--------\n",
      "Val loss = -0.9554\n",
      "\n",
      "--------Epoch 181--------\n",
      "Val loss = -0.9561\n",
      "\n",
      "--------Epoch 182--------\n",
      "Val loss = -0.9558\n",
      "\n",
      "--------Epoch 183--------\n",
      "Val loss = -0.9561\n",
      "\n",
      "--------Epoch 184--------\n",
      "Val loss = -0.9557\n",
      "\n",
      "--------Epoch 185--------\n",
      "Val loss = -0.9571\n",
      "\n",
      "--------Epoch 186--------\n",
      "Val loss = -0.9588\n",
      "\n",
      "--------Epoch 187--------\n",
      "Val loss = -0.9561\n",
      "\n",
      "--------Epoch 188--------\n",
      "Val loss = -0.9584\n",
      "\n",
      "--------Epoch 189--------\n",
      "Val loss = -0.9535\n",
      "\n",
      "--------Epoch 190--------\n",
      "Val loss = -0.9557\n",
      "\n",
      "--------Epoch 191--------\n",
      "Val loss = -0.9565\n",
      "\n",
      "--------Epoch 192--------\n",
      "Val loss = -0.9559\n",
      "\n",
      "--------Epoch 193--------\n",
      "Val loss = -0.9557\n",
      "\n",
      "--------Epoch 194--------\n",
      "Val loss = -0.9546\n",
      "\n",
      "--------Epoch 195--------\n",
      "Val loss = -0.9523\n",
      "\n",
      "--------Epoch 196--------\n",
      "Val loss = -0.9534\n",
      "\n",
      "--------Epoch 197--------\n",
      "Val loss = -0.9495\n",
      "\n",
      "--------Epoch 198--------\n",
      "Val loss = -0.9533\n",
      "\n",
      "--------Epoch 199--------\n",
      "Val loss = -0.9538\n",
      "\n",
      "--------Epoch 200--------\n",
      "Val loss = -0.9511\n",
      "\n",
      "--------Epoch 201--------\n",
      "Val loss = -0.9544\n",
      "\n",
      "--------Epoch 202--------\n",
      "Val loss = -0.9545\n",
      "\n",
      "--------Epoch 203--------\n",
      "Val loss = -0.9535\n",
      "\n",
      "--------Epoch 204--------\n",
      "Val loss = -0.9532\n",
      "\n",
      "--------Epoch 205--------\n",
      "Val loss = -0.9534\n",
      "\n",
      "--------Epoch 206--------\n",
      "Val loss = -0.9548\n",
      "\n",
      "--------Epoch 207--------\n",
      "Val loss = -0.9523\n",
      "\n",
      "--------Epoch 208--------\n",
      "Val loss = -0.9531\n",
      "\n",
      "--------Epoch 209--------\n",
      "Val loss = -0.9513\n",
      "\n",
      "--------Epoch 210--------\n",
      "Val loss = -0.9506\n",
      "\n",
      "--------Epoch 211--------\n",
      "Val loss = -0.9545\n",
      "\n",
      "--------Epoch 212--------\n",
      "Val loss = -0.9544\n",
      "\n",
      "--------Epoch 213--------\n",
      "Val loss = -0.9532\n",
      "\n",
      "--------Epoch 214--------\n",
      "Val loss = -0.9516\n",
      "\n",
      "--------Epoch 215--------\n",
      "Val loss = -0.9536\n",
      "\n",
      "--------Epoch 216--------\n",
      "Val loss = -0.9521\n",
      "\n",
      "--------Epoch 217--------\n",
      "Val loss = -0.9530\n",
      "\n",
      "--------Epoch 218--------\n",
      "Val loss = -0.9518\n",
      "\n",
      "--------Epoch 219--------\n",
      "Val loss = -0.9528\n",
      "\n",
      "--------Epoch 220--------\n",
      "Val loss = -0.9514\n",
      "\n",
      "--------Epoch 221--------\n",
      "Val loss = -0.9498\n",
      "\n",
      "--------Epoch 222--------\n",
      "Val loss = -0.9507\n",
      "\n",
      "--------Epoch 223--------\n",
      "Val loss = -0.9537\n",
      "\n",
      "--------Epoch 224--------\n",
      "Val loss = -0.9515\n",
      "\n",
      "--------Epoch 225--------\n",
      "Val loss = -0.9526\n",
      "\n",
      "--------Epoch 226--------\n",
      "Val loss = -0.9496\n",
      "\n",
      "--------Epoch 227--------\n",
      "Val loss = -0.9510\n",
      "\n",
      "--------Epoch 228--------\n",
      "Val loss = -0.9528\n",
      "\n",
      "--------Epoch 229--------\n",
      "Val loss = -0.9511\n",
      "\n",
      "--------Epoch 230--------\n",
      "Val loss = -0.9515\n",
      "\n",
      "--------Epoch 231--------\n",
      "Val loss = -0.9471\n",
      "\n",
      "--------Epoch 232--------\n",
      "Val loss = -0.9487\n",
      "\n",
      "--------Epoch 233--------\n",
      "Val loss = -0.9498\n",
      "\n",
      "--------Epoch 234--------\n",
      "Val loss = -0.9515\n",
      "\n",
      "--------Epoch 235--------\n",
      "Val loss = -0.9476\n",
      "\n",
      "--------Epoch 236--------\n",
      "Val loss = -0.9515\n",
      "\n",
      "--------Epoch 237--------\n",
      "Val loss = -0.9484\n",
      "\n",
      "--------Epoch 238--------\n",
      "Val loss = -0.9481\n",
      "\n",
      "--------Epoch 239--------\n",
      "Val loss = -0.9479\n",
      "\n",
      "--------Epoch 240--------\n",
      "Val loss = -0.9469\n",
      "\n",
      "--------Epoch 241--------\n",
      "Val loss = -0.9457\n",
      "\n",
      "--------Epoch 242--------\n",
      "Val loss = -0.9446\n",
      "\n",
      "--------Epoch 243--------\n",
      "Val loss = -0.9445\n",
      "\n",
      "--------Epoch 244--------\n",
      "Val loss = -0.9441\n",
      "\n",
      "--------Epoch 245--------\n",
      "Val loss = -0.9427\n",
      "\n",
      "--------Epoch 246--------\n",
      "Val loss = -0.9458\n",
      "\n",
      "--------Epoch 247--------\n",
      "Val loss = -0.9434\n",
      "\n",
      "--------Epoch 248--------\n",
      "Val loss = -0.9447\n",
      "\n",
      "--------Epoch 249--------\n",
      "Val loss = -0.9447\n",
      "\n",
      "--------Epoch 250--------\n",
      "Val loss = -0.9454\n",
      "\n",
      "Acc = 95.90\n"
     ]
    }
   ],
   "source": [
    "# Set up accuracy\n",
    "acc_list = []\n",
    "\n",
    "# Set up selector\n",
    "selector = nn.Sequential(\n",
    "    nn.Linear(d_in * 2, 512),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(512, 512),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(512, d_in))\n",
    "selector_layer = ConcreteSelector()\n",
    "gafs = GreedyAdaptiveFS(selector, deepcopy(model), mask_layer, selector_layer).to(device)\n",
    "\n",
    "# Tie weights\n",
    "selector[0].weight = nn.Parameter(gafs.model[0].weight)\n",
    "selector[0].bias   = nn.Parameter(gafs.model[0].bias)\n",
    "selector[2].weight = nn.Parameter(gafs.model[2].weight)\n",
    "selector[2].bias   = nn.Parameter(gafs.model[2].bias)\n",
    "\n",
    "for num in max_features:\n",
    "    # Train\n",
    "    gafs.fit(train_dataset,\n",
    "             val_dataset,\n",
    "             mbsize=128,\n",
    "             lr=2e-4,\n",
    "             nepochs=250,\n",
    "             max_features=num,\n",
    "             loss_fn=nn.CrossEntropyLoss(),\n",
    "             val_loss_fn=NegAccuracy(),\n",
    "             argmax=False,\n",
    "             no_repeats=False,\n",
    "             start_temp=10.0,\n",
    "             end_temp=0.01)\n",
    "    \n",
    "    # Get accuracy\n",
    "    test_acc = gafs.evaluate(test_dataset, num, Accuracy(), 1024)\n",
    "    print(f'Acc = {100*test_acc:.2f}')\n",
    "    acc_list.append(test_acc)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "sharp-layout",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.7062999967575073, 0.8753999994277954, 0.9239000005722046, 0.9518999997138977, 0.9589999966621399]\n"
     ]
    }
   ],
   "source": [
    "print(acc_list)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "47e04e17-12b8-4388-a7b6-91a1b467e86f",
   "metadata": {},
   "source": [
    "# Plot results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "2924f80c-92ec-49ce-b4b9-0a9f15a27985",
   "metadata": {},
   "outputs": [],
   "source": [
    "global_acc = [0.5562999975204468, 0.7678000000953674, 0.8604000005722046, 0.9107000004768372, 0.9193000002861023]\n",
    "adaptive_acc = [0.7062999967575073, 0.8753999994277954, 0.9239000005722046, 0.9518999997138977, 0.9589999966621399]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "07f3eb71-67ee-4f2b-9144-5566b913eb73",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(9, 6))\n",
    "\n",
    "# Plot\n",
    "plt.plot(max_features, global_acc, color='tab:blue', marker='o', markersize=20, label='Global')\n",
    "plt.plot(max_features, adaptive_acc, color='tab:green', marker='*', markersize=20, label='Ours')\n",
    "\n",
    "# # Plot and scatter\n",
    "# plt.plot(max_features, global_acc, color='tab:blue')\n",
    "# plt.plot(max_features, adaptive_acc, color='tab:green')\n",
    "# plt.scatter(max_features, global_acc, color='tab:blue', marker='o', s=20, label='Global')\n",
    "# plt.scatter(max_features, adaptive_acc, color='tab:green', marker='*', s=20, label='Ours')\n",
    "\n",
    "# Legend\n",
    "plt.legend(loc='lower right', frameon=False)\n",
    "\n",
    "# Labels\n",
    "plt.xlabel('# Features', fontsize=18)\n",
    "plt.ylabel('Accuracy', fontsize=18)\n",
    "plt.tick_params(labelsize=16)\n",
    "plt.title('MNIST Feature Selection')\n",
    "\n",
    "# Axis spines\n",
    "plt.gca().spines['right'].set_visible(False)\n",
    "plt.gca().spines['top'].set_visible(False)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "970af148-b5ba-48bc-8631-dbe1bba76c41",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
