{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.utils.data import DataLoader, Subset, RandomSampler\n",
    "from torch.cuda import amp\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "\n",
    "from spikingjelly.activation_based import neuron, functional, surrogate, layer, encoding\n",
    "from spikingjelly import visualizing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torchvision\n",
    "from torchvision import datasets, transforms\n",
    "from torchvision.utils import make_grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch.optim.lr_scheduler as lr_scheduler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import time\n",
    "import sys\n",
    "import datetime\n",
    "import argparse\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import math\n",
    "import yaml"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define your chosen classes\n",
    "\n",
    "classes = ['0', '1', '2', '3',\n",
    "           '4', '5', '6', '7', '8', '9']\n",
    "\n",
    "\n",
    "label_list = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] # [1,5,9] # Choose classes based on requirements\n",
    "label_tensor = torch.tensor(label_list)\n",
    "classes_filtered = [classes[i] for i in label_list]\n",
    "label_map = {label_list[i] : i for i in range(len(label_list))}\n",
    "label_map_inverse = { i : label_list[i] for i in range(len(label_list))}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Function to filter the dataset\n",
    "def filter_dataset_by_classes(dataset, class_indices):\n",
    "    indices = [i for i, (_, label) in enumerate(dataset) if label in class_indices]\n",
    "    return Subset(dataset, indices)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set your own args\n",
    "\n",
    "# args={}\n",
    "\n",
    "# args['device'] =  torch.device('mps' if torch.backends.mps.is_available() else 'cpu')\n",
    "\n",
    "# # Training params\n",
    "# args['batch_size']=32\n",
    "# args['test_batch_size']=10\n",
    "# args['start_epoch'] = 0\n",
    "# args['epochs']=50\n",
    "\n",
    "# # For optimizer\n",
    "# args['lr']=0.01\n",
    "# args['lr_threshold'] = 1\n",
    "# args['momentum']=0.5\n",
    "\n",
    "# # Set seed for RNG\n",
    "# args['torch-seed'] = 99 #random seed\n",
    "# args['seed-sklearn'] = 54\n",
    "\n",
    "# args['log_interval'] = 10\n",
    "# args['usage_device'] = torch.backends.mps.is_available()\n",
    "\n",
    "# # SNN hyper-params\n",
    "# args['T'] = 20 # Maximum time step for the firing of neurons\n",
    "# args['num_classes'] = len(label_list)  # Number of classes in MNIST\n",
    "# args['hidden_neurons'] = 8  # Number of neurons in the single hidden neuron\n",
    "\n",
    "# torch.manual_seed(args['torch-seed'])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load pre-saved args from YAML file\n",
    "\n",
    "yaml_file_name = 'final_exps/10-digit/(0,1)_quantisation/args_128_[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]_(3.56655216217041, 1.0003286600112915).yaml'\n",
    "with open(yaml_file_name, \"r\") as file:\n",
    "    args = yaml.safe_load(file)\n",
    "\n",
    "torch.manual_seed(args['torch-seed'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set device\n",
    "args['device'] =  torch.device('mps' if torch.backends.mps.is_available() else 'cpu')\n",
    "args\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [],
   "source": [
    "transform = transforms.Compose([\n",
    "    transforms.ToTensor()\n",
    "])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of training samples: 60000\n",
      "Number of validation samples: 7000\n",
      "Number of test samples: 3000\n"
     ]
    }
   ],
   "source": [
    "# download and transform train dataset\n",
    "full_train_dataset = datasets.MNIST('../mnist_data', download=True, train=True, transform=transform)\n",
    "\n",
    "full_val_test_dataset = datasets.MNIST('../mnist_data', download=True, train=False, transform=transform)\n",
    "\n",
    "# Filter the datasets\n",
    "train_dataset = filter_dataset_by_classes(full_train_dataset, label_list)\n",
    "val_test_dataset = filter_dataset_by_classes(full_val_test_dataset, label_list)\n",
    "\n",
    "# Split the validation and test datasets\n",
    "val_idx, test_idx = train_test_split(list(range(len(val_test_dataset))), test_size=0.3, random_state=args['seed-sklearn'])\n",
    "\n",
    "val_dataset = Subset(val_test_dataset, val_idx)\n",
    "test_dataset = Subset(val_test_dataset, test_idx)\n",
    "\n",
    "# Define train, validation, and test data loaders\n",
    "train_loader = DataLoader(train_dataset, batch_size=args['batch_size'], shuffle=True)\n",
    "val_loader = DataLoader(val_dataset, batch_size=args['batch_size'], shuffle=False)\n",
    "test_loader = DataLoader(test_dataset, batch_size=args['batch_size'], shuffle=False)\n",
    "\n",
    "print(\"Number of training samples:\", len(train_dataset))\n",
    "print(\"Number of validation samples:\", len(val_dataset))\n",
    "print(\"Number of test samples:\", len(test_dataset))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Visualise MNIST images\n",
    "def show_images(images, nmax=64):\n",
    "    fig, ax = plt.subplots(figsize=(8, 8))\n",
    "    ax.set_xticks([]); ax.set_yticks([])\n",
    "    ax.imshow(make_grid((images.detach()[:nmax]), nrow=8).permute(1, 2, 0))\n",
    "\n",
    "def show_batch(dl, nmax=64):\n",
    "    for images, _ in dl:\n",
    "        show_images(images, nmax)\n",
    "        break\n",
    "\n",
    "show_batch(test_loader)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Define the SNN models"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Layer with {0, 1} weights using STE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "class BinaryStepFunction_0_1(torch.autograd.Function):\n",
    "\n",
    "    @staticmethod\n",
    "    def forward(ctx, input):\n",
    "        return (input.sign() + 1)/2\n",
    "\n",
    "    @staticmethod\n",
    "    def backward(ctx, grad_output):\n",
    "        return grad_output.clone()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "class BinaryLayer_0_1(nn.Module):\n",
    "    def __init__(self, input_features, output_features):\n",
    "        super(BinaryLayer_0_1, self).__init__()\n",
    "        self.weight = nn.Parameter(torch.Tensor(output_features, input_features))\n",
    "        #nn.init.kaiming_uniform_(self.weight, a=math.sqrt(5))  # Weight initialization\n",
    "        nn.init.uniform_(self.weight, 0,1)\n",
    "\n",
    "    def forward(self, x):\n",
    "        weight_max = torch.abs(self.weight).max().detach()  \n",
    "        weight_min = torch.abs(self.weight).min().detach()  \n",
    "        # epsilon = (weight_max + weight_min) / 2  \n",
    "\n",
    "        binary_weight = BinaryStepFunction_0_1.apply(self.weight-args['epsilon'])\n",
    "        return F.linear(x, binary_weight)\n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "class SNN_model_thLR(nn.Module):\n",
    "    def __init__(self, in_channels, out_channels, hidden_neurons, init_th_1=1.0, init_th_2=1.0):  \n",
    "        super(SNN_model_thLR, self).__init__()\n",
    "\n",
    "        # First layer neuron\n",
    "        self.layer1 = BinaryLayer_0_1(in_channels, hidden_neurons)\n",
    "        self.v_threshold1 = nn.Parameter(torch.tensor( init_th_1 ))  # Learnable threshold for neuron1\n",
    "        self.neuron1 = neuron.IFNode(surrogate_function=surrogate.ATan())\n",
    "\n",
    "        # Second layer neuron\n",
    "        self.layer2 = BinaryLayer_0_1(hidden_neurons, out_channels)\n",
    "        self.v_threshold2 = nn.Parameter(torch.tensor( init_th_2 ))  # Learnable threshold for neuron2\n",
    "        self.neuron2 = neuron.IFNode(surrogate_function=surrogate.ATan())\n",
    "\n",
    "    def forward(self, x):\n",
    "        # Pass through first layer\n",
    "        y = self.layer1(x)\n",
    "       \n",
    "        self.neuron1.v_threshold = self.v_threshold1 \n",
    "        y = self.neuron1(y)\n",
    "\n",
    "\n",
    "        # Pass through second layer\n",
    "        y = self.layer2(y)\n",
    "        \n",
    "        self.neuron2.v_threshold = self.v_threshold2  \n",
    "        y = self.neuron2(y)\n",
    "\n",
    "        return y\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Layer with {-1, 0, 1} weights using STE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "class BinaryStepFunction_ternary(torch.autograd.Function):\n",
    "\n",
    "    @staticmethod\n",
    "    def forward(ctx, input):\n",
    "        return input.sign()\n",
    "\n",
    "    @staticmethod\n",
    "    def backward(ctx, grad_output):\n",
    "        return grad_output.clone()\n",
    "    \n",
    "class TernaryLayer(nn.Module):\n",
    "    def __init__(self, input_features, output_features):\n",
    "        super(TernaryLayer, self).__init__()\n",
    "        self.weight = nn.Parameter(torch.Tensor(output_features, input_features))\n",
    "        nn.init.kaiming_uniform_(self.weight, a=math.sqrt(5))  # Weight initialization\n",
    "\n",
    "    def forward(self, x):\n",
    "        ternary_weight = BinaryStepFunction_ternary.apply(self.weight - args['epsilon'])\n",
    "        return F.linear(x, ternary_weight)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "class SNN_model_ternary_thLR(nn.Module):\n",
    "    def __init__(self, in_channels, out_channels, hidden_neurons, init_th_1=1.0, init_th_2=1.0):  \n",
    "        super(SNN_model_ternary_thLR, self).__init__()\n",
    "\n",
    "        # First layer neuron\n",
    "        self.layer1 = TernaryLayer(in_channels, hidden_neurons)\n",
    "        self.v_threshold1 = nn.Parameter(torch.tensor( init_th_1 ))  # Learnable threshold for neuron1\n",
    "        self.neuron1 = neuron.IFNode(surrogate_function=surrogate.ATan())\n",
    "\n",
    "        # Second layer neuron\n",
    "        self.layer2 = TernaryLayer(hidden_neurons, out_channels)\n",
    "        self.v_threshold2 = nn.Parameter(torch.tensor( init_th_2 ))  # Learnable threshold for neuron2\n",
    "        self.neuron2 = neuron.IFNode(surrogate_function=surrogate.ATan())\n",
    "\n",
    "    def forward(self, x):\n",
    "        # Pass through first layer\n",
    "        y = self.layer1(x)\n",
    "       \n",
    "        self.neuron1.v_threshold = self.v_threshold1 \n",
    "        y = self.neuron1(y)\n",
    "\n",
    "\n",
    "        # Pass through second layer\n",
    "        y = self.layer2(y)\n",
    "        \n",
    "        self.neuron2.v_threshold = self.v_threshold2  \n",
    "        y = self.neuron2(y)\n",
    "\n",
    "        return y\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Define learning rate schedulers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_lr_lambda(base_lr, factor):\n",
    "    def lr_lambda(epoch):\n",
    "        return base_lr/(1+factor*epoch)\n",
    "    return lr_lambda\n",
    "\n",
    "\n",
    "def get_lr_lambda_spTh(base_lr_Th, factor):\n",
    "    def lr_lambda_spTh(epoch):\n",
    "        return base_lr_Th/(1+factor*epoch)\n",
    "    return lr_lambda_spTh"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Define the threshold binarised image encoding "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def thresholded_image_encoding_device(X: torch.Tensor, threshold: torch.Tensor):\n",
    "    # Move threshold to the same device as X\n",
    "    threshold = threshold.to(X.device)\n",
    "\n",
    "    # Check if threshold is a scalar tensor\n",
    "    if threshold.numel() == 1:  # Check if threshold has only one element\n",
    "        # Expand the scalar threshold to match the batch size\n",
    "        threshold = threshold.expand(X.shape[0])  # Replicate threshold for each batch\n",
    "\n",
    "    # Check if threshold size matches batch size\n",
    "    if threshold.shape[0] != X.shape[0]:\n",
    "        print(\"Threshold size does not match the batch-size\")\n",
    "        raise ValueError(\"Threshold size does not match the batch-size\")\n",
    "\n",
    "    # Expand the threshold to match the dimensions of X for broadcasting\n",
    "    threshold_expanded = threshold.view(-1, 1, 1, 1)\n",
    "\n",
    "    # Apply the threshold to X for each batch\n",
    "    thresholded_image = torch.where(X > threshold_expanded, 1, 0)\n",
    "\n",
    "    return thresholded_image.float()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Script for training BSNNs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 0 Train Loss: 0.0563 Validation Loss: 0.0418 Train Accuracy: 59.9767% Val Accuracy: 76.6286% LR: 0.0010 LR_th: 0.0001 Spike Thresh: (2.031759023666382, 1.0617432594299316)\n",
      "\n",
      "Maximum Validation Accuracy of 0.7663% at epoch 0\n",
      "Model Saved\n",
      "\n",
      "Epoch: 1 Train Loss: 0.0767 Validation Loss: 0.0617 Train Accuracy: 44.7917% Val Accuracy: 52.2714% LR: 0.0100 LR_th: 0.0010 Spike Thresh: (2.1468422412872314, 1.5362826585769653)\n",
      "Epoch: 2 Train Loss: 0.0624 Validation Loss: 0.0529 Train Accuracy: 57.4567% Val Accuracy: 56.6429% LR: 0.0100 LR_th: 0.0010 Spike Thresh: (2.2854907512664795, 2.081071376800537)\n",
      "Epoch: 3 Train Loss: 0.0501 Validation Loss: 0.0248 Train Accuracy: 70.2183% Val Accuracy: 84.4286% LR: 0.0100 LR_th: 0.0010 Spike Thresh: (2.439603567123413, 2.448559045791626)\n",
      "\n",
      "Maximum Validation Accuracy of 0.8443% at epoch 3\n",
      "Model Saved\n",
      "\n",
      "Epoch: 4 Train Loss: 0.0517 Validation Loss: 0.0808 Train Accuracy: 73.3483% Val Accuracy: 44.4286% LR: 0.0100 LR_th: 0.0010 Spike Thresh: (2.5568878650665283, 2.833897352218628)\n",
      "Epoch: 5 Train Loss: 0.1158 Validation Loss: 0.0836 Train Accuracy: 43.5233% Val Accuracy: 48.9714% LR: 0.0100 LR_th: 0.0010 Spike Thresh: (2.617924928665161, 2.8871798515319824)\n",
      "Epoch: 6 Train Loss: 0.0933 Validation Loss: 0.0472 Train Accuracy: 59.0000% Val Accuracy: 62.4286% LR: 0.0099 LR_th: 0.0010 Spike Thresh: (2.6575775146484375, 2.907118558883667)\n",
      "Epoch: 7 Train Loss: 0.0755 Validation Loss: 0.0499 Train Accuracy: 58.5983% Val Accuracy: 63.5429% LR: 0.0099 LR_th: 0.0010 Spike Thresh: (2.6210405826568604, 2.977963924407959)\n",
      "Epoch: 8 Train Loss: 0.0788 Validation Loss: 0.0555 Train Accuracy: 63.2500% Val Accuracy: 55.5143% LR: 0.0099 LR_th: 0.0010 Spike Thresh: (2.6394829750061035, 2.9395217895507812)\n",
      "Epoch: 9 Train Loss: 0.0721 Validation Loss: 0.0986 Train Accuracy: 69.1950% Val Accuracy: 51.8000% LR: 0.0099 LR_th: 0.0010 Spike Thresh: (2.708557367324829, 2.9373619556427)\n",
      "Epoch: 10 Train Loss: 0.0777 Validation Loss: 0.0343 Train Accuracy: 66.5833% Val Accuracy: 78.5857% LR: 0.0099 LR_th: 0.0010 Spike Thresh: (2.7154247760772705, 3.005988359451294)\n",
      "Epoch: 11 Train Loss: 0.0558 Validation Loss: 0.0242 Train Accuracy: 81.1117% Val Accuracy: 87.3143% LR: 0.0099 LR_th: 0.0010 Spike Thresh: (2.783661365509033, 3.053450107574463)\n",
      "\n",
      "Maximum Validation Accuracy of 0.8731% at epoch 11\n",
      "Model Saved\n",
      "\n",
      "Epoch: 12 Train Loss: 0.0512 Validation Loss: 0.0222 Train Accuracy: 86.6317% Val Accuracy: 85.8000% LR: 0.0099 LR_th: 0.0010 Spike Thresh: (2.9133405685424805, 3.162252187728882)\n",
      "Epoch: 13 Train Loss: 0.0510 Validation Loss: 0.0199 Train Accuracy: 87.8967% Val Accuracy: 87.9286% LR: 0.0099 LR_th: 0.0010 Spike Thresh: (3.0510780811309814, 3.337003231048584)\n",
      "\n",
      "Maximum Validation Accuracy of 0.8793% at epoch 13\n",
      "Model Saved\n",
      "\n",
      "Epoch: 14 Train Loss: 0.0485 Validation Loss: 0.0197 Train Accuracy: 89.4767% Val Accuracy: 88.3000% LR: 0.0099 LR_th: 0.0010 Spike Thresh: (3.0788333415985107, 3.5500900745391846)\n",
      "\n",
      "Maximum Validation Accuracy of 0.8830% at epoch 14\n",
      "Model Saved\n",
      "\n",
      "Epoch: 15 Train Loss: 0.0521 Validation Loss: 0.0292 Train Accuracy: 87.5650% Val Accuracy: 82.3143% LR: 0.0099 LR_th: 0.0010 Spike Thresh: (3.162379026412964, 3.868204355239868)\n",
      "Epoch: 16 Train Loss: 0.0711 Validation Loss: 0.0358 Train Accuracy: 77.2983% Val Accuracy: 75.7857% LR: 0.0098 LR_th: 0.0010 Spike Thresh: (3.18898344039917, 3.9117507934570312)\n",
      "Epoch: 17 Train Loss: 0.0875 Validation Loss: 0.0520 Train Accuracy: 68.9117% Val Accuracy: 70.9143% LR: 0.0098 LR_th: 0.0010 Spike Thresh: (3.210498809814453, 3.9725441932678223)\n",
      "Epoch: 18 Train Loss: 0.0839 Validation Loss: 0.0317 Train Accuracy: 72.1467% Val Accuracy: 79.2714% LR: 0.0098 LR_th: 0.0010 Spike Thresh: (3.1996021270751953, 3.960334300994873)\n",
      "Epoch: 19 Train Loss: 0.0712 Validation Loss: 0.0288 Train Accuracy: 81.1133% Val Accuracy: 85.6286% LR: 0.0098 LR_th: 0.0010 Spike Thresh: (3.2082605361938477, 3.938631057739258)\n",
      "Epoch: 20 Train Loss: 0.0704 Validation Loss: 0.0334 Train Accuracy: 81.0967% Val Accuracy: 78.4571% LR: 0.0098 LR_th: 0.0010 Spike Thresh: (3.2160274982452393, 3.9442999362945557)\n",
      "Epoch: 21 Train Loss: 0.0721 Validation Loss: 0.0253 Train Accuracy: 80.9067% Val Accuracy: 85.7857% LR: 0.0098 LR_th: 0.0010 Spike Thresh: (3.268038034439087, 3.9535858631134033)\n",
      "Epoch: 22 Train Loss: 0.0704 Validation Loss: 0.0368 Train Accuracy: 82.3700% Val Accuracy: 76.7571% LR: 0.0098 LR_th: 0.0010 Spike Thresh: (3.2859835624694824, 3.93440318107605)\n",
      "Epoch: 23 Train Loss: 0.0692 Validation Loss: 0.0226 Train Accuracy: 83.4717% Val Accuracy: 86.8286% LR: 0.0098 LR_th: 0.0010 Spike Thresh: (3.2880752086639404, 3.940753936767578)\n",
      "Epoch: 24 Train Loss: 0.0683 Validation Loss: 0.0360 Train Accuracy: 84.5533% Val Accuracy: 81.0286% LR: 0.0098 LR_th: 0.0010 Spike Thresh: (3.257343292236328, 3.954806089401245)\n",
      "Epoch: 25 Train Loss: 0.0752 Validation Loss: 0.0392 Train Accuracy: 81.1117% Val Accuracy: 71.7429% LR: 0.0098 LR_th: 0.0010 Spike Thresh: (3.3629117012023926, 4.020260334014893)\n",
      "Epoch: 26 Train Loss: 0.0704 Validation Loss: 0.0176 Train Accuracy: 82.5783% Val Accuracy: 90.1286% LR: 0.0097 LR_th: 0.0010 Spike Thresh: (3.369002342224121, 4.009576320648193)\n",
      "\n",
      "Maximum Validation Accuracy of 0.9013% at epoch 26\n",
      "Model Saved\n",
      "\n",
      "Epoch: 27 Train Loss: 0.0615 Validation Loss: 0.0155 Train Accuracy: 89.8900% Val Accuracy: 91.0571% LR: 0.0097 LR_th: 0.0010 Spike Thresh: (3.375980854034424, 4.0112457275390625)\n",
      "\n",
      "Maximum Validation Accuracy of 0.9106% at epoch 27\n",
      "Model Saved\n",
      "\n",
      "Epoch: 28 Train Loss: 0.0612 Validation Loss: 0.0161 Train Accuracy: 90.0933% Val Accuracy: 91.1000% LR: 0.0097 LR_th: 0.0010 Spike Thresh: (3.3903884887695312, 4.0236992835998535)\n",
      "\n",
      "Maximum Validation Accuracy of 0.9110% at epoch 28\n",
      "Model Saved\n",
      "\n",
      "Epoch: 29 Train Loss: 0.0613 Validation Loss: 0.0182 Train Accuracy: 90.0200% Val Accuracy: 90.4857% LR: 0.0097 LR_th: 0.0010 Spike Thresh: (3.3739686012268066, 4.030543327331543)\n",
      "Epoch: 30 Train Loss: 0.0612 Validation Loss: 0.0159 Train Accuracy: 90.7083% Val Accuracy: 91.5571% LR: 0.0097 LR_th: 0.0010 Spike Thresh: (3.4176368713378906, 4.088149070739746)\n",
      "\n",
      "Maximum Validation Accuracy of 0.9156% at epoch 30\n",
      "Model Saved\n",
      "\n",
      "Epoch: 31 Train Loss: 0.0589 Validation Loss: 0.0141 Train Accuracy: 91.9367% Val Accuracy: 91.9143% LR: 0.0097 LR_th: 0.0010 Spike Thresh: (3.484447479248047, 4.091681480407715)\n",
      "\n",
      "Maximum Validation Accuracy of 0.9191% at epoch 31\n",
      "Model Saved\n",
      "\n",
      "Epoch: 32 Train Loss: 0.0605 Validation Loss: 0.0148 Train Accuracy: 91.3000% Val Accuracy: 92.0429% LR: 0.0097 LR_th: 0.0010 Spike Thresh: (3.63273549079895, 4.057279586791992)\n",
      "\n",
      "Maximum Validation Accuracy of 0.9204% at epoch 32\n",
      "Model Saved\n",
      "\n",
      "Epoch: 33 Train Loss: 0.0620 Validation Loss: 0.0157 Train Accuracy: 91.1017% Val Accuracy: 90.9429% LR: 0.0097 LR_th: 0.0010 Spike Thresh: (3.7070062160491943, 4.048116683959961)\n",
      "Epoch: 34 Train Loss: 0.0638 Validation Loss: 0.0161 Train Accuracy: 90.6750% Val Accuracy: 90.4714% LR: 0.0097 LR_th: 0.0010 Spike Thresh: (3.746410608291626, 4.009742736816406)\n",
      "Epoch: 35 Train Loss: 0.0662 Validation Loss: 0.0194 Train Accuracy: 90.7000% Val Accuracy: 88.6857% LR: 0.0097 LR_th: 0.0010 Spike Thresh: (3.765214204788208, 4.046492576599121)\n",
      "Epoch: 36 Train Loss: 0.0678 Validation Loss: 0.0153 Train Accuracy: 90.7333% Val Accuracy: 91.3714% LR: 0.0097 LR_th: 0.0010 Spike Thresh: (3.8718936443328857, 4.042509078979492)\n",
      "Epoch: 37 Train Loss: 0.0695 Validation Loss: 0.0166 Train Accuracy: 90.7183% Val Accuracy: 91.0000% LR: 0.0096 LR_th: 0.0010 Spike Thresh: (3.885895252227783, 4.011817932128906)\n",
      "Epoch: 38 Train Loss: 0.0744 Validation Loss: 0.0200 Train Accuracy: 89.0017% Val Accuracy: 88.8286% LR: 0.0096 LR_th: 0.0010 Spike Thresh: (3.962158679962158, 4.0150299072265625)\n",
      "Epoch: 39 Train Loss: 0.0767 Validation Loss: 0.0160 Train Accuracy: 88.6767% Val Accuracy: 90.8286% LR: 0.0096 LR_th: 0.0010 Spike Thresh: (3.931729316711426, 4.01445198059082)\n",
      "Epoch: 40 Train Loss: 0.0738 Validation Loss: 0.0165 Train Accuracy: 90.7633% Val Accuracy: 90.7286% LR: 0.0096 LR_th: 0.0010 Spike Thresh: (3.9496910572052, 4.001015663146973)\n",
      "Epoch: 41 Train Loss: 0.0811 Validation Loss: 0.0170 Train Accuracy: 87.6833% Val Accuracy: 91.0143% LR: 0.0096 LR_th: 0.0010 Spike Thresh: (3.9521291255950928, 4.00405216217041)\n",
      "Epoch: 42 Train Loss: 0.0837 Validation Loss: 0.0243 Train Accuracy: 86.7617% Val Accuracy: 86.5714% LR: 0.0096 LR_th: 0.0010 Spike Thresh: (3.917278528213501, 3.9625022411346436)\n",
      "Epoch: 43 Train Loss: 0.0859 Validation Loss: 0.0204 Train Accuracy: 86.0533% Val Accuracy: 89.1000% LR: 0.0096 LR_th: 0.0010 Spike Thresh: (3.9615750312805176, 4.000368595123291)\n",
      "Epoch: 44 Train Loss: 0.0836 Validation Loss: 0.0197 Train Accuracy: 87.7333% Val Accuracy: 88.6714% LR: 0.0096 LR_th: 0.0010 Spike Thresh: (3.928823709487915, 4.0042290687561035)\n",
      "Epoch: 45 Train Loss: 0.0801 Validation Loss: 0.0165 Train Accuracy: 89.9200% Val Accuracy: 90.9714% LR: 0.0096 LR_th: 0.0010 Spike Thresh: (3.927466630935669, 4.003915309906006)\n",
      "Epoch: 46 Train Loss: 0.0827 Validation Loss: 0.0279 Train Accuracy: 89.0883% Val Accuracy: 82.9429% LR: 0.0096 LR_th: 0.0010 Spike Thresh: (3.947328567504883, 3.9855403900146484)\n",
      "Epoch: 47 Train Loss: 0.0950 Validation Loss: 0.0276 Train Accuracy: 82.5267% Val Accuracy: 84.4143% LR: 0.0096 LR_th: 0.0010 Spike Thresh: (3.886850118637085, 3.957441568374634)\n",
      "Epoch: 48 Train Loss: 0.0923 Validation Loss: 0.0376 Train Accuracy: 83.2567% Val Accuracy: 72.8571% LR: 0.0095 LR_th: 0.0010 Spike Thresh: (3.909088373184204, 3.982393980026245)\n",
      "Epoch: 49 Train Loss: 0.0959 Validation Loss: 0.0237 Train Accuracy: 82.0400% Val Accuracy: 87.0000% LR: 0.0095 LR_th: 0.0010 Spike Thresh: (3.8798224925994873, 4.013476848602295)\n",
      "Total training time: 1151.6557\n"
     ]
    }
   ],
   "source": [
    "trainBSNN = SNN_model_thLR(in_channels=28*28, hidden_neurons= args['hidden_neurons'], out_channels=args['num_classes'], init_th_1=args['v_thresh_1'], init_th_2=args['v_thresh_2'])\n",
    "trainBSNN.to(args['device'])\n",
    "\n",
    "v_thresh1 = None\n",
    "v_thresh2 = None\n",
    "\n",
    "\n",
    "optimizer = torch.optim.AdamW([\n",
    "    {'params': [trainBSNN.v_threshold1, trainBSNN.v_threshold2], 'lr': args['lr_threshold'], 'weight_decay': 0},  # No weight decay for thresholds\n",
    "    {'params': [param for name, param in trainBSNN.named_parameters() if 'v_threshold' not in name], 'lr': args['lr'], 'weight_decay': args['weight_decay']}  # Apply weight decay for other parameters\n",
    "])\n",
    "\n",
    "# Use the custom lr scheduler\n",
    "lr_lambda = get_lr_lambda(base_lr=args['lr'], factor=args['lr_decay'])\n",
    "scheduler = lr_scheduler.LambdaLR(optimizer, lr_lambda)\n",
    "\n",
    "lr_lambda_spTh = get_lr_lambda_spTh(base_lr_Th=args['lr_threshold'], factor=args['lr_th_decay'])\n",
    "scheduler_spTh = lr_scheduler.LambdaLR(optimizer, lr_lambda_spTh)\n",
    "\n",
    "  \n",
    "\n",
    "start_time = time.time()\n",
    "\n",
    "# Initialize lists to track spike and potential activity\n",
    "spike_list_layer1 = []\n",
    "v_list_layer1 = []\n",
    "spike_list_layer2 = []\n",
    "v_list_layer2 = []\n",
    "\n",
    "loss_train_arr = []\n",
    "loss_valid_arr = []\n",
    "\n",
    "loss_min = np.inf\n",
    "acc_max = -np.inf\n",
    "\n",
    "thresh_1 = 0.0\n",
    "thresh_2 = 0.0\n",
    "\n",
    "for epoch in range(args['start_epoch'], args['epochs']):\n",
    "\n",
    "    trainBSNN.train()\n",
    "\n",
    "    train_acc = 0\n",
    "    val_acc = 0\n",
    "    loss_train = 0\n",
    "    loss_valid = 0\n",
    "    train_samples = 0\n",
    "    val_samples = 0\n",
    "    running_train_loss = 0\n",
    "    running_eval_loss = 0\n",
    "    \n",
    "    encoder_train = encoding.PoissonEncoder()\n",
    "    encoder_test = encoding.PoissonEncoder()\n",
    "\n",
    "    for train_batch_idx, (img, label) in enumerate(train_loader):\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "        \n",
    "        label.apply_(label_map.get)\n",
    "        \n",
    "        img = img.to(args['device'])\n",
    "        label = label.to(args['device'])\n",
    "        label_onehot = F.one_hot(label, args['num_classes']).float()\n",
    "\n",
    "        out_fr = 0.\n",
    "\n",
    "        for t in range(args['T']):\n",
    "            encoded_img = encoder_train(img) #encoder_train(img) #thresholded_image_encoding_device(img, torch.tensor([0.5], dtype=torch.float32)) # \n",
    "            x = torch.flatten(encoded_img, start_dim=1)  # Flatten input image\n",
    "            out_fr += trainBSNN(x)\n",
    "\n",
    "\n",
    "        out_fr = out_fr / args['T']\n",
    "        train_loss_step = F.mse_loss(out_fr, label_onehot)  # MSE Loss\n",
    "\n",
    "        # Accumulate the L2 regularization for parameters except the thresholds\n",
    "        l2_reg = 0\n",
    "        for name, param in trainBSNN.named_parameters():\n",
    "            if 'v_threshold' not in name:\n",
    "                l2_reg += torch.norm(param, 2)  # L2 regularization term\n",
    "\n",
    "        # Add L2 regularization to the loss\n",
    "        total_loss = train_loss_step + args['alpha_l2'] * l2_reg\n",
    "\n",
    "        loss_train += float(total_loss)\n",
    "        total_loss.backward()\n",
    "        \n",
    "        optimizer.step()\n",
    "\n",
    "        # Clamp thresholds to ensure they are positive # No need to do in case of ternary weight quantisation\n",
    "        with torch.no_grad():\n",
    "            trainBSNN.v_threshold1.clamp_(min=0)\n",
    "            trainBSNN.v_threshold2.clamp_(min=0)\n",
    "\n",
    "        train_samples += label.numel()\n",
    "        train_acc += (out_fr.argmax(1) == label).float().sum().item()\n",
    "\n",
    "        # Reset the network's state (clear memory in neurons)\n",
    "        functional.reset_net(trainBSNN)\n",
    "\n",
    "        running_train_loss += float(total_loss.item())\n",
    "\n",
    "    lr_th_print = optimizer.param_groups[0][\"lr\"]\n",
    "    lr_print = optimizer.param_groups[1][\"lr\"]\n",
    "\n",
    "    # Step the scheduler\n",
    "    scheduler_spTh.step()  # Slower decay rate for thresholds\n",
    "    scheduler.step()  # Regular decay rate for other parameters\n",
    "\n",
    "    # Evaluation loop\n",
    "    trainBSNN.eval()\n",
    "    with torch.no_grad():\n",
    "\n",
    "        for eval_batch_idx, (img, label) in enumerate(val_loader):\n",
    "            \n",
    "            label.apply_(label_map.get)\n",
    "            \n",
    "            img = img.to(args['device'])\n",
    "            label = label.to(args['device'])\n",
    "            label_onehot = F.one_hot(label, args['num_classes']).float()\n",
    "\n",
    "            out_fr_eval = 0.\n",
    "\n",
    "            for t in range(args['T']):\n",
    "                # Choose either Poisson rate coding or threshold binarized coding\n",
    "                encoded_img = encoder_test(img) #thresholded_image_encoding_device(img, torch.tensor([0.5], dtype=torch.float32)) \n",
    "                x = torch.flatten(encoded_img, start_dim=1)  # Flatten input image\n",
    "                out_fr_eval += trainBSNN(x)\n",
    "\n",
    "            out_fr_eval = out_fr_eval / args['T']\n",
    "            validation_loss_step = F.mse_loss(out_fr_eval, label_onehot)  # MSE Loss for validation\n",
    "            loss_valid += float(validation_loss_step)\n",
    "            \n",
    "            val_samples += label.numel()\n",
    "            val_acc += (out_fr_eval.argmax(1) == label).float().sum().item()\n",
    "\n",
    "            # Reset the network's state (clear memory in neurons)\n",
    "            functional.reset_net(trainBSNN)\n",
    "            \n",
    "            running_eval_loss += float(validation_loss_step.item())\n",
    "\n",
    "    loss_train /= len(train_loader)\n",
    "    loss_valid /= len(val_loader)\n",
    "\n",
    "    loss_train_arr.append(loss_train)\n",
    "    loss_valid_arr.append(loss_valid)\n",
    "\n",
    "    print('Epoch: {} Train Loss: {:.4f} Validation Loss: {:.4f} Train Accuracy: {:.4f}% Val Accuracy: {:.4f}% LR: {:.4f} LR_th: {:.4f} Spike Thresh: {}'.format(\n",
    "        epoch, loss_train, loss_valid, train_acc/train_samples*100, val_acc/val_samples*100, lr_print, lr_th_print, (trainBSNN.v_threshold1.item(), trainBSNN.v_threshold2.item())))\n",
    "\n",
    "    chckpt_pwd = 'final_exps/'\n",
    "    chckpt_file_name = 'chckpt_bin_BIN-ENC_=_{}_classes={}_numNeur={}_epoch_{}.pth'.format((trainBSNN.v_threshold1.item(), trainBSNN.v_threshold2.item()), label_list, args['hidden_neurons'], epoch)\n",
    "    chckpt_file_path = chckpt_pwd + chckpt_file_name\n",
    "\n",
    "    # Save model checkpoint if validation accuracy improves\n",
    "    if acc_max < val_acc / val_samples:\n",
    "        acc_max = val_acc / val_samples\n",
    "        torch.save(trainBSNN.state_dict(), chckpt_file_path)\n",
    "        thresh_1 = trainBSNN.v_threshold1.item()\n",
    "        thresh_2 = trainBSNN.v_threshold2.item()\n",
    "        print(\"\\nMaximum Validation Accuracy of {:.4f}% at epoch {}\".format(acc_max, epoch))\n",
    "        print(\"Model Saved\\n\")\n",
    "\n",
    "end_time = time.time()\n",
    "\n",
    "# Save args to YAML file\n",
    "chckpt_pwd = 'final_exps/'\n",
    "yaml_file_name = 'args_{}_{}_{}'.format(args['hidden_neurons'], label_list, (thresh_1, thresh_2))\n",
    "with open(chckpt_pwd+yaml_file_name+'.yaml', \"w\") as file:\n",
    "    yaml.dump(args, file)\n",
    "\n",
    "print('Total training time: {:.4f}'.format(end_time-start_time))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load pre-trained model for testing and validating"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load best model weights from checkpoint file\n",
    "\n",
    "weights_checkpoint = 'chckpt_BIN-ENC_=_(2.614844799041748, 4.203311920166016)_classes=[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]_numNeur=128_epoch_6.pth' #'Full_0_1/chckpt_MSE_NIPS_3digits_0_1_full_8_epoch_33.pth'\n",
    "\n",
    "best_snnNet1 = SNN_model_thLR(in_channels=28*28, out_channels=args['num_classes'], hidden_neurons=args['hidden_neurons'])\n",
    "\n",
    "best_snnNet1.to('cpu')\n",
    "# Load the state dict\n",
    "state_dict = torch.load(weights_checkpoint, map_location='cpu')\n",
    "\n",
    "\n",
    "state_dict.pop(\"neuron1.v_threshold\", None)\n",
    "state_dict.pop(\"neuron2.v_threshold\", None)\n",
    "\n",
    "# Load the modified state dict into the model\n",
    "best_snnNet1.load_state_dict(state_dict)\n",
    "\n",
    "\n",
    "best_snnNet1.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# TEST SET ACCURACY\n",
    "\n",
    "encoder_test = encoding.PoissonEncoder()\n",
    "best_snnNet= best_snnNet1\n",
    "best_snnNet.eval()\n",
    "\n",
    "test_samples = 0.\n",
    "test_acc = 0.\n",
    "\n",
    "with torch.no_grad():\n",
    "\n",
    "    for test_batch_idx, (img, label) in enumerate(test_loader):\n",
    "        \n",
    "        label.apply_(label_map.get)\n",
    "        \n",
    "        img = img.to('cpu')\n",
    "        label = label.to('cpu')\n",
    "\n",
    "        out_fr = 0.\n",
    "\n",
    "        for t in range(args['T']):\n",
    "            encoded_img = encoder_test(img) #thresholded_image_encoding_device(img, torch.tensor([0.5], dtype=torch.float32)) \n",
    "            x = torch.flatten(encoded_img, start_dim=1)\n",
    "            out_fr += best_snnNet(x)\n",
    "\n",
    "        out_fr = out_fr / args['T']\n",
    "\n",
    "        test_samples += label.numel()\n",
    "        \n",
    "        test_acc += (out_fr.argmax(1) == label).float().sum().item()\n",
    "        \n",
    "        # After optimizing the parameters, the state of the network should be reset because the neurons of the SNN have “memory”.\n",
    "        functional.reset_net(best_snnNet)\n",
    "\n",
    "print(\"Test accuracy: {:.4f}%\".format(test_acc/test_samples*100))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# VALIDATION SET ACCURACY\n",
    "\n",
    "encoder_val = encoding.PoissonEncoder()\n",
    "\n",
    "best_snnNet.eval()\n",
    "\n",
    "val_samples = 0.\n",
    "val_acc = 0.\n",
    "\n",
    "with torch.no_grad():\n",
    "\n",
    "    for val_batch_idx, (img, label) in enumerate(val_loader):\n",
    "        \n",
    "        label.apply_(label_map.get)\n",
    "        \n",
    "        img = img.to('cpu')\n",
    "        label = label.to('cpu')\n",
    "\n",
    "        out_fr = 0.\n",
    "\n",
    "        for t in range(args['T']):\n",
    "            encoded_img = encoder_val(img) #thresholded_image_encoding_device(img, torch.tensor([0.5], dtype=torch.float32)) \n",
    "            x = torch.flatten(encoded_img, start_dim=1)\n",
    "            out_fr += best_snnNet(x)\n",
    "\n",
    "        out_fr = out_fr / args['T']\n",
    "\n",
    "        val_samples += label.numel()\n",
    "        \n",
    "        val_acc += (out_fr.argmax(1) == label).float().sum().item()\n",
    "        \n",
    "        # After optimizing the parameters, the state of the network should be reset because the neurons of the SNN have “memory”.\n",
    "        functional.reset_net(best_snnNet)\n",
    "        \n",
    "print(\"Validation accuracy: {:.4f}%\".format(val_acc/val_samples*100))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.10.15"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
