{
 "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "fixed-decline",
   "metadata": {},
   "outputs": [],
   "source": [
    "device = torch.device('cuda', 5)"
   ]
  },
  {
   "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",
    "num_features = (5, 10, 15, 20, 25)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "perceived-blind",
   "metadata": {},
   "source": [
    "# Pretrain predictor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "503c1728-3310-4a51-8bd6-c900bd000506",
   "metadata": {},
   "outputs": [],
   "source": [
    "from adaptive import MaskLayer, MaskingPretrainer\n",
    "from torchmetrics import Accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "separate-going",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# Set up model\n",
    "predictor = 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 = MaskingPretrainer(predictor, 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(num_features),\n",
    "             loss_fn=nn.CrossEntropyLoss(),\n",
    "             val_loss_fn=Accuracy(),\n",
    "             val_loss_mode='max')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "db6522d0-0539-4bc5-9b2a-6912bcbf730c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Save model\n",
    "predictor.cpu()\n",
    "torch.save(predictor, 'mnist_pretrained.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "abc41843-29c5-42c2-9a9a-eb0227eacd5e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Sequential(\n",
       "  (0): Linear(in_features=1568, out_features=512, bias=True)\n",
       "  (1): ReLU()\n",
       "  (2): Linear(in_features=512, out_features=512, bias=True)\n",
       "  (3): ReLU()\n",
       "  (4): Linear(in_features=512, out_features=10, bias=True)\n",
       ")"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Load model\n",
    "predictor = torch.load('mnist_pretrained.pt')\n",
    "predictor.to(device)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ethical-terry",
   "metadata": {},
   "source": [
    "# Adaptive selection"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "59bffcaf-df21-4f33-9b16-bb7169b5582a",
   "metadata": {},
   "outputs": [],
   "source": [
    "from adaptive import AdaptiveSelection"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "identical-single",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting training with temp = 1.0000\n",
      "\n",
      "--------Epoch 1 (1 total)--------\n",
      "Val loss = 0.6472, Zero temp loss = 0.5305\n",
      "\n",
      "--------Epoch 2 (2 total)--------\n",
      "Val loss = 0.6563, Zero temp loss = 0.5039\n",
      "\n",
      "--------Epoch 3 (3 total)--------\n",
      "Val loss = 0.6826, Zero temp loss = 0.4898\n",
      "\n",
      "--------Epoch 4 (4 total)--------\n",
      "Val loss = 0.6990, Zero temp loss = 0.4726\n",
      "\n",
      "--------Epoch 5 (5 total)--------\n",
      "Val loss = 0.7170, Zero temp loss = 0.4494\n",
      "\n",
      "--------Epoch 6 (6 total)--------\n",
      "Val loss = 0.7309, Zero temp loss = 0.4393\n",
      "\n",
      "--------Epoch 7 (7 total)--------\n",
      "Val loss = 0.7371, Zero temp loss = 0.4335\n",
      "\n",
      "--------Epoch 8 (8 total)--------\n",
      "Val loss = 0.7472, Zero temp loss = 0.4160\n",
      "\n",
      "--------Epoch 9 (9 total)--------\n",
      "Val loss = 0.7604, Zero temp loss = 0.4210\n",
      "\n",
      "--------Epoch 10 (10 total)--------\n",
      "Val loss = 0.7684, Zero temp loss = 0.4164\n",
      "\n",
      "--------Epoch 11 (11 total)--------\n",
      "Val loss = 0.7737, Zero temp loss = 0.4024\n",
      "\n",
      "--------Epoch 12 (12 total)--------\n",
      "Val loss = 0.7788, Zero temp loss = 0.3968\n",
      "\n",
      "--------Epoch 13 (13 total)--------\n",
      "Val loss = 0.7896, Zero temp loss = 0.3925\n",
      "\n",
      "--------Epoch 14 (14 total)--------\n",
      "Val loss = 0.7952, Zero temp loss = 0.3891\n",
      "\n",
      "--------Epoch 15 (15 total)--------\n",
      "Val loss = 0.7990, Zero temp loss = 0.3862\n",
      "\n",
      "--------Epoch 16 (16 total)--------\n",
      "Val loss = 0.8143, Zero temp loss = 0.3792\n",
      "\n",
      "--------Epoch 17 (17 total)--------\n",
      "Val loss = 0.8109, Zero temp loss = 0.3745\n",
      "\n",
      "--------Epoch 18 (18 total)--------\n",
      "Val loss = 0.8121, Zero temp loss = 0.3691\n",
      "\n",
      "--------Epoch 19 (19 total)--------\n",
      "Val loss = 0.8167, Zero temp loss = 0.3682\n",
      "\n",
      "--------Epoch 20 (20 total)--------\n",
      "Val loss = 0.8173, Zero temp loss = 0.3707\n",
      "\n",
      "--------Epoch 21 (21 total)--------\n",
      "Val loss = 0.8292, Zero temp loss = 0.3715\n",
      "\n",
      "--------Epoch 22 (22 total)--------\n",
      "Val loss = 0.8284, Zero temp loss = 0.3681\n",
      "\n",
      "--------Epoch 23 (23 total)--------\n",
      "Val loss = 0.8342, Zero temp loss = 0.3620\n",
      "\n",
      "--------Epoch 24 (24 total)--------\n",
      "Val loss = 0.8356, Zero temp loss = 0.3586\n",
      "\n",
      "--------Epoch 25 (25 total)--------\n",
      "Val loss = 0.8402, Zero temp loss = 0.3601\n",
      "\n",
      "--------Epoch 26 (26 total)--------\n",
      "Val loss = 0.8398, Zero temp loss = 0.3593\n",
      "\n",
      "--------Epoch 27 (27 total)--------\n",
      "Val loss = 0.8448, Zero temp loss = 0.3538\n",
      "\n",
      "--------Epoch 28 (28 total)--------\n",
      "Val loss = 0.8459, Zero temp loss = 0.3594\n",
      "\n",
      "--------Epoch 29 (29 total)--------\n",
      "Val loss = 0.8482, Zero temp loss = 0.3473\n",
      "\n",
      "--------Epoch 30 (30 total)--------\n",
      "Val loss = 0.8467, Zero temp loss = 0.3489\n",
      "\n",
      "--------Epoch 31 (31 total)--------\n",
      "Val loss = 0.8464, Zero temp loss = 0.3476\n",
      "\n",
      "--------Epoch 32 (32 total)--------\n",
      "Val loss = 0.8423, Zero temp loss = 0.3325\n",
      "\n",
      "Epoch    32: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 33 (33 total)--------\n",
      "Val loss = 0.8731, Zero temp loss = 0.3716\n",
      "\n",
      "--------Epoch 34 (34 total)--------\n",
      "Val loss = 0.8686, Zero temp loss = 0.3641\n",
      "\n",
      "--------Epoch 35 (35 total)--------\n",
      "Val loss = 0.8738, Zero temp loss = 0.3816\n",
      "\n",
      "--------Epoch 36 (36 total)--------\n",
      "Val loss = 0.8741, Zero temp loss = 0.3731\n",
      "\n",
      "--------Epoch 37 (37 total)--------\n",
      "Val loss = 0.8737, Zero temp loss = 0.3660\n",
      "\n",
      "--------Epoch 38 (38 total)--------\n",
      "Val loss = 0.8794, Zero temp loss = 0.3759\n",
      "\n",
      "--------Epoch 39 (39 total)--------\n",
      "Val loss = 0.8789, Zero temp loss = 0.3706\n",
      "\n",
      "--------Epoch 40 (40 total)--------\n",
      "Val loss = 0.8791, Zero temp loss = 0.3750\n",
      "\n",
      "--------Epoch 41 (41 total)--------\n",
      "Val loss = 0.8805, Zero temp loss = 0.3722\n",
      "\n",
      "--------Epoch 42 (42 total)--------\n",
      "Val loss = 0.8830, Zero temp loss = 0.3638\n",
      "\n",
      "--------Epoch 43 (43 total)--------\n",
      "Val loss = 0.8814, Zero temp loss = 0.3614\n",
      "\n",
      "--------Epoch 44 (44 total)--------\n",
      "Val loss = 0.8861, Zero temp loss = 0.3664\n",
      "\n",
      "--------Epoch 45 (45 total)--------\n",
      "Val loss = 0.8850, Zero temp loss = 0.3565\n",
      "\n",
      "--------Epoch 46 (46 total)--------\n",
      "Val loss = 0.8864, Zero temp loss = 0.3593\n",
      "\n",
      "--------Epoch 47 (47 total)--------\n",
      "Val loss = 0.8809, Zero temp loss = 0.3657\n",
      "\n",
      "--------Epoch 48 (48 total)--------\n",
      "Val loss = 0.8880, Zero temp loss = 0.3632\n",
      "\n",
      "--------Epoch 49 (49 total)--------\n",
      "Val loss = 0.8882, Zero temp loss = 0.3681\n",
      "\n",
      "--------Epoch 50 (50 total)--------\n",
      "Val loss = 0.8814, Zero temp loss = 0.3527\n",
      "\n",
      "--------Epoch 51 (51 total)--------\n",
      "Val loss = 0.8886, Zero temp loss = 0.3608\n",
      "\n",
      "--------Epoch 52 (52 total)--------\n",
      "Val loss = 0.8861, Zero temp loss = 0.3612\n",
      "\n",
      "--------Epoch 53 (53 total)--------\n",
      "Val loss = 0.8881, Zero temp loss = 0.3568\n",
      "\n",
      "--------Epoch 54 (54 total)--------\n",
      "Val loss = 0.8892, Zero temp loss = 0.3579\n",
      "\n",
      "--------Epoch 55 (55 total)--------\n",
      "Val loss = 0.8904, Zero temp loss = 0.3588\n",
      "\n",
      "--------Epoch 56 (56 total)--------\n",
      "Val loss = 0.8945, Zero temp loss = 0.3513\n",
      "\n",
      "--------Epoch 57 (57 total)--------\n",
      "Val loss = 0.8903, Zero temp loss = 0.3632\n",
      "\n",
      "--------Epoch 58 (58 total)--------\n",
      "Val loss = 0.8917, Zero temp loss = 0.3625\n",
      "\n",
      "--------Epoch 59 (59 total)--------\n",
      "Val loss = 0.8912, Zero temp loss = 0.3521\n",
      "\n",
      "Epoch    59: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 60 (60 total)--------\n",
      "Val loss = 0.8961, Zero temp loss = 0.3610\n",
      "\n",
      "--------Epoch 61 (61 total)--------\n",
      "Val loss = 0.8973, Zero temp loss = 0.3631\n",
      "\n",
      "--------Epoch 62 (62 total)--------\n",
      "Val loss = 0.8960, Zero temp loss = 0.3689\n",
      "\n",
      "--------Epoch 63 (63 total)--------\n",
      "Val loss = 0.8978, Zero temp loss = 0.3747\n",
      "\n",
      "--------Epoch 64 (64 total)--------\n",
      "Val loss = 0.8953, Zero temp loss = 0.3590\n",
      "\n",
      "--------Epoch 65 (65 total)--------\n",
      "Val loss = 0.8912, Zero temp loss = 0.3716\n",
      "\n",
      "--------Epoch 66 (66 total)--------\n",
      "Val loss = 0.8956, Zero temp loss = 0.3641\n",
      "\n",
      "Epoch    66: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 67 (67 total)--------\n",
      "Val loss = 0.8978, Zero temp loss = 0.3634\n",
      "\n",
      "--------Epoch 68 (68 total)--------\n",
      "Val loss = 0.8943, Zero temp loss = 0.3683\n",
      "\n",
      "--------Epoch 69 (69 total)--------\n",
      "Val loss = 0.8973, Zero temp loss = 0.3643\n",
      "\n",
      "--------Epoch 70 (70 total)--------\n",
      "Val loss = 0.8962, Zero temp loss = 0.3732\n",
      "\n",
      "--------Epoch 71 (71 total)--------\n",
      "Val loss = 0.8971, Zero temp loss = 0.3703\n",
      "\n",
      "Stopping temp = 1.0000 at epoch 71\n",
      "\n",
      "Starting training with temp = 0.5623\n",
      "\n",
      "--------Epoch 1 (72 total)--------\n",
      "Val loss = 0.7209, Zero temp loss = 0.4087\n",
      "\n",
      "--------Epoch 2 (73 total)--------\n",
      "Val loss = 0.7218, Zero temp loss = 0.4167\n",
      "\n",
      "--------Epoch 3 (74 total)--------\n",
      "Val loss = 0.7324, Zero temp loss = 0.4260\n",
      "\n",
      "--------Epoch 4 (75 total)--------\n",
      "Val loss = 0.7334, Zero temp loss = 0.4355\n",
      "\n",
      "--------Epoch 5 (76 total)--------\n",
      "Val loss = 0.7327, Zero temp loss = 0.4267\n",
      "\n",
      "--------Epoch 6 (77 total)--------\n",
      "Val loss = 0.7353, Zero temp loss = 0.4261\n",
      "\n",
      "--------Epoch 7 (78 total)--------\n",
      "Val loss = 0.7427, Zero temp loss = 0.4378\n",
      "\n",
      "--------Epoch 8 (79 total)--------\n",
      "Val loss = 0.7399, Zero temp loss = 0.4338\n",
      "\n",
      "--------Epoch 9 (80 total)--------\n",
      "Val loss = 0.7490, Zero temp loss = 0.4417\n",
      "\n",
      "--------Epoch 10 (81 total)--------\n",
      "Val loss = 0.7474, Zero temp loss = 0.4471\n",
      "\n",
      "--------Epoch 11 (82 total)--------\n",
      "Val loss = 0.7541, Zero temp loss = 0.4323\n",
      "\n",
      "--------Epoch 12 (83 total)--------\n",
      "Val loss = 0.7483, Zero temp loss = 0.4349\n",
      "\n",
      "--------Epoch 13 (84 total)--------\n",
      "Val loss = 0.7530, Zero temp loss = 0.4394\n",
      "\n",
      "--------Epoch 14 (85 total)--------\n",
      "Val loss = 0.7523, Zero temp loss = 0.4407\n",
      "\n",
      "Epoch    14: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 15 (86 total)--------\n",
      "Val loss = 0.7770, Zero temp loss = 0.4657\n",
      "\n",
      "--------Epoch 16 (87 total)--------\n",
      "Val loss = 0.7855, Zero temp loss = 0.4634\n",
      "\n",
      "--------Epoch 17 (88 total)--------\n",
      "Val loss = 0.7866, Zero temp loss = 0.4600\n",
      "\n",
      "--------Epoch 18 (89 total)--------\n",
      "Val loss = 0.7843, Zero temp loss = 0.4691\n",
      "\n",
      "--------Epoch 19 (90 total)--------\n",
      "Val loss = 0.7961, Zero temp loss = 0.4595\n",
      "\n",
      "--------Epoch 20 (91 total)--------\n",
      "Val loss = 0.7955, Zero temp loss = 0.4639\n",
      "\n",
      "--------Epoch 21 (92 total)--------\n",
      "Val loss = 0.7973, Zero temp loss = 0.4593\n",
      "\n",
      "--------Epoch 22 (93 total)--------\n",
      "Val loss = 0.7897, Zero temp loss = 0.4576\n",
      "\n",
      "--------Epoch 23 (94 total)--------\n",
      "Val loss = 0.7954, Zero temp loss = 0.4584\n",
      "\n",
      "--------Epoch 24 (95 total)--------\n",
      "Val loss = 0.7924, Zero temp loss = 0.4506\n",
      "\n",
      "Epoch    24: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 25 (96 total)--------\n",
      "Val loss = 0.8071, Zero temp loss = 0.4709\n",
      "\n",
      "--------Epoch 26 (97 total)--------\n",
      "Val loss = 0.8045, Zero temp loss = 0.4700\n",
      "\n",
      "--------Epoch 27 (98 total)--------\n",
      "Val loss = 0.8048, Zero temp loss = 0.4663\n",
      "\n",
      "--------Epoch 28 (99 total)--------\n",
      "Val loss = 0.8051, Zero temp loss = 0.4648\n",
      "\n",
      "Epoch    28: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 29 (100 total)--------\n",
      "Val loss = 0.8086, Zero temp loss = 0.4683\n",
      "\n",
      "--------Epoch 30 (101 total)--------\n",
      "Val loss = 0.8053, Zero temp loss = 0.4701\n",
      "\n",
      "--------Epoch 31 (102 total)--------\n",
      "Val loss = 0.8023, Zero temp loss = 0.4670\n",
      "\n",
      "--------Epoch 32 (103 total)--------\n",
      "Val loss = 0.8008, Zero temp loss = 0.4683\n",
      "\n",
      "--------Epoch 33 (104 total)--------\n",
      "Val loss = 0.8041, Zero temp loss = 0.4697\n",
      "\n",
      "Stopping temp = 0.5623 at epoch 33\n",
      "\n",
      "Starting training with temp = 0.3162\n",
      "\n",
      "--------Epoch 1 (105 total)--------\n",
      "Val loss = 0.6550, Zero temp loss = 0.5211\n",
      "\n",
      "--------Epoch 2 (106 total)--------\n",
      "Val loss = 0.6529, Zero temp loss = 0.5349\n",
      "\n",
      "--------Epoch 3 (107 total)--------\n",
      "Val loss = 0.6692, Zero temp loss = 0.5451\n",
      "\n",
      "--------Epoch 4 (108 total)--------\n",
      "Val loss = 0.6764, Zero temp loss = 0.5511\n",
      "\n",
      "--------Epoch 5 (109 total)--------\n",
      "Val loss = 0.6681, Zero temp loss = 0.5526\n",
      "\n",
      "--------Epoch 6 (110 total)--------\n",
      "Val loss = 0.6696, Zero temp loss = 0.5585\n",
      "\n",
      "--------Epoch 7 (111 total)--------\n",
      "Val loss = 0.6726, Zero temp loss = 0.5534\n",
      "\n",
      "Epoch     7: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 8 (112 total)--------\n",
      "Val loss = 0.6801, Zero temp loss = 0.5683\n",
      "\n",
      "--------Epoch 9 (113 total)--------\n",
      "Val loss = 0.6900, Zero temp loss = 0.5640\n",
      "\n",
      "--------Epoch 10 (114 total)--------\n",
      "Val loss = 0.6924, Zero temp loss = 0.5630\n",
      "\n",
      "--------Epoch 11 (115 total)--------\n",
      "Val loss = 0.6923, Zero temp loss = 0.5679\n",
      "\n",
      "--------Epoch 12 (116 total)--------\n",
      "Val loss = 0.6913, Zero temp loss = 0.5565\n",
      "\n",
      "--------Epoch 13 (117 total)--------\n",
      "Val loss = 0.6835, Zero temp loss = 0.5593\n",
      "\n",
      "Epoch    13: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 14 (118 total)--------\n",
      "Val loss = 0.6933, Zero temp loss = 0.5566\n",
      "\n",
      "--------Epoch 15 (119 total)--------\n",
      "Val loss = 0.7002, Zero temp loss = 0.5682\n",
      "\n",
      "--------Epoch 16 (120 total)--------\n",
      "Val loss = 0.7014, Zero temp loss = 0.5672\n",
      "\n",
      "--------Epoch 17 (121 total)--------\n",
      "Val loss = 0.6985, Zero temp loss = 0.5613\n",
      "\n",
      "--------Epoch 18 (122 total)--------\n",
      "Val loss = 0.7040, Zero temp loss = 0.5760\n",
      "\n",
      "--------Epoch 19 (123 total)--------\n",
      "Val loss = 0.6980, Zero temp loss = 0.5657\n",
      "\n",
      "--------Epoch 20 (124 total)--------\n",
      "Val loss = 0.7063, Zero temp loss = 0.5717\n",
      "\n",
      "--------Epoch 21 (125 total)--------\n",
      "Val loss = 0.6980, Zero temp loss = 0.5654\n",
      "\n",
      "--------Epoch 22 (126 total)--------\n",
      "Val loss = 0.6981, Zero temp loss = 0.5632\n",
      "\n",
      "--------Epoch 23 (127 total)--------\n",
      "Val loss = 0.7018, Zero temp loss = 0.5636\n",
      "\n",
      "Epoch    23: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 24 (128 total)--------\n",
      "Val loss = 0.7055, Zero temp loss = 0.5643\n",
      "\n",
      "Stopping temp = 0.3162 at epoch 24\n",
      "\n",
      "Starting training with temp = 0.1778\n",
      "\n",
      "--------Epoch 1 (129 total)--------\n",
      "Val loss = 0.6363, Zero temp loss = 0.5852\n",
      "\n",
      "--------Epoch 2 (130 total)--------\n",
      "Val loss = 0.6458, Zero temp loss = 0.6045\n",
      "\n",
      "--------Epoch 3 (131 total)--------\n",
      "Val loss = 0.6404, Zero temp loss = 0.6029\n",
      "\n",
      "--------Epoch 4 (132 total)--------\n",
      "Val loss = 0.6554, Zero temp loss = 0.6132\n",
      "\n",
      "--------Epoch 5 (133 total)--------\n",
      "Val loss = 0.6538, Zero temp loss = 0.6178\n",
      "\n",
      "--------Epoch 6 (134 total)--------\n",
      "Val loss = 0.6490, Zero temp loss = 0.6160\n",
      "\n",
      "--------Epoch 7 (135 total)--------\n",
      "Val loss = 0.6634, Zero temp loss = 0.6310\n",
      "\n",
      "--------Epoch 8 (136 total)--------\n",
      "Val loss = 0.6627, Zero temp loss = 0.6265\n",
      "\n",
      "--------Epoch 9 (137 total)--------\n",
      "Val loss = 0.6627, Zero temp loss = 0.6295\n",
      "\n",
      "--------Epoch 10 (138 total)--------\n",
      "Val loss = 0.6605, Zero temp loss = 0.6284\n",
      "\n",
      "Epoch    10: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 11 (139 total)--------\n",
      "Val loss = 0.6804, Zero temp loss = 0.6462\n",
      "\n",
      "--------Epoch 12 (140 total)--------\n",
      "Val loss = 0.6743, Zero temp loss = 0.6419\n",
      "\n",
      "--------Epoch 13 (141 total)--------\n",
      "Val loss = 0.6774, Zero temp loss = 0.6448\n",
      "\n",
      "--------Epoch 14 (142 total)--------\n",
      "Val loss = 0.6740, Zero temp loss = 0.6367\n",
      "\n",
      "Epoch    14: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 15 (143 total)--------\n",
      "Val loss = 0.6759, Zero temp loss = 0.6391\n",
      "\n",
      "Stopping temp = 0.1778 at epoch 15\n",
      "\n",
      "Starting training with temp = 0.1000\n",
      "\n",
      "--------Epoch 1 (144 total)--------\n",
      "Val loss = 0.6535, Zero temp loss = 0.6434\n",
      "\n",
      "--------Epoch 2 (145 total)--------\n",
      "Val loss = 0.6589, Zero temp loss = 0.6442\n",
      "\n",
      "--------Epoch 3 (146 total)--------\n",
      "Val loss = 0.6713, Zero temp loss = 0.6591\n",
      "\n",
      "--------Epoch 4 (147 total)--------\n",
      "Val loss = 0.6646, Zero temp loss = 0.6535\n",
      "\n",
      "--------Epoch 5 (148 total)--------\n",
      "Val loss = 0.6628, Zero temp loss = 0.6537\n",
      "\n",
      "--------Epoch 6 (149 total)--------\n",
      "Val loss = 0.6725, Zero temp loss = 0.6631\n",
      "\n",
      "--------Epoch 7 (150 total)--------\n",
      "Val loss = 0.6687, Zero temp loss = 0.6619\n",
      "\n",
      "--------Epoch 8 (151 total)--------\n",
      "Val loss = 0.6773, Zero temp loss = 0.6684\n",
      "\n",
      "--------Epoch 9 (152 total)--------\n",
      "Val loss = 0.6701, Zero temp loss = 0.6635\n",
      "\n",
      "--------Epoch 10 (153 total)--------\n",
      "Val loss = 0.6773, Zero temp loss = 0.6694\n",
      "\n",
      "--------Epoch 11 (154 total)--------\n",
      "Val loss = 0.6729, Zero temp loss = 0.6642\n",
      "\n",
      "Epoch    11: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 12 (155 total)--------\n",
      "Val loss = 0.6822, Zero temp loss = 0.6753\n",
      "\n",
      "--------Epoch 13 (156 total)--------\n",
      "Val loss = 0.6788, Zero temp loss = 0.6719\n",
      "\n",
      "--------Epoch 14 (157 total)--------\n",
      "Val loss = 0.6850, Zero temp loss = 0.6784\n",
      "\n",
      "--------Epoch 15 (158 total)--------\n",
      "Val loss = 0.6839, Zero temp loss = 0.6764\n",
      "\n",
      "--------Epoch 16 (159 total)--------\n",
      "Val loss = 0.6857, Zero temp loss = 0.6783\n",
      "\n",
      "--------Epoch 17 (160 total)--------\n",
      "Val loss = 0.6912, Zero temp loss = 0.6828\n",
      "\n",
      "--------Epoch 18 (161 total)--------\n",
      "Val loss = 0.6884, Zero temp loss = 0.6800\n",
      "\n",
      "--------Epoch 19 (162 total)--------\n",
      "Val loss = 0.6823, Zero temp loss = 0.6751\n",
      "\n",
      "--------Epoch 20 (163 total)--------\n",
      "Val loss = 0.6870, Zero temp loss = 0.6781\n",
      "\n",
      "Epoch    20: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 21 (164 total)--------\n",
      "Val loss = 0.6868, Zero temp loss = 0.6784\n",
      "\n",
      "Stopping temp = 0.1000 at epoch 21\n",
      "\n",
      "Acc = 70.33\n",
      "\n",
      "Starting training with temp = 1.0000\n",
      "\n",
      "--------Epoch 1 (1 total)--------\n",
      "Val loss = 0.8525, Zero temp loss = 0.6403\n",
      "\n",
      "--------Epoch 2 (2 total)--------\n",
      "Val loss = 0.8662, Zero temp loss = 0.6203\n",
      "\n",
      "--------Epoch 3 (3 total)--------\n",
      "Val loss = 0.8701, Zero temp loss = 0.6019\n",
      "\n",
      "--------Epoch 4 (4 total)--------\n",
      "Val loss = 0.8760, Zero temp loss = 0.6087\n",
      "\n",
      "--------Epoch 5 (5 total)--------\n",
      "Val loss = 0.8782, Zero temp loss = 0.5858\n",
      "\n",
      "--------Epoch 6 (6 total)--------\n",
      "Val loss = 0.8824, Zero temp loss = 0.5890\n",
      "\n",
      "--------Epoch 7 (7 total)--------\n",
      "Val loss = 0.8827, Zero temp loss = 0.5817\n",
      "\n",
      "--------Epoch 8 (8 total)--------\n",
      "Val loss = 0.8890, Zero temp loss = 0.5770\n",
      "\n",
      "--------Epoch 9 (9 total)--------\n",
      "Val loss = 0.8829, Zero temp loss = 0.5661\n",
      "\n",
      "--------Epoch 10 (10 total)--------\n",
      "Val loss = 0.8883, Zero temp loss = 0.5800\n",
      "\n",
      "--------Epoch 11 (11 total)--------\n",
      "Val loss = 0.8886, Zero temp loss = 0.5789\n",
      "\n",
      "Epoch    11: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 12 (12 total)--------\n",
      "Val loss = 0.8938, Zero temp loss = 0.5909\n",
      "\n",
      "--------Epoch 13 (13 total)--------\n",
      "Val loss = 0.8989, Zero temp loss = 0.5821\n",
      "\n",
      "--------Epoch 14 (14 total)--------\n",
      "Val loss = 0.9022, Zero temp loss = 0.5952\n",
      "\n",
      "--------Epoch 15 (15 total)--------\n",
      "Val loss = 0.9005, Zero temp loss = 0.5852\n",
      "\n",
      "--------Epoch 16 (16 total)--------\n",
      "Val loss = 0.9024, Zero temp loss = 0.5854\n",
      "\n",
      "--------Epoch 17 (17 total)--------\n",
      "Val loss = 0.9049, Zero temp loss = 0.5819\n",
      "\n",
      "--------Epoch 18 (18 total)--------\n",
      "Val loss = 0.9024, Zero temp loss = 0.5822\n",
      "\n",
      "--------Epoch 19 (19 total)--------\n",
      "Val loss = 0.9076, Zero temp loss = 0.5933\n",
      "\n",
      "--------Epoch 20 (20 total)--------\n",
      "Val loss = 0.9094, Zero temp loss = 0.5754\n",
      "\n",
      "--------Epoch 21 (21 total)--------\n",
      "Val loss = 0.9045, Zero temp loss = 0.5762\n",
      "\n",
      "--------Epoch 22 (22 total)--------\n",
      "Val loss = 0.9077, Zero temp loss = 0.5748\n",
      "\n",
      "--------Epoch 23 (23 total)--------\n",
      "Val loss = 0.9089, Zero temp loss = 0.5842\n",
      "\n",
      "Epoch    23: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 24 (24 total)--------\n",
      "Val loss = 0.9068, Zero temp loss = 0.5759\n",
      "\n",
      "Stopping temp = 1.0000 at epoch 24\n",
      "\n",
      "Starting training with temp = 0.5623\n",
      "\n",
      "--------Epoch 1 (25 total)--------\n",
      "Val loss = 0.8457, Zero temp loss = 0.7060\n",
      "\n",
      "--------Epoch 2 (26 total)--------\n",
      "Val loss = 0.8433, Zero temp loss = 0.7097\n",
      "\n",
      "--------Epoch 3 (27 total)--------\n",
      "Val loss = 0.8450, Zero temp loss = 0.7159\n",
      "\n",
      "--------Epoch 4 (28 total)--------\n",
      "Val loss = 0.8503, Zero temp loss = 0.7150\n",
      "\n",
      "--------Epoch 5 (29 total)--------\n",
      "Val loss = 0.8534, Zero temp loss = 0.7178\n",
      "\n",
      "--------Epoch 6 (30 total)--------\n",
      "Val loss = 0.8476, Zero temp loss = 0.7196\n",
      "\n",
      "--------Epoch 7 (31 total)--------\n",
      "Val loss = 0.8581, Zero temp loss = 0.7281\n",
      "\n",
      "--------Epoch 8 (32 total)--------\n",
      "Val loss = 0.8586, Zero temp loss = 0.7261\n",
      "\n",
      "--------Epoch 9 (33 total)--------\n",
      "Val loss = 0.8575, Zero temp loss = 0.7278\n",
      "\n",
      "--------Epoch 10 (34 total)--------\n",
      "Val loss = 0.8491, Zero temp loss = 0.7175\n",
      "\n",
      "--------Epoch 11 (35 total)--------\n",
      "Val loss = 0.8511, Zero temp loss = 0.7290\n",
      "\n",
      "Epoch    11: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 12 (36 total)--------\n",
      "Val loss = 0.8658, Zero temp loss = 0.7355\n",
      "\n",
      "--------Epoch 13 (37 total)--------\n",
      "Val loss = 0.8665, Zero temp loss = 0.7395\n",
      "\n",
      "--------Epoch 14 (38 total)--------\n",
      "Val loss = 0.8718, Zero temp loss = 0.7350\n",
      "\n",
      "--------Epoch 15 (39 total)--------\n",
      "Val loss = 0.8665, Zero temp loss = 0.7326\n",
      "\n",
      "--------Epoch 16 (40 total)--------\n",
      "Val loss = 0.8668, Zero temp loss = 0.7312\n",
      "\n",
      "--------Epoch 17 (41 total)--------\n",
      "Val loss = 0.8676, Zero temp loss = 0.7308\n",
      "\n",
      "Epoch    17: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 18 (42 total)--------\n",
      "Val loss = 0.8730, Zero temp loss = 0.7334\n",
      "\n",
      "--------Epoch 19 (43 total)--------\n",
      "Val loss = 0.8741, Zero temp loss = 0.7383\n",
      "\n",
      "--------Epoch 20 (44 total)--------\n",
      "Val loss = 0.8721, Zero temp loss = 0.7394\n",
      "\n",
      "--------Epoch 21 (45 total)--------\n",
      "Val loss = 0.8713, Zero temp loss = 0.7345\n",
      "\n",
      "--------Epoch 22 (46 total)--------\n",
      "Val loss = 0.8735, Zero temp loss = 0.7445\n",
      "\n",
      "Epoch    22: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 23 (47 total)--------\n",
      "Val loss = 0.8741, Zero temp loss = 0.7339\n",
      "\n",
      "--------Epoch 24 (48 total)--------\n",
      "Val loss = 0.8755, Zero temp loss = 0.7381\n",
      "\n",
      "--------Epoch 25 (49 total)--------\n",
      "Val loss = 0.8743, Zero temp loss = 0.7367\n",
      "\n",
      "--------Epoch 26 (50 total)--------\n",
      "Val loss = 0.8730, Zero temp loss = 0.7370\n",
      "\n",
      "--------Epoch 27 (51 total)--------\n",
      "Val loss = 0.8799, Zero temp loss = 0.7395\n",
      "\n",
      "--------Epoch 28 (52 total)--------\n",
      "Val loss = 0.8761, Zero temp loss = 0.7381\n",
      "\n",
      "--------Epoch 29 (53 total)--------\n",
      "Val loss = 0.8759, Zero temp loss = 0.7390\n",
      "\n",
      "--------Epoch 30 (54 total)--------\n",
      "Val loss = 0.8727, Zero temp loss = 0.7322\n",
      "\n",
      "--------Epoch 31 (55 total)--------\n",
      "Val loss = 0.8742, Zero temp loss = 0.7400\n",
      "\n",
      "Stopping temp = 0.5623 at epoch 31\n",
      "\n",
      "Starting training with temp = 0.3162\n",
      "\n",
      "--------Epoch 1 (56 total)--------\n",
      "Val loss = 0.8292, Zero temp loss = 0.7868\n",
      "\n",
      "--------Epoch 2 (57 total)--------\n",
      "Val loss = 0.8364, Zero temp loss = 0.7967\n",
      "\n",
      "--------Epoch 3 (58 total)--------\n",
      "Val loss = 0.8379, Zero temp loss = 0.8035\n",
      "\n",
      "--------Epoch 4 (59 total)--------\n",
      "Val loss = 0.8393, Zero temp loss = 0.8101\n",
      "\n",
      "--------Epoch 5 (60 total)--------\n",
      "Val loss = 0.8423, Zero temp loss = 0.8104\n",
      "\n",
      "--------Epoch 6 (61 total)--------\n",
      "Val loss = 0.8378, Zero temp loss = 0.8072\n",
      "\n",
      "--------Epoch 7 (62 total)--------\n",
      "Val loss = 0.8427, Zero temp loss = 0.8125\n",
      "\n",
      "--------Epoch 8 (63 total)--------\n",
      "Val loss = 0.8393, Zero temp loss = 0.8103\n",
      "\n",
      "--------Epoch 9 (64 total)--------\n",
      "Val loss = 0.8442, Zero temp loss = 0.8146\n",
      "\n",
      "--------Epoch 10 (65 total)--------\n",
      "Val loss = 0.8472, Zero temp loss = 0.8225\n",
      "\n",
      "--------Epoch 11 (66 total)--------\n",
      "Val loss = 0.8495, Zero temp loss = 0.8191\n",
      "\n",
      "--------Epoch 12 (67 total)--------\n",
      "Val loss = 0.8465, Zero temp loss = 0.8188\n",
      "\n",
      "--------Epoch 13 (68 total)--------\n",
      "Val loss = 0.8472, Zero temp loss = 0.8201\n",
      "\n",
      "--------Epoch 14 (69 total)--------\n",
      "Val loss = 0.8489, Zero temp loss = 0.8193\n",
      "\n",
      "Epoch    14: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 15 (70 total)--------\n",
      "Val loss = 0.8537, Zero temp loss = 0.8282\n",
      "\n",
      "--------Epoch 16 (71 total)--------\n",
      "Val loss = 0.8565, Zero temp loss = 0.8308\n",
      "\n",
      "--------Epoch 17 (72 total)--------\n",
      "Val loss = 0.8594, Zero temp loss = 0.8296\n",
      "\n",
      "--------Epoch 18 (73 total)--------\n",
      "Val loss = 0.8578, Zero temp loss = 0.8261\n",
      "\n",
      "--------Epoch 19 (74 total)--------\n",
      "Val loss = 0.8609, Zero temp loss = 0.8337\n",
      "\n",
      "--------Epoch 20 (75 total)--------\n",
      "Val loss = 0.8611, Zero temp loss = 0.8310\n",
      "\n",
      "--------Epoch 21 (76 total)--------\n",
      "Val loss = 0.8606, Zero temp loss = 0.8342\n",
      "\n",
      "--------Epoch 22 (77 total)--------\n",
      "Val loss = 0.8611, Zero temp loss = 0.8345\n",
      "\n",
      "--------Epoch 23 (78 total)--------\n",
      "Val loss = 0.8523, Zero temp loss = 0.8244\n",
      "\n",
      "Epoch    23: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 24 (79 total)--------\n",
      "Val loss = 0.8584, Zero temp loss = 0.8307\n",
      "\n",
      "--------Epoch 25 (80 total)--------\n",
      "Val loss = 0.8590, Zero temp loss = 0.8307\n",
      "\n",
      "--------Epoch 26 (81 total)--------\n",
      "Val loss = 0.8601, Zero temp loss = 0.8345\n",
      "\n",
      "Epoch    26: reducing learning rate of group 0 to 1.0000e-05.\n",
      "Stopping temp = 0.3162 at epoch 26\n",
      "\n",
      "Starting training with temp = 0.1778\n",
      "\n",
      "--------Epoch 1 (82 total)--------\n",
      "Val loss = 0.8416, Zero temp loss = 0.8315\n",
      "\n",
      "--------Epoch 2 (83 total)--------\n",
      "Val loss = 0.8450, Zero temp loss = 0.8358\n",
      "\n",
      "--------Epoch 3 (84 total)--------\n",
      "Val loss = 0.8469, Zero temp loss = 0.8375\n",
      "\n",
      "--------Epoch 4 (85 total)--------\n",
      "Val loss = 0.8437, Zero temp loss = 0.8361\n",
      "\n",
      "--------Epoch 5 (86 total)--------\n",
      "Val loss = 0.8489, Zero temp loss = 0.8403\n",
      "\n",
      "--------Epoch 6 (87 total)--------\n",
      "Val loss = 0.8499, Zero temp loss = 0.8431\n",
      "\n",
      "--------Epoch 7 (88 total)--------\n",
      "Val loss = 0.8499, Zero temp loss = 0.8427\n",
      "\n",
      "--------Epoch 8 (89 total)--------\n",
      "Val loss = 0.8510, Zero temp loss = 0.8426\n",
      "\n",
      "--------Epoch 9 (90 total)--------\n",
      "Val loss = 0.8508, Zero temp loss = 0.8441\n",
      "\n",
      "--------Epoch 10 (91 total)--------\n",
      "Val loss = 0.8512, Zero temp loss = 0.8426\n",
      "\n",
      "--------Epoch 11 (92 total)--------\n",
      "Val loss = 0.8487, Zero temp loss = 0.8419\n",
      "\n",
      "--------Epoch 12 (93 total)--------\n",
      "Val loss = 0.8526, Zero temp loss = 0.8478\n",
      "\n",
      "--------Epoch 13 (94 total)--------\n",
      "Val loss = 0.8495, Zero temp loss = 0.8437\n",
      "\n",
      "--------Epoch 14 (95 total)--------\n",
      "Val loss = 0.8529, Zero temp loss = 0.8458\n",
      "\n",
      "--------Epoch 15 (96 total)--------\n",
      "Val loss = 0.8563, Zero temp loss = 0.8513\n",
      "\n",
      "--------Epoch 16 (97 total)--------\n",
      "Val loss = 0.8556, Zero temp loss = 0.8470\n",
      "\n",
      "--------Epoch 17 (98 total)--------\n",
      "Val loss = 0.8526, Zero temp loss = 0.8475\n",
      "\n",
      "--------Epoch 18 (99 total)--------\n",
      "Val loss = 0.8559, Zero temp loss = 0.8495\n",
      "\n",
      "Epoch    18: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 19 (100 total)--------\n",
      "Val loss = 0.8623, Zero temp loss = 0.8568\n",
      "\n",
      "--------Epoch 20 (101 total)--------\n",
      "Val loss = 0.8596, Zero temp loss = 0.8544\n",
      "\n",
      "--------Epoch 21 (102 total)--------\n",
      "Val loss = 0.8624, Zero temp loss = 0.8586\n",
      "\n",
      "--------Epoch 22 (103 total)--------\n",
      "Val loss = 0.8619, Zero temp loss = 0.8571\n",
      "\n",
      "--------Epoch 23 (104 total)--------\n",
      "Val loss = 0.8664, Zero temp loss = 0.8613\n",
      "\n",
      "--------Epoch 24 (105 total)--------\n",
      "Val loss = 0.8670, Zero temp loss = 0.8624\n",
      "\n",
      "--------Epoch 25 (106 total)--------\n",
      "Val loss = 0.8634, Zero temp loss = 0.8582\n",
      "\n",
      "--------Epoch 26 (107 total)--------\n",
      "Val loss = 0.8660, Zero temp loss = 0.8605\n",
      "\n",
      "--------Epoch 27 (108 total)--------\n",
      "Val loss = 0.8644, Zero temp loss = 0.8595\n",
      "\n",
      "Epoch    27: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 28 (109 total)--------\n",
      "Val loss = 0.8694, Zero temp loss = 0.8659\n",
      "\n",
      "--------Epoch 29 (110 total)--------\n",
      "Val loss = 0.8637, Zero temp loss = 0.8595\n",
      "\n",
      "--------Epoch 30 (111 total)--------\n",
      "Val loss = 0.8665, Zero temp loss = 0.8624\n",
      "\n",
      "--------Epoch 31 (112 total)--------\n",
      "Val loss = 0.8626, Zero temp loss = 0.8571\n",
      "\n",
      "Epoch    31: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 32 (113 total)--------\n",
      "Val loss = 0.8688, Zero temp loss = 0.8635\n",
      "\n",
      "Stopping temp = 0.1778 at epoch 32\n",
      "\n",
      "Starting training with temp = 0.1000\n",
      "\n",
      "--------Epoch 1 (114 total)--------\n",
      "Val loss = 0.8565, Zero temp loss = 0.8535\n",
      "\n",
      "--------Epoch 2 (115 total)--------\n",
      "Val loss = 0.8485, Zero temp loss = 0.8463\n",
      "\n",
      "--------Epoch 3 (116 total)--------\n",
      "Val loss = 0.8518, Zero temp loss = 0.8495\n",
      "\n",
      "--------Epoch 4 (117 total)--------\n",
      "Val loss = 0.8565, Zero temp loss = 0.8542\n",
      "\n",
      "Epoch     4: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 5 (118 total)--------\n",
      "Val loss = 0.8603, Zero temp loss = 0.8584\n",
      "\n",
      "--------Epoch 6 (119 total)--------\n",
      "Val loss = 0.8637, Zero temp loss = 0.8618\n",
      "\n",
      "--------Epoch 7 (120 total)--------\n",
      "Val loss = 0.8619, Zero temp loss = 0.8590\n",
      "\n",
      "--------Epoch 8 (121 total)--------\n",
      "Val loss = 0.8649, Zero temp loss = 0.8628\n",
      "\n",
      "--------Epoch 9 (122 total)--------\n",
      "Val loss = 0.8622, Zero temp loss = 0.8603\n",
      "\n",
      "--------Epoch 10 (123 total)--------\n",
      "Val loss = 0.8642, Zero temp loss = 0.8621\n",
      "\n",
      "--------Epoch 11 (124 total)--------\n",
      "Val loss = 0.8670, Zero temp loss = 0.8646\n",
      "\n",
      "--------Epoch 12 (125 total)--------\n",
      "Val loss = 0.8660, Zero temp loss = 0.8630\n",
      "\n",
      "--------Epoch 13 (126 total)--------\n",
      "Val loss = 0.8670, Zero temp loss = 0.8655\n",
      "\n",
      "--------Epoch 14 (127 total)--------\n",
      "Val loss = 0.8633, Zero temp loss = 0.8602\n",
      "\n",
      "Epoch    14: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 15 (128 total)--------\n",
      "Val loss = 0.8660, Zero temp loss = 0.8635\n",
      "\n",
      "--------Epoch 16 (129 total)--------\n",
      "Val loss = 0.8663, Zero temp loss = 0.8645\n",
      "\n",
      "--------Epoch 17 (130 total)--------\n",
      "Val loss = 0.8647, Zero temp loss = 0.8623\n",
      "\n",
      "Epoch    17: reducing learning rate of group 0 to 1.0000e-05.\n",
      "Stopping temp = 0.1000 at epoch 17\n",
      "\n",
      "Acc = 87.83\n",
      "\n",
      "Starting training with temp = 1.0000\n",
      "\n",
      "--------Epoch 1 (1 total)--------\n",
      "Val loss = 0.8936, Zero temp loss = 0.8257\n",
      "\n",
      "--------Epoch 2 (2 total)--------\n",
      "Val loss = 0.9034, Zero temp loss = 0.8170\n",
      "\n",
      "--------Epoch 3 (3 total)--------\n",
      "Val loss = 0.9018, Zero temp loss = 0.7950\n",
      "\n",
      "--------Epoch 4 (4 total)--------\n",
      "Val loss = 0.9058, Zero temp loss = 0.7951\n",
      "\n",
      "--------Epoch 5 (5 total)--------\n",
      "Val loss = 0.9109, Zero temp loss = 0.7849\n",
      "\n",
      "--------Epoch 6 (6 total)--------\n",
      "Val loss = 0.9097, Zero temp loss = 0.7826\n",
      "\n",
      "--------Epoch 7 (7 total)--------\n",
      "Val loss = 0.9085, Zero temp loss = 0.7670\n",
      "\n",
      "--------Epoch 8 (8 total)--------\n",
      "Val loss = 0.9095, Zero temp loss = 0.7671\n",
      "\n",
      "Epoch     8: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 9 (9 total)--------\n",
      "Val loss = 0.9138, Zero temp loss = 0.7724\n",
      "\n",
      "--------Epoch 10 (10 total)--------\n",
      "Val loss = 0.9167, Zero temp loss = 0.7765\n",
      "\n",
      "--------Epoch 11 (11 total)--------\n",
      "Val loss = 0.9163, Zero temp loss = 0.7743\n",
      "\n",
      "--------Epoch 12 (12 total)--------\n",
      "Val loss = 0.9168, Zero temp loss = 0.7689\n",
      "\n",
      "--------Epoch 13 (13 total)--------\n",
      "Val loss = 0.9165, Zero temp loss = 0.7673\n",
      "\n",
      "--------Epoch 14 (14 total)--------\n",
      "Val loss = 0.9219, Zero temp loss = 0.7745\n",
      "\n",
      "--------Epoch 15 (15 total)--------\n",
      "Val loss = 0.9206, Zero temp loss = 0.7739\n",
      "\n",
      "--------Epoch 16 (16 total)--------\n",
      "Val loss = 0.9237, Zero temp loss = 0.7718\n",
      "\n",
      "--------Epoch 17 (17 total)--------\n",
      "Val loss = 0.9207, Zero temp loss = 0.7666\n",
      "\n",
      "--------Epoch 18 (18 total)--------\n",
      "Val loss = 0.9193, Zero temp loss = 0.7633\n",
      "\n",
      "--------Epoch 19 (19 total)--------\n",
      "Val loss = 0.9226, Zero temp loss = 0.7630\n",
      "\n",
      "Epoch    19: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 20 (20 total)--------\n",
      "Val loss = 0.9212, Zero temp loss = 0.7639\n",
      "\n",
      "Stopping temp = 1.0000 at epoch 20\n",
      "\n",
      "Starting training with temp = 0.5623\n",
      "\n",
      "--------Epoch 1 (21 total)--------\n",
      "Val loss = 0.9008, Zero temp loss = 0.8549\n",
      "\n",
      "--------Epoch 2 (22 total)--------\n",
      "Val loss = 0.9039, Zero temp loss = 0.8606\n",
      "\n",
      "--------Epoch 3 (23 total)--------\n",
      "Val loss = 0.8998, Zero temp loss = 0.8598\n",
      "\n",
      "--------Epoch 4 (24 total)--------\n",
      "Val loss = 0.9054, Zero temp loss = 0.8670\n",
      "\n",
      "--------Epoch 5 (25 total)--------\n",
      "Val loss = 0.9004, Zero temp loss = 0.8647\n",
      "\n",
      "--------Epoch 6 (26 total)--------\n",
      "Val loss = 0.9045, Zero temp loss = 0.8624\n",
      "\n",
      "--------Epoch 7 (27 total)--------\n",
      "Val loss = 0.9070, Zero temp loss = 0.8700\n",
      "\n",
      "--------Epoch 8 (28 total)--------\n",
      "Val loss = 0.9040, Zero temp loss = 0.8598\n",
      "\n",
      "--------Epoch 9 (29 total)--------\n",
      "Val loss = 0.9022, Zero temp loss = 0.8595\n",
      "\n",
      "--------Epoch 10 (30 total)--------\n",
      "Val loss = 0.9068, Zero temp loss = 0.8622\n",
      "\n",
      "Epoch    10: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 11 (31 total)--------\n",
      "Val loss = 0.9111, Zero temp loss = 0.8682\n",
      "\n",
      "--------Epoch 12 (32 total)--------\n",
      "Val loss = 0.9113, Zero temp loss = 0.8685\n",
      "\n",
      "--------Epoch 13 (33 total)--------\n",
      "Val loss = 0.9123, Zero temp loss = 0.8728\n",
      "\n",
      "--------Epoch 14 (34 total)--------\n",
      "Val loss = 0.9106, Zero temp loss = 0.8684\n",
      "\n",
      "--------Epoch 15 (35 total)--------\n",
      "Val loss = 0.9123, Zero temp loss = 0.8699\n",
      "\n",
      "--------Epoch 16 (36 total)--------\n",
      "Val loss = 0.9112, Zero temp loss = 0.8696\n",
      "\n",
      "Epoch    16: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 17 (37 total)--------\n",
      "Val loss = 0.9172, Zero temp loss = 0.8766\n",
      "\n",
      "--------Epoch 18 (38 total)--------\n",
      "Val loss = 0.9122, Zero temp loss = 0.8736\n",
      "\n",
      "--------Epoch 19 (39 total)--------\n",
      "Val loss = 0.9161, Zero temp loss = 0.8742\n",
      "\n",
      "--------Epoch 20 (40 total)--------\n",
      "Val loss = 0.9137, Zero temp loss = 0.8788\n",
      "\n",
      "Epoch    20: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 21 (41 total)--------\n",
      "Val loss = 0.9164, Zero temp loss = 0.8722\n",
      "\n",
      "Stopping temp = 0.5623 at epoch 21\n",
      "\n",
      "Starting training with temp = 0.3162\n",
      "\n",
      "--------Epoch 1 (42 total)--------\n",
      "Val loss = 0.9075, Zero temp loss = 0.8962\n",
      "\n",
      "--------Epoch 2 (43 total)--------\n",
      "Val loss = 0.9052, Zero temp loss = 0.8957\n",
      "\n",
      "--------Epoch 3 (44 total)--------\n",
      "Val loss = 0.9032, Zero temp loss = 0.8924\n",
      "\n",
      "--------Epoch 4 (45 total)--------\n",
      "Val loss = 0.9028, Zero temp loss = 0.8958\n",
      "\n",
      "Epoch     4: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 5 (46 total)--------\n",
      "Val loss = 0.9111, Zero temp loss = 0.9026\n",
      "\n",
      "--------Epoch 6 (47 total)--------\n",
      "Val loss = 0.9077, Zero temp loss = 0.8983\n",
      "\n",
      "--------Epoch 7 (48 total)--------\n",
      "Val loss = 0.9114, Zero temp loss = 0.9041\n",
      "\n",
      "--------Epoch 8 (49 total)--------\n",
      "Val loss = 0.9109, Zero temp loss = 0.9023\n",
      "\n",
      "--------Epoch 9 (50 total)--------\n",
      "Val loss = 0.9083, Zero temp loss = 0.9007\n",
      "\n",
      "--------Epoch 10 (51 total)--------\n",
      "Val loss = 0.9124, Zero temp loss = 0.9037\n",
      "\n",
      "--------Epoch 11 (52 total)--------\n",
      "Val loss = 0.9091, Zero temp loss = 0.9023\n",
      "\n",
      "--------Epoch 12 (53 total)--------\n",
      "Val loss = 0.9145, Zero temp loss = 0.9046\n",
      "\n",
      "--------Epoch 13 (54 total)--------\n",
      "Val loss = 0.9167, Zero temp loss = 0.9078\n",
      "\n",
      "--------Epoch 14 (55 total)--------\n",
      "Val loss = 0.9151, Zero temp loss = 0.9063\n",
      "\n",
      "--------Epoch 15 (56 total)--------\n",
      "Val loss = 0.9115, Zero temp loss = 0.9041\n",
      "\n",
      "--------Epoch 16 (57 total)--------\n",
      "Val loss = 0.9136, Zero temp loss = 0.9065\n",
      "\n",
      "Epoch    16: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 17 (58 total)--------\n",
      "Val loss = 0.9121, Zero temp loss = 0.9049\n",
      "\n",
      "Stopping temp = 0.3162 at epoch 17\n",
      "\n",
      "Starting training with temp = 0.1778\n",
      "\n",
      "--------Epoch 1 (59 total)--------\n",
      "Val loss = 0.9046, Zero temp loss = 0.9014\n",
      "\n",
      "--------Epoch 2 (60 total)--------\n",
      "Val loss = 0.9076, Zero temp loss = 0.9048\n",
      "\n",
      "--------Epoch 3 (61 total)--------\n",
      "Val loss = 0.9056, Zero temp loss = 0.9024\n",
      "\n",
      "--------Epoch 4 (62 total)--------\n",
      "Val loss = 0.9038, Zero temp loss = 0.8989\n",
      "\n",
      "--------Epoch 5 (63 total)--------\n",
      "Val loss = 0.9054, Zero temp loss = 0.9016\n",
      "\n",
      "Epoch     5: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 6 (64 total)--------\n",
      "Val loss = 0.9082, Zero temp loss = 0.9065\n",
      "\n",
      "--------Epoch 7 (65 total)--------\n",
      "Val loss = 0.9089, Zero temp loss = 0.9066\n",
      "\n",
      "--------Epoch 8 (66 total)--------\n",
      "Val loss = 0.9116, Zero temp loss = 0.9098\n",
      "\n",
      "--------Epoch 9 (67 total)--------\n",
      "Val loss = 0.9110, Zero temp loss = 0.9094\n",
      "\n",
      "--------Epoch 10 (68 total)--------\n",
      "Val loss = 0.9164, Zero temp loss = 0.9151\n",
      "\n",
      "--------Epoch 11 (69 total)--------\n",
      "Val loss = 0.9146, Zero temp loss = 0.9116\n",
      "\n",
      "--------Epoch 12 (70 total)--------\n",
      "Val loss = 0.9126, Zero temp loss = 0.9114\n",
      "\n",
      "--------Epoch 13 (71 total)--------\n",
      "Val loss = 0.9123, Zero temp loss = 0.9107\n",
      "\n",
      "Epoch    13: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 14 (72 total)--------\n",
      "Val loss = 0.9139, Zero temp loss = 0.9101\n",
      "\n",
      "Stopping temp = 0.1778 at epoch 14\n",
      "\n",
      "Starting training with temp = 0.1000\n",
      "\n",
      "--------Epoch 1 (73 total)--------\n",
      "Val loss = 0.8990, Zero temp loss = 0.8971\n",
      "\n",
      "--------Epoch 2 (74 total)--------\n",
      "Val loss = 0.8989, Zero temp loss = 0.8977\n",
      "\n",
      "--------Epoch 3 (75 total)--------\n",
      "Val loss = 0.9031, Zero temp loss = 0.9026\n",
      "\n",
      "--------Epoch 4 (76 total)--------\n",
      "Val loss = 0.9035, Zero temp loss = 0.9028\n",
      "\n",
      "--------Epoch 5 (77 total)--------\n",
      "Val loss = 0.9015, Zero temp loss = 0.9010\n",
      "\n",
      "--------Epoch 6 (78 total)--------\n",
      "Val loss = 0.8995, Zero temp loss = 0.8997\n",
      "\n",
      "--------Epoch 7 (79 total)--------\n",
      "Val loss = 0.9030, Zero temp loss = 0.9016\n",
      "\n",
      "Epoch     7: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 8 (80 total)--------\n",
      "Val loss = 0.9061, Zero temp loss = 0.9055\n",
      "\n",
      "--------Epoch 9 (81 total)--------\n",
      "Val loss = 0.9055, Zero temp loss = 0.9053\n",
      "\n",
      "--------Epoch 10 (82 total)--------\n",
      "Val loss = 0.9077, Zero temp loss = 0.9071\n",
      "\n",
      "--------Epoch 11 (83 total)--------\n",
      "Val loss = 0.9066, Zero temp loss = 0.9064\n",
      "\n",
      "--------Epoch 12 (84 total)--------\n",
      "Val loss = 0.9080, Zero temp loss = 0.9075\n",
      "\n",
      "--------Epoch 13 (85 total)--------\n",
      "Val loss = 0.9073, Zero temp loss = 0.9063\n",
      "\n",
      "--------Epoch 14 (86 total)--------\n",
      "Val loss = 0.9130, Zero temp loss = 0.9126\n",
      "\n",
      "--------Epoch 15 (87 total)--------\n",
      "Val loss = 0.9149, Zero temp loss = 0.9147\n",
      "\n",
      "--------Epoch 16 (88 total)--------\n",
      "Val loss = 0.9124, Zero temp loss = 0.9123\n",
      "\n",
      "--------Epoch 17 (89 total)--------\n",
      "Val loss = 0.9160, Zero temp loss = 0.9157\n",
      "\n",
      "--------Epoch 18 (90 total)--------\n",
      "Val loss = 0.9122, Zero temp loss = 0.9112\n",
      "\n",
      "--------Epoch 19 (91 total)--------\n",
      "Val loss = 0.9154, Zero temp loss = 0.9144\n",
      "\n",
      "--------Epoch 20 (92 total)--------\n",
      "Val loss = 0.9156, Zero temp loss = 0.9146\n",
      "\n",
      "Epoch    20: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 21 (93 total)--------\n",
      "Val loss = 0.9162, Zero temp loss = 0.9144\n",
      "\n",
      "--------Epoch 22 (94 total)--------\n",
      "Val loss = 0.9155, Zero temp loss = 0.9152\n",
      "\n",
      "--------Epoch 23 (95 total)--------\n",
      "Val loss = 0.9162, Zero temp loss = 0.9156\n",
      "\n",
      "--------Epoch 24 (96 total)--------\n",
      "Val loss = 0.9112, Zero temp loss = 0.9106\n",
      "\n",
      "Epoch    24: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 25 (97 total)--------\n",
      "Val loss = 0.9129, Zero temp loss = 0.9126\n",
      "\n",
      "--------Epoch 26 (98 total)--------\n",
      "Val loss = 0.9185, Zero temp loss = 0.9178\n",
      "\n",
      "--------Epoch 27 (99 total)--------\n",
      "Val loss = 0.9164, Zero temp loss = 0.9159\n",
      "\n",
      "--------Epoch 28 (100 total)--------\n",
      "Val loss = 0.9160, Zero temp loss = 0.9158\n",
      "\n",
      "--------Epoch 29 (101 total)--------\n",
      "Val loss = 0.9157, Zero temp loss = 0.9157\n",
      "\n",
      "--------Epoch 30 (102 total)--------\n",
      "Val loss = 0.9127, Zero temp loss = 0.9123\n",
      "\n",
      "Stopping temp = 0.1000 at epoch 30\n",
      "\n",
      "Acc = 92.35\n",
      "\n",
      "Starting training with temp = 1.0000\n",
      "\n",
      "--------Epoch 1 (1 total)--------\n",
      "Val loss = 0.9201, Zero temp loss = 0.8990\n",
      "\n",
      "--------Epoch 2 (2 total)--------\n",
      "Val loss = 0.9193, Zero temp loss = 0.8796\n",
      "\n",
      "--------Epoch 3 (3 total)--------\n",
      "Val loss = 0.9272, Zero temp loss = 0.8835\n",
      "\n",
      "--------Epoch 4 (4 total)--------\n",
      "Val loss = 0.9285, Zero temp loss = 0.8793\n",
      "\n",
      "--------Epoch 5 (5 total)--------\n",
      "Val loss = 0.9246, Zero temp loss = 0.8710\n",
      "\n",
      "--------Epoch 6 (6 total)--------\n",
      "Val loss = 0.9288, Zero temp loss = 0.8741\n",
      "\n",
      "--------Epoch 7 (7 total)--------\n",
      "Val loss = 0.9282, Zero temp loss = 0.8724\n",
      "\n",
      "--------Epoch 8 (8 total)--------\n",
      "Val loss = 0.9329, Zero temp loss = 0.8735\n",
      "\n",
      "--------Epoch 9 (9 total)--------\n",
      "Val loss = 0.9293, Zero temp loss = 0.8729\n",
      "\n",
      "--------Epoch 10 (10 total)--------\n",
      "Val loss = 0.9289, Zero temp loss = 0.8632\n",
      "\n",
      "--------Epoch 11 (11 total)--------\n",
      "Val loss = 0.9294, Zero temp loss = 0.8644\n",
      "\n",
      "Epoch    11: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 12 (12 total)--------\n",
      "Val loss = 0.9306, Zero temp loss = 0.8702\n",
      "\n",
      "Stopping temp = 1.0000 at epoch 12\n",
      "\n",
      "Starting training with temp = 0.5623\n",
      "\n",
      "--------Epoch 1 (13 total)--------\n",
      "Val loss = 0.9266, Zero temp loss = 0.9102\n",
      "\n",
      "--------Epoch 2 (14 total)--------\n",
      "Val loss = 0.9289, Zero temp loss = 0.9133\n",
      "\n",
      "--------Epoch 3 (15 total)--------\n",
      "Val loss = 0.9271, Zero temp loss = 0.9148\n",
      "\n",
      "--------Epoch 4 (16 total)--------\n",
      "Val loss = 0.9273, Zero temp loss = 0.9130\n",
      "\n",
      "--------Epoch 5 (17 total)--------\n",
      "Val loss = 0.9275, Zero temp loss = 0.9130\n",
      "\n",
      "Epoch     5: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 6 (18 total)--------\n",
      "Val loss = 0.9334, Zero temp loss = 0.9185\n",
      "\n",
      "--------Epoch 7 (19 total)--------\n",
      "Val loss = 0.9303, Zero temp loss = 0.9182\n",
      "\n",
      "--------Epoch 8 (20 total)--------\n",
      "Val loss = 0.9312, Zero temp loss = 0.9207\n",
      "\n",
      "--------Epoch 9 (21 total)--------\n",
      "Val loss = 0.9285, Zero temp loss = 0.9149\n",
      "\n",
      "Epoch     9: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 10 (22 total)--------\n",
      "Val loss = 0.9341, Zero temp loss = 0.9227\n",
      "\n",
      "--------Epoch 11 (23 total)--------\n",
      "Val loss = 0.9330, Zero temp loss = 0.9195\n",
      "\n",
      "--------Epoch 12 (24 total)--------\n",
      "Val loss = 0.9345, Zero temp loss = 0.9215\n",
      "\n",
      "--------Epoch 13 (25 total)--------\n",
      "Val loss = 0.9333, Zero temp loss = 0.9226\n",
      "\n",
      "--------Epoch 14 (26 total)--------\n",
      "Val loss = 0.9354, Zero temp loss = 0.9223\n",
      "\n",
      "--------Epoch 15 (27 total)--------\n",
      "Val loss = 0.9340, Zero temp loss = 0.9229\n",
      "\n",
      "--------Epoch 16 (28 total)--------\n",
      "Val loss = 0.9327, Zero temp loss = 0.9188\n",
      "\n",
      "--------Epoch 17 (29 total)--------\n",
      "Val loss = 0.9335, Zero temp loss = 0.9250\n",
      "\n",
      "Epoch    17: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 18 (30 total)--------\n",
      "Val loss = 0.9357, Zero temp loss = 0.9224\n",
      "\n",
      "--------Epoch 19 (31 total)--------\n",
      "Val loss = 0.9345, Zero temp loss = 0.9226\n",
      "\n",
      "--------Epoch 20 (32 total)--------\n",
      "Val loss = 0.9314, Zero temp loss = 0.9202\n",
      "\n",
      "--------Epoch 21 (33 total)--------\n",
      "Val loss = 0.9345, Zero temp loss = 0.9238\n",
      "\n",
      "--------Epoch 22 (34 total)--------\n",
      "Val loss = 0.9351, Zero temp loss = 0.9235\n",
      "\n",
      "Stopping temp = 0.5623 at epoch 22\n",
      "\n",
      "Starting training with temp = 0.3162\n",
      "\n",
      "--------Epoch 1 (35 total)--------\n",
      "Val loss = 0.9269, Zero temp loss = 0.9239\n",
      "\n",
      "--------Epoch 2 (36 total)--------\n",
      "Val loss = 0.9301, Zero temp loss = 0.9243\n",
      "\n",
      "--------Epoch 3 (37 total)--------\n",
      "Val loss = 0.9275, Zero temp loss = 0.9226\n",
      "\n",
      "--------Epoch 4 (38 total)--------\n",
      "Val loss = 0.9340, Zero temp loss = 0.9311\n",
      "\n",
      "--------Epoch 5 (39 total)--------\n",
      "Val loss = 0.9274, Zero temp loss = 0.9253\n",
      "\n",
      "--------Epoch 6 (40 total)--------\n",
      "Val loss = 0.9294, Zero temp loss = 0.9275\n",
      "\n",
      "--------Epoch 7 (41 total)--------\n",
      "Val loss = 0.9293, Zero temp loss = 0.9261\n",
      "\n",
      "Epoch     7: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 8 (42 total)--------\n",
      "Val loss = 0.9316, Zero temp loss = 0.9294\n",
      "\n",
      "Stopping temp = 0.3162 at epoch 8\n",
      "\n",
      "Starting training with temp = 0.1778\n",
      "\n",
      "--------Epoch 1 (43 total)--------\n",
      "Val loss = 0.9286, Zero temp loss = 0.9262\n",
      "\n",
      "--------Epoch 2 (44 total)--------\n",
      "Val loss = 0.9258, Zero temp loss = 0.9248\n",
      "\n",
      "--------Epoch 3 (45 total)--------\n",
      "Val loss = 0.9247, Zero temp loss = 0.9238\n",
      "\n",
      "--------Epoch 4 (46 total)--------\n",
      "Val loss = 0.9238, Zero temp loss = 0.9226\n",
      "\n",
      "Epoch     4: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 5 (47 total)--------\n",
      "Val loss = 0.9305, Zero temp loss = 0.9297\n",
      "\n",
      "--------Epoch 6 (48 total)--------\n",
      "Val loss = 0.9300, Zero temp loss = 0.9294\n",
      "\n",
      "--------Epoch 7 (49 total)--------\n",
      "Val loss = 0.9313, Zero temp loss = 0.9316\n",
      "\n",
      "--------Epoch 8 (50 total)--------\n",
      "Val loss = 0.9308, Zero temp loss = 0.9294\n",
      "\n",
      "--------Epoch 9 (51 total)--------\n",
      "Val loss = 0.9324, Zero temp loss = 0.9317\n",
      "\n",
      "--------Epoch 10 (52 total)--------\n",
      "Val loss = 0.9316, Zero temp loss = 0.9310\n",
      "\n",
      "--------Epoch 11 (53 total)--------\n",
      "Val loss = 0.9365, Zero temp loss = 0.9359\n",
      "\n",
      "--------Epoch 12 (54 total)--------\n",
      "Val loss = 0.9356, Zero temp loss = 0.9346\n",
      "\n",
      "--------Epoch 13 (55 total)--------\n",
      "Val loss = 0.9365, Zero temp loss = 0.9358\n",
      "\n",
      "--------Epoch 14 (56 total)--------\n",
      "Val loss = 0.9324, Zero temp loss = 0.9312\n",
      "\n",
      "Epoch    14: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 15 (57 total)--------\n",
      "Val loss = 0.9360, Zero temp loss = 0.9358\n",
      "\n",
      "--------Epoch 16 (58 total)--------\n",
      "Val loss = 0.9327, Zero temp loss = 0.9324\n",
      "\n",
      "--------Epoch 17 (59 total)--------\n",
      "Val loss = 0.9348, Zero temp loss = 0.9336\n",
      "\n",
      "Epoch    17: reducing learning rate of group 0 to 1.0000e-05.\n",
      "Stopping temp = 0.1778 at epoch 17\n",
      "\n",
      "Starting training with temp = 0.1000\n",
      "\n",
      "--------Epoch 1 (60 total)--------\n",
      "Val loss = 0.9257, Zero temp loss = 0.9249\n",
      "\n",
      "--------Epoch 2 (61 total)--------\n",
      "Val loss = 0.9184, Zero temp loss = 0.9177\n",
      "\n",
      "--------Epoch 3 (62 total)--------\n",
      "Val loss = 0.9200, Zero temp loss = 0.9198\n",
      "\n",
      "--------Epoch 4 (63 total)--------\n",
      "Val loss = 0.9217, Zero temp loss = 0.9213\n",
      "\n",
      "Epoch     4: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 5 (64 total)--------\n",
      "Val loss = 0.9265, Zero temp loss = 0.9265\n",
      "\n",
      "--------Epoch 6 (65 total)--------\n",
      "Val loss = 0.9320, Zero temp loss = 0.9316\n",
      "\n",
      "--------Epoch 7 (66 total)--------\n",
      "Val loss = 0.9274, Zero temp loss = 0.9264\n",
      "\n",
      "--------Epoch 8 (67 total)--------\n",
      "Val loss = 0.9290, Zero temp loss = 0.9286\n",
      "\n",
      "--------Epoch 9 (68 total)--------\n",
      "Val loss = 0.9291, Zero temp loss = 0.9287\n",
      "\n",
      "Epoch     9: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 10 (69 total)--------\n",
      "Val loss = 0.9269, Zero temp loss = 0.9263\n",
      "\n",
      "Stopping temp = 0.1000 at epoch 10\n",
      "\n",
      "Acc = 94.25\n",
      "\n",
      "Starting training with temp = 1.0000\n",
      "\n",
      "--------Epoch 1 (1 total)--------\n",
      "Val loss = 0.9343, Zero temp loss = 0.9188\n",
      "\n",
      "--------Epoch 2 (2 total)--------\n",
      "Val loss = 0.9359, Zero temp loss = 0.9183\n",
      "\n",
      "--------Epoch 3 (3 total)--------\n",
      "Val loss = 0.9383, Zero temp loss = 0.9155\n",
      "\n",
      "--------Epoch 4 (4 total)--------\n",
      "Val loss = 0.9355, Zero temp loss = 0.9088\n",
      "\n",
      "--------Epoch 5 (5 total)--------\n",
      "Val loss = 0.9381, Zero temp loss = 0.9079\n",
      "\n",
      "--------Epoch 6 (6 total)--------\n",
      "Val loss = 0.9379, Zero temp loss = 0.9110\n",
      "\n",
      "Epoch     6: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 7 (7 total)--------\n",
      "Val loss = 0.9403, Zero temp loss = 0.9199\n",
      "\n",
      "--------Epoch 8 (8 total)--------\n",
      "Val loss = 0.9421, Zero temp loss = 0.9177\n",
      "\n",
      "--------Epoch 9 (9 total)--------\n",
      "Val loss = 0.9435, Zero temp loss = 0.9178\n",
      "\n",
      "--------Epoch 10 (10 total)--------\n",
      "Val loss = 0.9438, Zero temp loss = 0.9149\n",
      "\n",
      "--------Epoch 11 (11 total)--------\n",
      "Val loss = 0.9426, Zero temp loss = 0.9185\n",
      "\n",
      "--------Epoch 12 (12 total)--------\n",
      "Val loss = 0.9434, Zero temp loss = 0.9191\n",
      "\n",
      "--------Epoch 13 (13 total)--------\n",
      "Val loss = 0.9425, Zero temp loss = 0.9175\n",
      "\n",
      "Epoch    13: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 14 (14 total)--------\n",
      "Val loss = 0.9437, Zero temp loss = 0.9200\n",
      "\n",
      "Stopping temp = 1.0000 at epoch 14\n",
      "\n",
      "Starting training with temp = 0.5623\n",
      "\n",
      "--------Epoch 1 (15 total)--------\n",
      "Val loss = 0.9407, Zero temp loss = 0.9346\n",
      "\n",
      "--------Epoch 2 (16 total)--------\n",
      "Val loss = 0.9374, Zero temp loss = 0.9320\n",
      "\n",
      "--------Epoch 3 (17 total)--------\n",
      "Val loss = 0.9402, Zero temp loss = 0.9329\n",
      "\n",
      "--------Epoch 4 (18 total)--------\n",
      "Val loss = 0.9394, Zero temp loss = 0.9323\n",
      "\n",
      "Epoch     4: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 5 (19 total)--------\n",
      "Val loss = 0.9427, Zero temp loss = 0.9384\n",
      "\n",
      "--------Epoch 6 (20 total)--------\n",
      "Val loss = 0.9422, Zero temp loss = 0.9377\n",
      "\n",
      "--------Epoch 7 (21 total)--------\n",
      "Val loss = 0.9445, Zero temp loss = 0.9391\n",
      "\n",
      "--------Epoch 8 (22 total)--------\n",
      "Val loss = 0.9463, Zero temp loss = 0.9398\n",
      "\n",
      "--------Epoch 9 (23 total)--------\n",
      "Val loss = 0.9436, Zero temp loss = 0.9394\n",
      "\n",
      "--------Epoch 10 (24 total)--------\n",
      "Val loss = 0.9439, Zero temp loss = 0.9379\n",
      "\n",
      "--------Epoch 11 (25 total)--------\n",
      "Val loss = 0.9443, Zero temp loss = 0.9398\n",
      "\n",
      "Epoch    11: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 12 (26 total)--------\n",
      "Val loss = 0.9412, Zero temp loss = 0.9380\n",
      "\n",
      "Stopping temp = 0.5623 at epoch 12\n",
      "\n",
      "Starting training with temp = 0.3162\n",
      "\n",
      "--------Epoch 1 (27 total)--------\n",
      "Val loss = 0.9375, Zero temp loss = 0.9361\n",
      "\n",
      "--------Epoch 2 (28 total)--------\n",
      "Val loss = 0.9404, Zero temp loss = 0.9389\n",
      "\n",
      "--------Epoch 3 (29 total)--------\n",
      "Val loss = 0.9373, Zero temp loss = 0.9354\n",
      "\n",
      "--------Epoch 4 (30 total)--------\n",
      "Val loss = 0.9362, Zero temp loss = 0.9342\n",
      "\n",
      "--------Epoch 5 (31 total)--------\n",
      "Val loss = 0.9421, Zero temp loss = 0.9402\n",
      "\n",
      "--------Epoch 6 (32 total)--------\n",
      "Val loss = 0.9368, Zero temp loss = 0.9361\n",
      "\n",
      "--------Epoch 7 (33 total)--------\n",
      "Val loss = 0.9408, Zero temp loss = 0.9395\n",
      "\n",
      "--------Epoch 8 (34 total)--------\n",
      "Val loss = 0.9407, Zero temp loss = 0.9373\n",
      "\n",
      "Epoch     8: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 9 (35 total)--------\n",
      "Val loss = 0.9437, Zero temp loss = 0.9424\n",
      "\n",
      "--------Epoch 10 (36 total)--------\n",
      "Val loss = 0.9433, Zero temp loss = 0.9430\n",
      "\n",
      "--------Epoch 11 (37 total)--------\n",
      "Val loss = 0.9458, Zero temp loss = 0.9447\n",
      "\n",
      "--------Epoch 12 (38 total)--------\n",
      "Val loss = 0.9431, Zero temp loss = 0.9419\n",
      "\n",
      "--------Epoch 13 (39 total)--------\n",
      "Val loss = 0.9452, Zero temp loss = 0.9443\n",
      "\n",
      "--------Epoch 14 (40 total)--------\n",
      "Val loss = 0.9460, Zero temp loss = 0.9453\n",
      "\n",
      "--------Epoch 15 (41 total)--------\n",
      "Val loss = 0.9447, Zero temp loss = 0.9434\n",
      "\n",
      "--------Epoch 16 (42 total)--------\n",
      "Val loss = 0.9446, Zero temp loss = 0.9431\n",
      "\n",
      "--------Epoch 17 (43 total)--------\n",
      "Val loss = 0.9445, Zero temp loss = 0.9433\n",
      "\n",
      "Epoch    17: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 18 (44 total)--------\n",
      "Val loss = 0.9470, Zero temp loss = 0.9445\n",
      "\n",
      "--------Epoch 19 (45 total)--------\n",
      "Val loss = 0.9455, Zero temp loss = 0.9445\n",
      "\n",
      "--------Epoch 20 (46 total)--------\n",
      "Val loss = 0.9478, Zero temp loss = 0.9468\n",
      "\n",
      "--------Epoch 21 (47 total)--------\n",
      "Val loss = 0.9475, Zero temp loss = 0.9462\n",
      "\n",
      "--------Epoch 22 (48 total)--------\n",
      "Val loss = 0.9464, Zero temp loss = 0.9454\n",
      "\n",
      "--------Epoch 23 (49 total)--------\n",
      "Val loss = 0.9466, Zero temp loss = 0.9451\n",
      "\n",
      "Epoch    23: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 24 (50 total)--------\n",
      "Val loss = 0.9470, Zero temp loss = 0.9466\n",
      "\n",
      "Stopping temp = 0.3162 at epoch 24\n",
      "\n",
      "Starting training with temp = 0.1778\n",
      "\n",
      "--------Epoch 1 (51 total)--------\n",
      "Val loss = 0.9378, Zero temp loss = 0.9366\n",
      "\n",
      "--------Epoch 2 (52 total)--------\n",
      "Val loss = 0.9360, Zero temp loss = 0.9353\n",
      "\n",
      "--------Epoch 3 (53 total)--------\n",
      "Val loss = 0.9358, Zero temp loss = 0.9360\n",
      "\n",
      "--------Epoch 4 (54 total)--------\n",
      "Val loss = 0.9371, Zero temp loss = 0.9367\n",
      "\n",
      "Epoch     4: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 5 (55 total)--------\n",
      "Val loss = 0.9366, Zero temp loss = 0.9363\n",
      "\n",
      "Stopping temp = 0.1778 at epoch 5\n",
      "\n",
      "Starting training with temp = 0.1000\n",
      "\n",
      "--------Epoch 1 (56 total)--------\n",
      "Val loss = 0.9355, Zero temp loss = 0.9353\n",
      "\n",
      "--------Epoch 2 (57 total)--------\n",
      "Val loss = 0.9317, Zero temp loss = 0.9316\n",
      "\n",
      "--------Epoch 3 (58 total)--------\n",
      "Val loss = 0.9334, Zero temp loss = 0.9332\n",
      "\n",
      "--------Epoch 4 (59 total)--------\n",
      "Val loss = 0.9289, Zero temp loss = 0.9283\n",
      "\n",
      "Epoch     4: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 5 (60 total)--------\n",
      "Val loss = 0.9360, Zero temp loss = 0.9359\n",
      "\n",
      "--------Epoch 6 (61 total)--------\n",
      "Val loss = 0.9343, Zero temp loss = 0.9337\n",
      "\n",
      "--------Epoch 7 (62 total)--------\n",
      "Val loss = 0.9368, Zero temp loss = 0.9365\n",
      "\n",
      "--------Epoch 8 (63 total)--------\n",
      "Val loss = 0.9386, Zero temp loss = 0.9387\n",
      "\n",
      "--------Epoch 9 (64 total)--------\n",
      "Val loss = 0.9374, Zero temp loss = 0.9371\n",
      "\n",
      "--------Epoch 10 (65 total)--------\n",
      "Val loss = 0.9375, Zero temp loss = 0.9370\n",
      "\n",
      "--------Epoch 11 (66 total)--------\n",
      "Val loss = 0.9397, Zero temp loss = 0.9399\n",
      "\n",
      "--------Epoch 12 (67 total)--------\n",
      "Val loss = 0.9396, Zero temp loss = 0.9392\n",
      "\n",
      "--------Epoch 13 (68 total)--------\n",
      "Val loss = 0.9387, Zero temp loss = 0.9382\n",
      "\n",
      "--------Epoch 14 (69 total)--------\n",
      "Val loss = 0.9406, Zero temp loss = 0.9405\n",
      "\n",
      "--------Epoch 15 (70 total)--------\n",
      "Val loss = 0.9405, Zero temp loss = 0.9402\n",
      "\n",
      "--------Epoch 16 (71 total)--------\n",
      "Val loss = 0.9407, Zero temp loss = 0.9405\n",
      "\n",
      "--------Epoch 17 (72 total)--------\n",
      "Val loss = 0.9413, Zero temp loss = 0.9410\n",
      "\n",
      "--------Epoch 18 (73 total)--------\n",
      "Val loss = 0.9414, Zero temp loss = 0.9412\n",
      "\n",
      "--------Epoch 19 (74 total)--------\n",
      "Val loss = 0.9397, Zero temp loss = 0.9397\n",
      "\n",
      "--------Epoch 20 (75 total)--------\n",
      "Val loss = 0.9407, Zero temp loss = 0.9410\n",
      "\n",
      "--------Epoch 21 (76 total)--------\n",
      "Val loss = 0.9410, Zero temp loss = 0.9404\n",
      "\n",
      "Epoch    21: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 22 (77 total)--------\n",
      "Val loss = 0.9408, Zero temp loss = 0.9410\n",
      "\n",
      "Stopping temp = 0.1000 at epoch 22\n",
      "\n",
      "Acc = 95.15\n",
      "\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",
    "mask_layer = MaskLayer(append=True)\n",
    "gafs = AdaptiveSelection(selector, deepcopy(predictor), mask_layer).to(device)\n",
    "\n",
    "# Tie weights\n",
    "gafs.selector[0] = gafs.predictor[0]\n",
    "gafs.selector[2] = gafs.predictor[2]\n",
    "\n",
    "for num in num_features:\n",
    "    # Train\n",
    "    gafs.fit(train_dataset,\n",
    "             val_dataset,\n",
    "             mbsize=128,\n",
    "             lr=1e-3,\n",
    "             nepochs=250,\n",
    "             max_features=num,\n",
    "             loss_fn=nn.CrossEntropyLoss(),\n",
    "             val_loss_fn=Accuracy(),\n",
    "             val_loss_mode='max')\n",
    "    \n",
    "    # Get accuracy\n",
    "    test_acc = gafs.evaluate(test_dataset, num, Accuracy(), 1024)\n",
    "    print(f'Acc = {100*test_acc:.2f}\\n')\n",
    "    acc_list.append(test_acc)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "sharp-layout",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.7032999992370605, 0.8783000111579895, 0.9235000014305115, 0.9424999952316284, 0.9514999985694885]\n"
     ]
    }
   ],
   "source": [
    "print(acc_list)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "47e04e17-12b8-4388-a7b6-91a1b467e86f",
   "metadata": {},
   "source": [
    "# Plot results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "07f3eb71-67ee-4f2b-9144-5566b913eb73",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(9, 6))\n",
    "\n",
    "# Plot\n",
    "plt.plot(num_features, acc_list, color='tab:green', marker='o', markersize=10)\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', fontsize=20)\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
}
