{
 "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', 7)"
   ]
  },
  {
   "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": 6,
   "id": "separate-going",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------Epoch 1--------\n",
      "Val loss = 0.3986\n",
      "\n",
      "--------Epoch 2--------\n",
      "Val loss = 0.4443\n",
      "\n",
      "--------Epoch 3--------\n",
      "Val loss = 0.4577\n",
      "\n",
      "--------Epoch 4--------\n",
      "Val loss = 0.4632\n",
      "\n",
      "--------Epoch 5--------\n",
      "Val loss = 0.4645\n",
      "\n",
      "--------Epoch 6--------\n",
      "Val loss = 0.4862\n",
      "\n",
      "--------Epoch 7--------\n",
      "Val loss = 0.4844\n",
      "\n",
      "--------Epoch 8--------\n",
      "Val loss = 0.4853\n",
      "\n",
      "--------Epoch 9--------\n",
      "Val loss = 0.4989\n",
      "\n",
      "--------Epoch 10--------\n",
      "Val loss = 0.4914\n",
      "\n",
      "--------Epoch 11--------\n",
      "Val loss = 0.4927\n",
      "\n",
      "--------Epoch 12--------\n",
      "Val loss = 0.5021\n",
      "\n",
      "--------Epoch 13--------\n",
      "Val loss = 0.5114\n",
      "\n",
      "--------Epoch 14--------\n",
      "Val loss = 0.5077\n",
      "\n",
      "--------Epoch 15--------\n",
      "Val loss = 0.5169\n",
      "\n",
      "--------Epoch 16--------\n",
      "Val loss = 0.5068\n",
      "\n",
      "--------Epoch 17--------\n",
      "Val loss = 0.5115\n",
      "\n",
      "--------Epoch 18--------\n",
      "Val loss = 0.5112\n",
      "\n",
      "Epoch    18: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 19--------\n",
      "Val loss = 0.5310\n",
      "\n",
      "--------Epoch 20--------\n",
      "Val loss = 0.5355\n",
      "\n",
      "--------Epoch 21--------\n",
      "Val loss = 0.5288\n",
      "\n",
      "--------Epoch 22--------\n",
      "Val loss = 0.5440\n",
      "\n",
      "--------Epoch 23--------\n",
      "Val loss = 0.5437\n",
      "\n",
      "--------Epoch 24--------\n",
      "Val loss = 0.5417\n",
      "\n",
      "--------Epoch 25--------\n",
      "Val loss = 0.5442\n",
      "\n",
      "--------Epoch 26--------\n",
      "Val loss = 0.5450\n",
      "\n",
      "--------Epoch 27--------\n",
      "Val loss = 0.5464\n",
      "\n",
      "--------Epoch 28--------\n",
      "Val loss = 0.5408\n",
      "\n",
      "--------Epoch 29--------\n",
      "Val loss = 0.5441\n",
      "\n",
      "--------Epoch 30--------\n",
      "Val loss = 0.5520\n",
      "\n",
      "--------Epoch 31--------\n",
      "Val loss = 0.5401\n",
      "\n",
      "--------Epoch 32--------\n",
      "Val loss = 0.5420\n",
      "\n",
      "--------Epoch 33--------\n",
      "Val loss = 0.5499\n",
      "\n",
      "Epoch    33: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 34--------\n",
      "Val loss = 0.5480\n",
      "\n",
      "Stopping early at epoch 34\n"
     ]
    }
   ],
   "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')\n",
    "\n",
    "# Save model\n",
    "predictor.cpu()\n",
    "torch.save(predictor, 'mnist_predictor_pretrained.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Load model\n",
    "predictor = torch.load('mnist_predictor_pretrained.pt')\n",
    "predictor.to(device)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ethical-terry",
   "metadata": {},
   "source": [
    "# Adaptive selection"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "59bffcaf-df21-4f33-9b16-bb7169b5582a",
   "metadata": {},
   "outputs": [],
   "source": [
    "from adaptive import AdaptiveSelection"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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.7483, Zero-temp loss = 0.6924\n",
      "\n",
      "--------Epoch 2 (2 total)--------\n",
      "Val loss = 0.7711, Zero-temp loss = 0.7082\n",
      "\n",
      "--------Epoch 3 (3 total)--------\n",
      "Val loss = 0.7807, Zero-temp loss = 0.7131\n",
      "\n",
      "--------Epoch 4 (4 total)--------\n",
      "Val loss = 0.7938, Zero-temp loss = 0.7182\n",
      "\n",
      "--------Epoch 5 (5 total)--------\n",
      "Val loss = 0.8017, Zero-temp loss = 0.7198\n",
      "\n",
      "--------Epoch 6 (6 total)--------\n",
      "Val loss = 0.8119, Zero-temp loss = 0.7235\n",
      "\n",
      "--------Epoch 7 (7 total)--------\n",
      "Val loss = 0.8139, Zero-temp loss = 0.7204\n",
      "\n",
      "--------Epoch 8 (8 total)--------\n",
      "Val loss = 0.8210, Zero-temp loss = 0.7213\n",
      "\n",
      "--------Epoch 9 (9 total)--------\n",
      "Val loss = 0.8277, Zero-temp loss = 0.7228\n",
      "\n",
      "--------Epoch 10 (10 total)--------\n",
      "Val loss = 0.8300, Zero-temp loss = 0.7204\n",
      "\n",
      "--------Epoch 11 (11 total)--------\n",
      "Val loss = 0.8334, Zero-temp loss = 0.7194\n",
      "\n",
      "--------Epoch 12 (12 total)--------\n",
      "Val loss = 0.8379, Zero-temp loss = 0.7179\n",
      "\n",
      "--------Epoch 13 (13 total)--------\n",
      "Val loss = 0.8439, Zero-temp loss = 0.7203\n",
      "\n",
      "--------Epoch 14 (14 total)--------\n",
      "Val loss = 0.8456, Zero-temp loss = 0.7147\n",
      "\n",
      "--------Epoch 15 (15 total)--------\n",
      "Val loss = 0.8494, Zero-temp loss = 0.7112\n",
      "\n",
      "--------Epoch 16 (16 total)--------\n",
      "Val loss = 0.8535, Zero-temp loss = 0.7123\n",
      "\n",
      "--------Epoch 17 (17 total)--------\n",
      "Val loss = 0.8580, Zero-temp loss = 0.7149\n",
      "\n",
      "--------Epoch 18 (18 total)--------\n",
      "Val loss = 0.8613, Zero-temp loss = 0.7124\n",
      "\n",
      "--------Epoch 19 (19 total)--------\n",
      "Val loss = 0.8620, Zero-temp loss = 0.7109\n",
      "\n",
      "--------Epoch 20 (20 total)--------\n",
      "Val loss = 0.8652, Zero-temp loss = 0.7122\n",
      "\n",
      "--------Epoch 21 (21 total)--------\n",
      "Val loss = 0.8634, Zero-temp loss = 0.7013\n",
      "\n",
      "--------Epoch 22 (22 total)--------\n",
      "Val loss = 0.8697, Zero-temp loss = 0.7069\n",
      "\n",
      "--------Epoch 23 (23 total)--------\n",
      "Val loss = 0.8694, Zero-temp loss = 0.7042\n",
      "\n",
      "--------Epoch 24 (24 total)--------\n",
      "Val loss = 0.8719, Zero-temp loss = 0.6989\n",
      "\n",
      "--------Epoch 25 (25 total)--------\n",
      "Val loss = 0.8743, Zero-temp loss = 0.7012\n",
      "\n",
      "--------Epoch 26 (26 total)--------\n",
      "Val loss = 0.8793, Zero-temp loss = 0.7048\n",
      "\n",
      "--------Epoch 27 (27 total)--------\n",
      "Val loss = 0.8782, Zero-temp loss = 0.6977\n",
      "\n",
      "--------Epoch 28 (28 total)--------\n",
      "Val loss = 0.8763, Zero-temp loss = 0.6948\n",
      "\n",
      "--------Epoch 29 (29 total)--------\n",
      "Val loss = 0.8791, Zero-temp loss = 0.6981\n",
      "\n",
      "Epoch    29: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 30 (30 total)--------\n",
      "Val loss = 0.8872, Zero-temp loss = 0.7042\n",
      "\n",
      "--------Epoch 31 (31 total)--------\n",
      "Val loss = 0.8917, Zero-temp loss = 0.7070\n",
      "\n",
      "--------Epoch 32 (32 total)--------\n",
      "Val loss = 0.8910, Zero-temp loss = 0.7018\n",
      "\n",
      "--------Epoch 33 (33 total)--------\n",
      "Val loss = 0.8914, Zero-temp loss = 0.7083\n",
      "\n",
      "--------Epoch 34 (34 total)--------\n",
      "Val loss = 0.8909, Zero-temp loss = 0.7052\n",
      "\n",
      "Epoch    34: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 35 (35 total)--------\n",
      "Val loss = 0.8932, Zero-temp loss = 0.7015\n",
      "\n",
      "--------Epoch 36 (36 total)--------\n",
      "Val loss = 0.8926, Zero-temp loss = 0.7032\n",
      "\n",
      "--------Epoch 37 (37 total)--------\n",
      "Val loss = 0.8955, Zero-temp loss = 0.7066\n",
      "\n",
      "--------Epoch 38 (38 total)--------\n",
      "Val loss = 0.8934, Zero-temp loss = 0.7056\n",
      "\n",
      "--------Epoch 39 (39 total)--------\n",
      "Val loss = 0.8968, Zero-temp loss = 0.7062\n",
      "\n",
      "--------Epoch 40 (40 total)--------\n",
      "Val loss = 0.8950, Zero-temp loss = 0.7061\n",
      "\n",
      "--------Epoch 41 (41 total)--------\n",
      "Val loss = 0.8941, Zero-temp loss = 0.7082\n",
      "\n",
      "--------Epoch 42 (42 total)--------\n",
      "Val loss = 0.8947, Zero-temp loss = 0.7048\n",
      "\n",
      "Epoch    42: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 43 (43 total)--------\n",
      "Val loss = 0.8961, Zero-temp loss = 0.7090\n",
      "\n",
      "Stopping temp = 1.0000 at epoch 43\n",
      "\n",
      "Starting training with temp = 0.5623\n",
      "\n",
      "--------Epoch 1 (44 total)--------\n",
      "Val loss = 0.8318, Zero-temp loss = 0.7361\n",
      "\n",
      "--------Epoch 2 (45 total)--------\n",
      "Val loss = 0.8376, Zero-temp loss = 0.7424\n",
      "\n",
      "--------Epoch 3 (46 total)--------\n",
      "Val loss = 0.8394, Zero-temp loss = 0.7439\n",
      "\n",
      "--------Epoch 4 (47 total)--------\n",
      "Val loss = 0.8400, Zero-temp loss = 0.7430\n",
      "\n",
      "--------Epoch 5 (48 total)--------\n",
      "Val loss = 0.8412, Zero-temp loss = 0.7433\n",
      "\n",
      "--------Epoch 6 (49 total)--------\n",
      "Val loss = 0.8387, Zero-temp loss = 0.7385\n",
      "\n",
      "--------Epoch 7 (50 total)--------\n",
      "Val loss = 0.8405, Zero-temp loss = 0.7431\n",
      "\n",
      "--------Epoch 8 (51 total)--------\n",
      "Val loss = 0.8431, Zero-temp loss = 0.7473\n",
      "\n",
      "--------Epoch 9 (52 total)--------\n",
      "Val loss = 0.8436, Zero-temp loss = 0.7432\n",
      "\n",
      "--------Epoch 10 (53 total)--------\n",
      "Val loss = 0.8452, Zero-temp loss = 0.7444\n",
      "\n",
      "--------Epoch 11 (54 total)--------\n",
      "Val loss = 0.8462, Zero-temp loss = 0.7461\n",
      "\n",
      "--------Epoch 12 (55 total)--------\n",
      "Val loss = 0.8459, Zero-temp loss = 0.7443\n",
      "\n",
      "--------Epoch 13 (56 total)--------\n",
      "Val loss = 0.8488, Zero-temp loss = 0.7477\n",
      "\n",
      "--------Epoch 14 (57 total)--------\n",
      "Val loss = 0.8452, Zero-temp loss = 0.7425\n",
      "\n",
      "--------Epoch 15 (58 total)--------\n",
      "Val loss = 0.8459, Zero-temp loss = 0.7412\n",
      "\n",
      "--------Epoch 16 (59 total)--------\n",
      "Val loss = 0.8520, Zero-temp loss = 0.7467\n",
      "\n",
      "--------Epoch 17 (60 total)--------\n",
      "Val loss = 0.8504, Zero-temp loss = 0.7442\n",
      "\n",
      "--------Epoch 18 (61 total)--------\n",
      "Val loss = 0.8499, Zero-temp loss = 0.7434\n",
      "\n",
      "--------Epoch 19 (62 total)--------\n",
      "Val loss = 0.8527, Zero-temp loss = 0.7467\n",
      "\n",
      "--------Epoch 20 (63 total)--------\n",
      "Val loss = 0.8521, Zero-temp loss = 0.7469\n",
      "\n",
      "--------Epoch 21 (64 total)--------\n",
      "Val loss = 0.8551, Zero-temp loss = 0.7467\n",
      "\n",
      "--------Epoch 22 (65 total)--------\n",
      "Val loss = 0.8540, Zero-temp loss = 0.7440\n",
      "\n",
      "--------Epoch 23 (66 total)--------\n",
      "Val loss = 0.8542, Zero-temp loss = 0.7450\n",
      "\n",
      "--------Epoch 24 (67 total)--------\n",
      "Val loss = 0.8563, Zero-temp loss = 0.7461\n",
      "\n",
      "--------Epoch 25 (68 total)--------\n",
      "Val loss = 0.8531, Zero-temp loss = 0.7398\n",
      "\n",
      "--------Epoch 26 (69 total)--------\n",
      "Val loss = 0.8548, Zero-temp loss = 0.7433\n",
      "\n",
      "--------Epoch 27 (70 total)--------\n",
      "Val loss = 0.8561, Zero-temp loss = 0.7431\n",
      "\n",
      "Epoch    27: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 28 (71 total)--------\n",
      "Val loss = 0.8640, Zero-temp loss = 0.7501\n",
      "\n",
      "--------Epoch 29 (72 total)--------\n",
      "Val loss = 0.8680, Zero-temp loss = 0.7542\n",
      "\n",
      "--------Epoch 30 (73 total)--------\n",
      "Val loss = 0.8655, Zero-temp loss = 0.7515\n",
      "\n",
      "--------Epoch 31 (74 total)--------\n",
      "Val loss = 0.8685, Zero-temp loss = 0.7537\n",
      "\n",
      "--------Epoch 32 (75 total)--------\n",
      "Val loss = 0.8696, Zero-temp loss = 0.7553\n",
      "\n",
      "--------Epoch 33 (76 total)--------\n",
      "Val loss = 0.8702, Zero-temp loss = 0.7549\n",
      "\n",
      "--------Epoch 34 (77 total)--------\n",
      "Val loss = 0.8719, Zero-temp loss = 0.7564\n",
      "\n",
      "--------Epoch 35 (78 total)--------\n",
      "Val loss = 0.8711, Zero-temp loss = 0.7520\n",
      "\n",
      "--------Epoch 36 (79 total)--------\n",
      "Val loss = 0.8719, Zero-temp loss = 0.7543\n",
      "\n",
      "--------Epoch 37 (80 total)--------\n",
      "Val loss = 0.8690, Zero-temp loss = 0.7519\n",
      "\n",
      "Epoch    37: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 38 (81 total)--------\n",
      "Val loss = 0.8733, Zero-temp loss = 0.7570\n",
      "\n",
      "--------Epoch 39 (82 total)--------\n",
      "Val loss = 0.8706, Zero-temp loss = 0.7534\n",
      "\n",
      "--------Epoch 40 (83 total)--------\n",
      "Val loss = 0.8730, Zero-temp loss = 0.7564\n",
      "\n",
      "--------Epoch 41 (84 total)--------\n",
      "Val loss = 0.8750, Zero-temp loss = 0.7577\n",
      "\n",
      "--------Epoch 42 (85 total)--------\n",
      "Val loss = 0.8737, Zero-temp loss = 0.7570\n",
      "\n",
      "--------Epoch 43 (86 total)--------\n",
      "Val loss = 0.8730, Zero-temp loss = 0.7550\n",
      "\n",
      "--------Epoch 44 (87 total)--------\n",
      "Val loss = 0.8730, Zero-temp loss = 0.7557\n",
      "\n",
      "Epoch    44: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 45 (88 total)--------\n",
      "Val loss = 0.8745, Zero-temp loss = 0.7563\n",
      "\n",
      "Stopping temp = 0.5623 at epoch 45\n",
      "\n",
      "Starting training with temp = 0.3162\n",
      "\n",
      "--------Epoch 1 (89 total)--------\n",
      "Val loss = 0.8174, Zero-temp loss = 0.7657\n",
      "\n",
      "--------Epoch 2 (90 total)--------\n",
      "Val loss = 0.8192, Zero-temp loss = 0.7700\n",
      "\n",
      "--------Epoch 3 (91 total)--------\n",
      "Val loss = 0.8217, Zero-temp loss = 0.7742\n",
      "\n",
      "--------Epoch 4 (92 total)--------\n",
      "Val loss = 0.8206, Zero-temp loss = 0.7749\n",
      "\n",
      "--------Epoch 5 (93 total)--------\n",
      "Val loss = 0.8204, Zero-temp loss = 0.7743\n",
      "\n",
      "--------Epoch 6 (94 total)--------\n",
      "Val loss = 0.8212, Zero-temp loss = 0.7758\n",
      "\n",
      "Epoch     6: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 7 (95 total)--------\n",
      "Val loss = 0.8304, Zero-temp loss = 0.7846\n",
      "\n",
      "--------Epoch 8 (96 total)--------\n",
      "Val loss = 0.8341, Zero-temp loss = 0.7866\n",
      "\n",
      "--------Epoch 9 (97 total)--------\n",
      "Val loss = 0.8323, Zero-temp loss = 0.7848\n",
      "\n",
      "--------Epoch 10 (98 total)--------\n",
      "Val loss = 0.8316, Zero-temp loss = 0.7831\n",
      "\n",
      "--------Epoch 11 (99 total)--------\n",
      "Val loss = 0.8328, Zero-temp loss = 0.7846\n",
      "\n",
      "Epoch    11: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 12 (100 total)--------\n",
      "Val loss = 0.8364, Zero-temp loss = 0.7882\n",
      "\n",
      "--------Epoch 13 (101 total)--------\n",
      "Val loss = 0.8371, Zero-temp loss = 0.7883\n",
      "\n",
      "--------Epoch 14 (102 total)--------\n",
      "Val loss = 0.8379, Zero-temp loss = 0.7899\n",
      "\n",
      "--------Epoch 15 (103 total)--------\n",
      "Val loss = 0.8358, Zero-temp loss = 0.7873\n",
      "\n",
      "--------Epoch 16 (104 total)--------\n",
      "Val loss = 0.8354, Zero-temp loss = 0.7859\n",
      "\n",
      "--------Epoch 17 (105 total)--------\n",
      "Val loss = 0.8385, Zero-temp loss = 0.7903\n",
      "\n",
      "--------Epoch 18 (106 total)--------\n",
      "Val loss = 0.8373, Zero-temp loss = 0.7889\n",
      "\n",
      "--------Epoch 19 (107 total)--------\n",
      "Val loss = 0.8363, Zero-temp loss = 0.7879\n",
      "\n",
      "--------Epoch 20 (108 total)--------\n",
      "Val loss = 0.8393, Zero-temp loss = 0.7898\n",
      "\n",
      "--------Epoch 21 (109 total)--------\n",
      "Val loss = 0.8378, Zero-temp loss = 0.7890\n",
      "\n",
      "--------Epoch 22 (110 total)--------\n",
      "Val loss = 0.8391, Zero-temp loss = 0.7895\n",
      "\n",
      "--------Epoch 23 (111 total)--------\n",
      "Val loss = 0.8372, Zero-temp loss = 0.7889\n",
      "\n",
      "Epoch    23: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 24 (112 total)--------\n",
      "Val loss = 0.8368, Zero-temp loss = 0.7873\n",
      "\n",
      "Stopping temp = 0.3162 at epoch 24\n",
      "\n",
      "Starting training with temp = 0.1778\n",
      "\n",
      "--------Epoch 1 (113 total)--------\n",
      "Val loss = 0.8061, Zero-temp loss = 0.7867\n",
      "\n",
      "--------Epoch 2 (114 total)--------\n",
      "Val loss = 0.8087, Zero-temp loss = 0.7900\n",
      "\n",
      "--------Epoch 3 (115 total)--------\n",
      "Val loss = 0.8099, Zero-temp loss = 0.7918\n",
      "\n",
      "--------Epoch 4 (116 total)--------\n",
      "Val loss = 0.8117, Zero-temp loss = 0.7937\n",
      "\n",
      "--------Epoch 5 (117 total)--------\n",
      "Val loss = 0.8116, Zero-temp loss = 0.7954\n",
      "\n",
      "--------Epoch 6 (118 total)--------\n",
      "Val loss = 0.8124, Zero-temp loss = 0.7959\n",
      "\n",
      "--------Epoch 7 (119 total)--------\n",
      "Val loss = 0.8110, Zero-temp loss = 0.7933\n",
      "\n",
      "--------Epoch 8 (120 total)--------\n",
      "Val loss = 0.8130, Zero-temp loss = 0.7958\n",
      "\n",
      "--------Epoch 9 (121 total)--------\n",
      "Val loss = 0.8119, Zero-temp loss = 0.7960\n",
      "\n",
      "--------Epoch 10 (122 total)--------\n",
      "Val loss = 0.8132, Zero-temp loss = 0.7968\n",
      "\n",
      "--------Epoch 11 (123 total)--------\n",
      "Val loss = 0.8133, Zero-temp loss = 0.7975\n",
      "\n",
      "--------Epoch 12 (124 total)--------\n",
      "Val loss = 0.8112, Zero-temp loss = 0.7945\n",
      "\n",
      "--------Epoch 13 (125 total)--------\n",
      "Val loss = 0.8113, Zero-temp loss = 0.7948\n",
      "\n",
      "Epoch    13: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 14 (126 total)--------\n",
      "Val loss = 0.8171, Zero-temp loss = 0.8007\n",
      "\n",
      "--------Epoch 15 (127 total)--------\n",
      "Val loss = 0.8204, Zero-temp loss = 0.8039\n",
      "\n",
      "--------Epoch 16 (128 total)--------\n",
      "Val loss = 0.8226, Zero-temp loss = 0.8061\n",
      "\n",
      "--------Epoch 17 (129 total)--------\n",
      "Val loss = 0.8223, Zero-temp loss = 0.8059\n",
      "\n",
      "--------Epoch 18 (130 total)--------\n",
      "Val loss = 0.8203, Zero-temp loss = 0.8038\n",
      "\n",
      "--------Epoch 19 (131 total)--------\n",
      "Val loss = 0.8214, Zero-temp loss = 0.8045\n",
      "\n",
      "Epoch    19: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 20 (132 total)--------\n",
      "Val loss = 0.8246, Zero-temp loss = 0.8074\n",
      "\n",
      "--------Epoch 21 (133 total)--------\n",
      "Val loss = 0.8240, Zero-temp loss = 0.8065\n",
      "\n",
      "--------Epoch 22 (134 total)--------\n",
      "Val loss = 0.8245, Zero-temp loss = 0.8078\n",
      "\n",
      "--------Epoch 23 (135 total)--------\n",
      "Val loss = 0.8232, Zero-temp loss = 0.8066\n",
      "\n",
      "Epoch    23: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 24 (136 total)--------\n",
      "Val loss = 0.8247, Zero-temp loss = 0.8072\n",
      "\n",
      "--------Epoch 25 (137 total)--------\n",
      "Val loss = 0.8263, Zero-temp loss = 0.8093\n",
      "\n",
      "--------Epoch 26 (138 total)--------\n",
      "Val loss = 0.8264, Zero-temp loss = 0.8088\n",
      "\n",
      "--------Epoch 27 (139 total)--------\n",
      "Val loss = 0.8253, Zero-temp loss = 0.8080\n",
      "\n",
      "--------Epoch 28 (140 total)--------\n",
      "Val loss = 0.8245, Zero-temp loss = 0.8074\n",
      "\n",
      "--------Epoch 29 (141 total)--------\n",
      "Val loss = 0.8254, Zero-temp loss = 0.8081\n",
      "\n",
      "--------Epoch 30 (142 total)--------\n",
      "Val loss = 0.8241, Zero-temp loss = 0.8067\n",
      "\n",
      "Stopping temp = 0.1778 at epoch 30\n",
      "\n",
      "Starting training with temp = 0.1000\n",
      "\n",
      "--------Epoch 1 (143 total)--------\n",
      "Val loss = 0.8050, Zero-temp loss = 0.7975\n",
      "\n",
      "--------Epoch 2 (144 total)--------\n",
      "Val loss = 0.8068, Zero-temp loss = 0.7997\n",
      "\n",
      "--------Epoch 3 (145 total)--------\n",
      "Val loss = 0.8089, Zero-temp loss = 0.8017\n",
      "\n",
      "--------Epoch 4 (146 total)--------\n",
      "Val loss = 0.8068, Zero-temp loss = 0.8005\n",
      "\n",
      "--------Epoch 5 (147 total)--------\n",
      "Val loss = 0.8044, Zero-temp loss = 0.7978\n",
      "\n",
      "--------Epoch 6 (148 total)--------\n",
      "Val loss = 0.8050, Zero-temp loss = 0.7985\n",
      "\n",
      "Epoch     6: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 7 (149 total)--------\n",
      "Val loss = 0.8119, Zero-temp loss = 0.8051\n",
      "\n",
      "--------Epoch 8 (150 total)--------\n",
      "Val loss = 0.8157, Zero-temp loss = 0.8093\n",
      "\n",
      "--------Epoch 9 (151 total)--------\n",
      "Val loss = 0.8173, Zero-temp loss = 0.8104\n",
      "\n",
      "--------Epoch 10 (152 total)--------\n",
      "Val loss = 0.8167, Zero-temp loss = 0.8105\n",
      "\n",
      "--------Epoch 11 (153 total)--------\n",
      "Val loss = 0.8184, Zero-temp loss = 0.8117\n",
      "\n",
      "--------Epoch 12 (154 total)--------\n",
      "Val loss = 0.8167, Zero-temp loss = 0.8103\n",
      "\n",
      "--------Epoch 13 (155 total)--------\n",
      "Val loss = 0.8187, Zero-temp loss = 0.8126\n",
      "\n",
      "--------Epoch 14 (156 total)--------\n",
      "Val loss = 0.8179, Zero-temp loss = 0.8112\n",
      "\n",
      "--------Epoch 15 (157 total)--------\n",
      "Val loss = 0.8188, Zero-temp loss = 0.8120\n",
      "\n",
      "--------Epoch 16 (158 total)--------\n",
      "Val loss = 0.8188, Zero-temp loss = 0.8121\n",
      "\n",
      "Epoch    16: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 17 (159 total)--------\n",
      "Val loss = 0.8212, Zero-temp loss = 0.8145\n",
      "\n",
      "--------Epoch 18 (160 total)--------\n",
      "Val loss = 0.8200, Zero-temp loss = 0.8132\n",
      "\n",
      "--------Epoch 19 (161 total)--------\n",
      "Val loss = 0.8184, Zero-temp loss = 0.8114\n",
      "\n",
      "--------Epoch 20 (162 total)--------\n",
      "Val loss = 0.8201, Zero-temp loss = 0.8132\n",
      "\n",
      "Epoch    20: reducing learning rate of group 0 to 1.0000e-05.\n",
      "--------Epoch 21 (163 total)--------\n",
      "Val loss = 0.8204, Zero-temp loss = 0.8134\n",
      "\n",
      "Stopping temp = 0.1000 at epoch 21\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",
    "# Train\n",
    "gafs.fit(train_dataset,\n",
    "         val_dataset,\n",
    "         mbsize=128,\n",
    "         lr=1e-3,\n",
    "         nepochs=250,\n",
    "         max_features=max(num_features),\n",
    "         loss_fn=nn.CrossEntropyLoss(),\n",
    "         val_loss_fn=Accuracy(),\n",
    "         val_loss_mode='max',\n",
    "         validation_mode='mean')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "0f8510d8-84c3-428e-990f-ad5c952af61a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Acc (5) = 70.95\n",
      "Acc (10) = 88.62\n",
      "Acc (15) = 93.33\n",
      "Acc (20) = 94.87\n",
      "Acc (25) = 95.14\n"
     ]
    }
   ],
   "source": [
    "# Get accuracy\n",
    "for num in num_features:\n",
    "    test_acc = gafs.evaluate(test_dataset, num, Accuracy(), 1024)\n",
    "    print(f'Acc ({num}) = {100*test_acc:.2f}')\n",
    "    acc_list.append(test_acc)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "697ee1c2-65a5-4a89-98cc-6fbe617c46df",
   "metadata": {},
   "source": [
    "# Check calibration"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "d15bca2b-f56d-402c-be55-c3a9fe4470de",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torchmetrics.functional.classification.calibration_error import _ce_update, _binning_bucketize"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "88b7a790-5b8d-423c-9ee2-f7a39c7ad499",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set feature budget\n",
    "num = 10\n",
    "\n",
    "# Prepare inputs\n",
    "x = torch.stack([x for x, y in test_dataset])\n",
    "y = torch.tensor(np.array([y for x, y in test_dataset]))\n",
    "\n",
    "# Generate predictions\n",
    "with torch.no_grad():\n",
    "    pred = gafs.forward(x.to(device), max_features=num).softmax(dim=1).cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "426aa45b-9295-41c0-9c41-e572167246d7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Acc = 88.62\n",
      "\n"
     ]
    }
   ],
   "source": [
    "test_acc = gafs.evaluate(test_dataset, num, Accuracy(), 1024)\n",
    "print(f'Acc = {100*test_acc:.2f}\\n')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "abfd0c31-1c79-41e9-abc0-d0ad1b0b3578",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calibration error = 0.0161\n"
     ]
    }
   ],
   "source": [
    "# Calculate per-bin calibration results\n",
    "bin_boundaries = torch.linspace(0, 1, 20)\n",
    "confidences, accuracies = _ce_update(pred, y)\n",
    "acc_bin, conf_bin, prop_bin = _binning_bucketize(confidences, accuracies, bin_boundaries)\n",
    "\n",
    "# Calculate l2 metric\n",
    "ce = torch.sqrt(torch.sum(torch.pow(acc_bin - conf_bin, 2) * prop_bin))\n",
    "print(f'Calibration error = {ce:.4f}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "72630242-cf6d-42b2-b9c5-bbe34961da28",
   "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(conf_bin, acc_bin, marker='o')\n",
    "plt.plot([0, 1], [0, 1], color='black', linestyle=':')\n",
    "\n",
    "# Labels\n",
    "plt.xlabel('Confidence', fontsize=18)\n",
    "plt.ylabel('Accuracy', fontsize=18)\n",
    "plt.tick_params(labelsize=16)\n",
    "plt.title('Calibration', fontsize=20)\n",
    "\n",
    "# Axis spines\n",
    "plt.gca().spines['right'].set_visible(False)\n",
    "plt.gca().spines['top'].set_visible(False)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "47e04e17-12b8-4388-a7b6-91a1b467e86f",
   "metadata": {},
   "source": [
    "# Plot results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "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
}
