{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../..')\n",
    "\n",
    "from AbstractModels.SpikingConvolutionNetwork import SpikingConvolutionNetwork\n",
    "from AbstractModels.util.decode import decode_mean\n",
    "\n",
    "from SNN.Encoders import IdentityEncoder\n",
    "from SNN.models.classification import ITQIFVGG11, ITLIFVGG11\n",
    "\n",
    "from Datasets.NCaltech101 import NCaltech101\n",
    "\n",
    "import torch\n",
    "\n",
    "from torchvision.transforms import v2 as transforms\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from SNN.util.energy_consumption import approximate_energy_consumption"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [],
   "source": [
    "seed = 42\n",
    "\n",
    "torch.manual_seed(seed)\n",
    "torch.cuda.manual_seed(seed)\n",
    "torch.cuda.manual_seed_all(seed)\n",
    "np.random.seed(seed)\n",
    "torch.backends.cudnn.deterministic = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "model1 = SpikingConvolutionNetwork(\n",
    "    encoder=IdentityEncoder(),\n",
    "    snn=ITQIFVGG11(num_classes=101, method='asym_rectangle'),\n",
    "    decoder=decode_mean,\n",
    "    seq_length=10,\n",
    "    input_scale=1.0\n",
    ")\n",
    "\n",
    "model2 = SpikingConvolutionNetwork(\n",
    "    encoder=IdentityEncoder(),\n",
    "    snn=ITLIFVGG11(num_classes=101, method='asym_rectangle'),\n",
    "    decoder=decode_mean,\n",
    "    seq_length=10,\n",
    "    input_scale=1.0\n",
    ")\n",
    "\n",
    "dataset = NCaltech101(\n",
    "    root='../../data/',\n",
    "    train=False,\n",
    "    download=True,\n",
    "    transform=transforms.Compose([\n",
    "        torch.as_tensor,\n",
    "        transforms.Resize((48, 48)),\n",
    "        transforms.ToImage(),\n",
    "        transforms.ToDtype(torch.float, scale=True)\n",
    "    ])\n",
    ")\n",
    "\n",
    "dataloader = torch.utils.data.DataLoader(\n",
    "    dataset,\n",
    "    batch_size=16,\n",
    "    shuffle=True\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "DIR = '../../SNN/output/NCaltech101/'\n",
    "\n",
    "LIF_weights = 'LIFVGG11_NCaltech101_NDA_LOW_200_(2024-09-02)_(22-24-07)'\n",
    "\n",
    "QLIF_weights = [\n",
    "    'QLIFVGG11_NCaltech101_NDA_LOW_200_(2024-08-29)_(22-26-41)',\n",
    "    'QLIFVGG11_NCaltech101_NDA_LOW_200_(2024-08-30)_(23-05-01)',\n",
    "    'QLIFVGG11_NCaltech101_NDA_LOW_200_(2024-08-31)_(00-24-42)'\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_spike_rate(model: SpikingConvolutionNetwork, dataloader, device) -> list:\n",
    "    model.to(device)\n",
    "    model.eval()\n",
    "\n",
    "    for data, _ in dataloader:\n",
    "        data = data.float().to(device)\n",
    "        model(data)\n",
    "    return np.array(model.spike_rate())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ejahns/Documents/discretized-qif-neuron-model-archive/src/Graphs/SpikeRateEnergyConsumption/../../AbstractModels/ConvolutionModel.py:585: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  checkpoint = torch.load(f\"{path}.pth\", map_location=self.DEVICE)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded from ../../SNN/output/NCaltech101/LIFVGG11_NCaltech101_NDA_LOW_200_(2024-09-02)_(22-24-07)/LIFVGG11_NCaltech101_NDA_LOW_200_(2024-09-02)_(22-24-07).pth\n"
     ]
    }
   ],
   "source": [
    "model1.load_by_path(f'{DIR}{LIF_weights}/{LIF_weights}', None, None)\n",
    "lif_spike_rate = get_spike_rate(model1, dataloader, device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded from ../../SNN/output/NCaltech101/QLIFVGG11_NCaltech101_NDA_LOW_200_(2024-08-29)_(22-26-41)/QLIFVGG11_NCaltech101_NDA_LOW_200_(2024-08-29)_(22-26-41).pth\n",
      "Loaded from ../../SNN/output/NCaltech101/QLIFVGG11_NCaltech101_NDA_LOW_200_(2024-08-30)_(23-05-01)/QLIFVGG11_NCaltech101_NDA_LOW_200_(2024-08-30)_(23-05-01).pth\n",
      "Loaded from ../../SNN/output/NCaltech101/QLIFVGG11_NCaltech101_NDA_LOW_200_(2024-08-31)_(00-24-42)/QLIFVGG11_NCaltech101_NDA_LOW_200_(2024-08-31)_(00-24-42).pth\n"
     ]
    }
   ],
   "source": [
    "qlif_spike_rates = []\n",
    "for weight in QLIF_weights:\n",
    "    model2.load_by_path(f'{DIR}{weight}/{weight}', None, None)\n",
    "    qlif_spike_rates.append(get_spike_rate(model2, dataloader, device))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [],
   "source": [
    "qlif_spike_rate = np.mean(qlif_spike_rates, axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "def difference_percentage(x: float, y: float) -> float:\n",
    "    return (x - y) / x * 100\n",
    "\n",
    "def times_greater(x: float, y: float) -> float:\n",
    "    return x / y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Spike Rate of LIF: 0.17346146138344232\n",
      "Mean Spike Rate of QLIF: 0.08637040578430907\n",
      "QLIF spikes 50.207726203006885% less than LIF\n"
     ]
    }
   ],
   "source": [
    "lif_mean_spike_rate = np.mean(lif_spike_rate)\n",
    "qlif_mean_spike_rate = np.mean(qlif_spike_rate)\n",
    "\n",
    "print(f'Mean Spike Rate of LIF: {lif_mean_spike_rate}')\n",
    "print(f'Mean Spike Rate of QLIF: {qlif_mean_spike_rate}')\n",
    "# What percentage less does qlif spike less than lif\n",
    "print(f'QLIF spikes {difference_percentage(lif_mean_spike_rate, qlif_mean_spike_rate)}% less than LIF')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LIF energy: 0.7884076736028235 mJ\n",
      "QLIF energy: 0.37398225382692446 mJ\n",
      "Times Difference: 2.108141938648488x\n"
     ]
    }
   ],
   "source": [
    "lif_energy = approximate_energy_consumption(model1, dataloader, 10, lif_spike_rate)\n",
    "qlif_energy = approximate_energy_consumption(model2, dataloader, 10, qlif_spike_rate)\n",
    "\n",
    "percent_diff = times_greater(lif_energy, qlif_energy)\n",
    "\n",
    "print(f'LIF energy: {lif_energy} mJ')\n",
    "print(f'QLIF energy: {qlif_energy} mJ')\n",
    "print(f'Times Difference: {percent_diff}x')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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be6nQYMG2XrNkXp4BMMwjIkTJ5q/z5kzx+o2Keuz89X7AQMGmPv5+uuvHd5PitTXYVu3/PnzG4sXL7a5D1vDI9hzroeGhqbb3+zZsw1/f/8Mt3vuuecy/L9szz6sDT+Q+nqxePFiI3/+/Fa39fT0NObNm2fvw5wlWR0eoXz58oYk4+67786w3Zw5c8z6p06date+GR4BQG4htAUAJ7p48aI5Nma9evUybHvfffcZkowCBQqke4P0xx9/mC8GH3vsMafVV6dOHXO/Z86ccdp+s+N2CG2vX79uhui9evUylycnJ5tvCtq3b59uuwsXLphBQkRERIbHSHlDXrhw4XRj8B08eNAIDAw0pJvjsg0ZMsRYsmSJ8fvvvxs//vij0bdvXzNwadiwoXH9+vV0+095s1OtWjXD09PTCA4ONj799FPjt99+MzZt2mSMGTMmzfF8fHyMNm3aGB9//LGxZs0aY+fOncaaNWuMzz//3Khevbr5WA8fPtzmY5ZyjksyWrdubSxdutT4/fffjaVLlxqPPfaYWW9Gb3zOnTtnPsa+vr5Gv379jAULFhjbt2831q1bZwwZMsR881ipUiXj4sWLGT7O1qQOm4oXL27s3r07y/u4dT/169c3JBlhYWHmc7VkyRLj4YcfNtvUq1cvXaBqGI6Htjdu3DDCw8PNbfv3759uHElnnEv2sPfv8a677jLbnT9/Pt367JyL169fN6KiooypU6emeUMeFRWV5nbhwgVzm+TkZKN169Zm+zZt2hizZs0yNm/ebGzZssX46KOPjKCgIEOS4ePj4/B41vZe91J/uDdq1Kg0j0tuXhPskd3QtlGjRkaNGjWMN99801iyZImxdetW47fffjPmz59vdOrUyfDw8DADmJQPzlLr3LmzId38YC0+Pt7mcT788EOzzh07dqRZd+3aNfP/pKenp9GtWzdj7ty5xm+//WZs3LjReOedd8z/BYULFzZiYmLS7T8lqCtatKhRpkwZo0CBAsabb75prF+/3ti2bZvx9ddfG3///XeWHptnnnnGrLlmzZrGzJkzje3btxs//vijER4eblgsFkOSUaRIEePYsWPptk99vj344IOGh4eH0aNHD2PFihXGjh07jCVLlhgPPPCA2Wbw4MFZqs/a/U/527969apRpkwZ87mzds1zRmhbt25dcz/Z+cApxZtvvmmULl3aeOmll8xrwI4dO4ylS5car7/+ulGgQAFDkpEvXz7jzz//tLoPW6FtdHS0ERUVZT4uTz75ZLrrUnR0dJpt5s+fbz7PlSpVMiZMmGCsWrXK2LFjh7Fo0SLzf2rKtd+a1PMo5MuXz/jf//5n/PDDD8bOnTuNDRs2GJ9++qkRFhZmVKxYMd22KdeLOnXqGPny5TMqVqxoXi+2bNliREZGmq9/AwICcuQ1ZlZC28uXL5v39cknn8yw7c6dO822gwYNsqsWQlsAuYXQFgCcLPWbK1tvzPbs2WO26d69e7r1s2fPNtcPGzbMabWlvIkvV66c0/aZXbdDaLtkyRJz3z///HOadW+88YYZKFoLnZ566imbYWyKixcvmuHu888/n279gw8+aEgyateubZw9e9bqPlauXGmGGpMmTUq3PnWPvBo1aqQJqm4VFxdnnDhxwub65ORko2fPnoZ0s8ehtaA0dTDy6quvWt1Pv379zDa23vh06dLFfJN265vYFDt37jR7Dg0dOtRm3bYkJSWlCZgtFovRrFkz45133jHWrl1rdxCcOrSy9VwahmE899xzZpvPPvss3XpHQttr166l6YmXOuBLzRnnkj3s+XtctGiR2aZly5ZW2zjjXMzKRGQp35bw9vY2Vq5cabXN+fPnzbC4UaNGGe7PFnuue7GxsUbFihXNdhs2bDDX5fY1wR7ZDW0PHDiQ4fqffvrJvD9TpkxJt37t2rXm8b/55hub+0nptV+zZs1064YOHWpIMgoVKmT8/vvvVrePiYkxSpcubUgyunTpkm596tCyQIECDn8IlOL7779P83di7f9I6m/5PPPMM+nWpz7fJBmzZs1K1+batWvGvffeawbOGfXWzMitoa1hGMZnn31mLpsxY0a6bZwR2qb0ni5btqzD+0jt8OHDGX5odfToUaNs2bKGdLOnvzXOmojs7Nmz5oc0vXr1svncpJy/Hh4e6V5/njhxwvyAs0SJEkZUVJTN41mbjDP19aJu3brGpUuX0rVJ/dp1woQJGd4nR2QltP3rr7/MWqz1qE/t7NmzZttOnTrZVQuhLYDcQmgLAE6W+g3Wm2++abXNa6+9ZrZZs2ZNuvWpA6+MhllISkpK1zsj9S31G46LFy+a+6xdu3aG9+HIkSM293n69Gk7Hwn73A6hbUoYVq5cuXQ9F/fu3Wse94svvki3bepgytqwB4aRdhiFX375Jc26DRs2mOv++OOPDOtM+cDgwQcfTLcu9Ruu1OGPo/777z/D09PTkGQsXLgw3fqqVauaj9m1a9es7iM+Pt7saWTtjc/hw4fNYyxfvjzDel5//XVDuvkVYUccPHjQqFy5cppgI3WIW6NGDeP111/PcAiG1KFVyZIljStXrlhtd/nyZaN48eKGJKN69erp1mc1tL18+bL5dWeLxWJ8+umnVrdz1rlkD1t/jwkJCcZff/1lvPvuu2aAkD9/fuO3335z6DiGkfm5aG9om5ycbISEhBiSjIEDB2Z4zB9++MHcZ2ZhozUZXfcuXbpkrFixIs2QIPfff7+53l2vCdkNbe3Rtm1bQ7o5tMqtUj9/Dz30kNXtd+zYYfN/6+XLl81g7JNPPsmwjs8//9wM92/9pkzq0NLWhydZ8eijj5rHshampXjooYcMSYaXl1e6DzpSn29PPfWUzX18+eWXZrs9e/Y4VK+10DYhIcHsoR4SEpIudMxuaHvp0iW7X984U8prtYCAgHSvDQzDeaHtqFGjzEDa1v9TwzCMxMREM0i+9QPMIUOGZPpaJCOprxe2zo3k5GTzf3q7du2yfAx7a7AntN22bZtZ7xtvvJFh2/j4eLOttWuLNYS2AHILE5EBgJM98sgj5sQb33zzTboJqJKTkzVnzhxJUrly5dJMkpPi8uXL5s/+/v42jxUbG6saNWrYvB0/fjzL+5Skl19+2eY+P//88wy3zWvOnz9vTt7WpUuXdJPzVK9eXbVq1ZIkzZo1K932rVu3NmelTnneb5WyPCgoSE2aNEmzLmVilbvvvls1atTIsNamTZtKkrZv325zAqLy5cunO0ZmEhMTdezYMf3111/au3ev9u7dqxMnTqho0aKSbk5wl9rx48fNSds6dOggX19fq/v18/NThw4dbB53xYoVSkpKUv78+fXoo49mWGPKfT9x4oRDk8NUrlxZe/bs0Xvvvae77rorzTrDMBQVFaX33ntP1apV08CBAzOdqOuZZ55R/vz5ra4rUKCAOfHJvn37dOrUqSzXm+K///5Ty5YttXbtWnl5eWn27Nnq27ev1bbOPpfslXpyHV9fX91zzz0aOnSo4uPjVadOHa1evVoNGza0a19ZPRez4s8//9Q///wjSeYkg7akPD6StGXLFoePKUnh4eFpHqPAwEC1bt3avC8hISH69ttvzfbucE3IDWfPntXBgwfN53nv3r0qXry4JOvPs8ViUa9evSRJP//8s9XrwLRp0yRJPj4+evbZZ9Os++WXX3Tp0iVJ9j//iYmJ2rFjh812tx4jq27cuKFffvlFkhQWFqby5cvbbBsREWFuk9FEZxnVVLduXfPn6OjoLFZrm4+Pj4YNGyZJ+ueff2xO/ueorLy+cVRsbKwOHz6sffv2medjyjU+ZV1OSfmbf/zxx23+P5UkLy8vPfDAA5LSX5e+//57STcnzX3iiSccrqVGjRq67777rK6zWCyqXbu2JOeeP45IPcGgj49Phm1TP6bZmdQUAHKCl6sLAIC8xsvLS126dNHEiRMVExOjTZs2pXlDvHbtWnPm8WeffVYeHuk/PytYsKD585UrV5xSV07sU5IOHDig69evW11Xrlw5FSpUyGnHcoW5c+ea969r165W23Tt2lW7d+/Wr7/+qn/++UchISHmOl9fXz399NP6+uuvtXz5cl2+fDnNc3HixAnzDXbnzp3ThcK///67pJszNds7m3tiYqLOnz+vEiVKpFtn682WtX1MmjRJs2bN0q5du2w+x5J07ty5NL/v3bvX/Dl1CGBNvXr1bK5Lue/x8fHy8rL/JcupU6cUFBRkd/sU+fPn16BBgzRo0CD9888/+vXXX7Vjxw5t2bJFv//+u5KTk5WUlKQJEybo3LlzmjFjhs191a9fP8NjNWjQQJ999pkkKSoqSqVKlcpyvSdPnlTTpk31559/ys/PTwsWLFDr1q1ttnf2uZRdPj4+eu6559SoUaNMa3D0XMyKlMdHkhl82CM7obstFotFVatWVZcuXfTqq6+qQIEC5jpXXRNyw+bNm/Xxxx9rzZo1On/+vM12tp7nnj17avjw4UpKStKMGTP01ltvmesSEhLMD8iefPJJM+hPkfr5L126tN0123r+CxQooEqVKtm9H2uio6MVHx8vSZl+sJF6fepr8K2qVq1qc12RIkXMn1MHoc4QHh6usWPHKjo6Wm+//ba6d++eaZh25cqVDMPQe++9V1LOvb45cuSI3n//fS1fvlxHjhzJsO25c+ey/Xxbk5SUpN27d0uSvvrqK3311Vd2bZf6vExMTDTPicaNG9t93bAmo/NH+r9z6Nbz5+LFizp27JjVbXx8fNJ9WJpd+fLlM3/O6H+GdPPakMLPz8+pdQBAdtHTFgByQPfu3c2fb+19mfr31O1SS/1m8uzZszaPU6hQIRk3h7oxbz169LDaNjAw0Ay+MtqnJC1dujTNPtetW2ezbVhYmM1euUuXLs3wOLeDmTNnSroZbNjq1dalSxd5enqmaZ9aSs+mq1evavHixWnWzZs3T8nJyWnapXbmzBmH6k55o3+rwoULZ7rt+fPn9cADD6hfv37aunVrpm94bu2ZcuHCBfPnlJ5xtmS03tn3PStCQkLUrVs3ffjhh9q6dav+/fdf9e7d21w/c+ZMbdq0yeb2mYWcKb3xJWUYTmVk9erV+vPPPyVJI0eOzDCwlVz3eEZFRZm3DRs26NNPP1VISIiuX7+uvn37avz48Ta3ze65mBWuenzefvtt8/HZu3evoqOjFRsbqz///FPDhg1LE9jmRJ32XBNyQ2RkpBo3bqxvv/02078JW89zmTJl9Nhjj0mSpk+fnuabLt99952535Qeuak5+3F1xgeWqR+HzK4pqT/4yejxs/UNAElpPkROSkqyp0S7eXl5afjw4ZJuhqFff/11ptts3749w28TpQgICJC3t7ck6fTp006pd+XKlapWrZo+/fTTTANbKed6aJ4/f96hbzukPi/Pnz9v/i1k5QMJazI6f6T/O4duPX+WLl1q83kMCwvLVk3WpA7y4+LiMmybOui/9XoLAK5GT1sAyAG1atVSjRo1FBUVpQULFuiTTz6Rr6+vrly5YoZ2devWVbVq1axuX7NmTfPnXbt2Oa2u++67Tzt37tSxY8d07tw5FStWzGn7zov279+vbdu2SZL++OMPu3qnzJ49W5GRkWnahoaGqmzZsjp+/LjmzJmTJlhP6fl165vQFClvfGrWrKnZs2fbXXvZsmWtLk8JlzPyyiuvmF/5bdu2rXr16qX77rtPJUqUUL58+cz7FhQUpKNHj6YbAsRZUu57sWLFMvzg4FYVK1Z0ei1ly5bV5MmTFRcXp3nz5kmSFixYoMaNG1ttn52eTPZq1KiRDh06pNOnTysyMlINGzZM87X9Wzn7XLJXSm+4FE2aNFH37t3VuHFj/fHHHxo6dKiaNWtmtXdybp6LqUOG5cuXKzg42K7tstsLuWzZsukeo4y44pqQ09auXauRI0dKuvn17ddee02NGzdWUFCQ/P39zQ8chw8frtGjR2e4r969e2v58uWKjo7Whg0bFBoaKun/hkYoV66c1ZAo9fO/c+dOMwTMTLly5awud/bjmhvXlJzWtWtXvfvuuzpw4IDeeecd9erVK8Ov+2fFfffdpx07dujEiRM6ffp0mg/GsurcuXPq0qWL4uPjVaBAAb322mt65JFHFBISosDAQLOH8M8//6yWLVtKUo7/H5RuntuvvPKKXdtl1os5r0t9vbPVwzfF0aNHzZ8zGoIEAFyB0BYAckj37t01aNAgXbx4UcuXL9fTTz+tJUuWmJ/o2+plK90MOYoWLar//vtPGzduVHx8fKa9G+wRGhqqnTt3SpJWrVpl8+v+WRETE5Ptfbgra71mMxMdHZ1uSAwPDw917txZ77//vtauXWu+oTxw4IAZSNkaZzCl13VcXFyWgh1HxcbGav78+WZNGYVCqXvUppa6515mvbozWp9y3y9fvqx77rnHLcKliIgIM7Q9dOiQzXaZ9fZKvT71V5KzonLlyvrqq6/UvHlznT17Vq1bt9aqVatsDjeQ2+dSRgoWLKiZM2eqTp06unHjhgYOHKgNGzakaeOMczErUn/DoVChQi5/jGxxp+fRWSZPnizp5rXjt99+s9kD355e6a1bt1bp0qV18uRJTZs2TaGhoTp+/LhWr14tSerRo4fVYYlSP//Fixe3GcbmptTXhsyuKam/Du/oNSWneXp6asSIEXr22Wd1/PhxffnllxmGkM2aNbM7DA0NDTX/n65YscJqb2p7LVy4UBcvXpQkLVmyRA899JDVdo5+SyIrUj+XhmE49DdfpEgReXh4KDk5WSdPnnRmeXbr2bOnevbsmWvHK1iwoMqXL6+jR4+aY+zbknr9Pffck9OlAUCWMDwCAOSQZ5991gyZUsKGlKERvL291blzZ5vbWiwWM1CNjY3NcOzMrEgdFH/66ac51jMkLzAMw3ze7rvvPs2dOzfD25w5c8wx1DIaIiEpKckMor755htJN59vW+dD6kk9cmLszFsdPHhQiYmJkqSOHTvabPf333/b/Mph9erVzZ8zmqRHSjuO5K1S7ntCQkKG7XJTmTJlzJ8z6vm2ffv2DPeTen12grfq1atr7dq1KlasmOLi4vToo4/anBgrt8+lzNSsWVNdunSRJG3cuFGrVq1Ks94Z56Jkfw/FlMdHujm2qrtyt+fRGfbt2ydJat68eYZDpthzHfD09DTDoYULFyouLk4zZsxQcnKyLBaLwsPDrW7njs9/pUqVzA9st27dmmHblG+FSNm7puS0Tp06md8yGjt2rNOGFUgdCH7yySfmsEOOSDkfixQpYjOwlew7HzNiz7XJx8fH/J/q6Hnp7e1tnhMbN268Y177pXwTZv/+/RleK1Mm+5OU6RjrAJDbCG0BIIeULl3afLH/ww8/aO/evVq7dq0kqVWrVpmO9TlgwAAzBBwyZIhTZiauVauWHn30UUk33wBOnDgx2/vMq9avX2/OPt69e3d16tQpw1vnzp31yCOPSLr5tfnUMxdLNx/7lDeqKWHt3LlzJd38uritibNSZnk2DEMfffSR8+/oLVKPnZfRhC5ffvmlzXXlypUzJxVZsGBBmkk+Urt27ZoWLFhgcz9t2rQx39R++OGHGZWdLVl5A5v6TXpGk84sWLDAZhhx5coVffvtt5KkatWqZXuMwRo1amjNmjUqUqSILl++rFatWqUJcFLk9rlkjzfffNPs9fj222+nWeeMc1FKOyGNrXNRkurUqWP2rpw0aVK6v2F34Y7PY3alPNcZPc+7du3KNLhM8dxzz8lisejKlSuaP3++pk+fLklq2rRpmokiU3vooYfMgPTjjz92i2DLy8vLHN7hp59+yvBr3lOmTDG3adasWW6U5xAPDw9zKIxTp06ZEzJmV40aNcy/jd27d+vdd9+1e9tNmzaleY2Vcj5eu3bNZvgbHx+fbs6CrEq5NmV0XZL+72/+77//1o8//ujQsdq0aSNJOnz4sL777juH9nG7adu2rflzyjXgVvHx8Wn+Hzt7QjQAyC5CWwDIQSk9WxMTE9WpUydzbLKMhkZIERQUpI8//liSdOnSJTVu3DjDiY+km2/iU77SZ8vkyZPNwPi1117T6NGjM53cxxlfPb7dpO4t2759e7u2efrppyXdfL6svSlK6W27bds2zZ07VwcPHkyz3JqwsDA1aNBAkjR+/HjzzYUtUVFRWr58uV31WlO5cmUzKJ0xY4bV4GL58uX69NNPM9xPnz59JN0cS27w4MFW2wwaNEgnTpywuY+7775bHTp0kHRzwrYJEyZkeMzDhw+bQXhWTJ48Wc8//3yGwx1INyfPefPNN83fn3zySZttT506pYEDB1pdN2DAAHPSoxdffDHL9VpTs2ZNrVmzRoULF1ZsbKzCwsLS9QLL7XPJHlWrVtVTTz0l6WYvstRjFzvrXEwdiv/zzz8223l4eGjo0KGSbvZi7d69e4ZhSmxsbKbHzgnu+DxmV5UqVSTdDM+s/R2ePXtW3bp1s3t/ISEhZnA5bNgw81qb0VfmCxUqpH79+kmSfv31V/Xv3z/D3pqnT582g9Kc1LdvX0nS9evX9dxzz5m9z1ObOnWqOfzDU089le0PgnJa+/btzbH7x40b57T9fvXVV+ZYtm+99ZaGDx+e4eubK1euaOTIkWrRooUuXbpkLk85H1MHeqklJSWpd+/eGf7/skfK85TRdUm6ObZ3ygRZ4eHhZk9gW1asWKE//vgjzbJ+/frJ399f0s3/z3v37rW5fWZjwN4u2rVrZ364OmbMGKuP86BBg8zXuIMGDcrV+gDAHoxpCwA5qF27dipYsKAuX75svsguXLiw2eMhMxERETp+/LhGjhypEydOqEmTJmrRooXatGmjGjVqqEiRIkpKStKpU6e0c+dOffvtt+ZxPD09rU5EUbZsWX3//fd64okndPr0aQ0fPlxTpkxRp06d1KhRI5UsWVK+vr66ePGi9u/fr5UrV+r77783t8/u2LopX1dNkTqIvjWULlWqlFq1apVuH6dOnUr3VerUX327tUdF48aNVblyZbtrjI+P16JFiyTdnDDO3gmJ2rRpIx8fH12/fl0zZ85M95XuLl26aNiwYTIMQy+99JKkm199TAkmbZkzZ44aNGig8+fPq2PHjpo9e7Y6duyoKlWqyNPTU2fOnNGuXbu0fPly/fbbbxo4cKDd59itihYtqscee0wrVqzQqlWrFBYWphdffFEVKlTQmTNntGjRIk2fPl2VKlXSxYsXbY5J269fP02bNk179+7Vhx9+qEOHDikiIkLlypXTsWPHNGnSJK1YsUINGjQwe4Va+6roF198od9//13R0dEaOHCgvvvuO3Xv3l3Vq1eXr6+v/vvvP+3Zs0erVq3Szz//rHbt2mU49Ig1169f1+TJkzV58mQ1atRIYWFhqlu3rkqWLCkPDw8dP35c69at05QpU3T58mVJNwPblAlorKlXr56++OILHT58WC+88II5tt4XX3xh9pSqXbu2XnjhhSzVmpHatWvrp59+0kMPPaSLFy8qLCxMa9euTfO179w8l+w1dOhQLVy4UNLN3rbNmzeX5LxzMSgoyDzv3n//fZUrV0533323OXxNyZIlzZnGX3jhBf30009asmSJFixYoJ07d6pPnz5q0KCBAgMDFRsbq7///lvr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afTo0Ro/frzq1aun/v37KzIyUk888YQef/xx7dixQ9HR0ZKkihUrqm7duvL09HR68QAAAAAAAACQ19jd0zY1X19fvf3229q5c6fq16+v9957T/fee69Wr14tDw8P1a9fXx07dlTHjh3VoEEDAlsAAAAAAAAAsJNDoW2K6tWra9OmTfriiy90/vx5Pfroo+ratavOnj3rrPoAAAAAAAAA4I6SrdA2RZ8+ffTXX3+pQ4cOmjNnjqpWraqpU6c6Y9cAAAAAAAAAcEfJcmi7YcMGDRs2TH369NGwYcP0yy+/SJJKliypefPmacWKFQoICFBERISaNWumAwcOOL1oAAAAAAAAAMir7J6ILCkpSV26dNHChQslSYZhSJLGjBmjp556SvPmzZOnp6ceffRR/fnnnxo+fLg++ugj1axZU4MHD9bQoUPl7e2dM/cCAAAAAAAAAPIIu3vajh07VgsWLJC/v79effVVff755+rfv78KFCigxYsXa8yYMWZbPz8/jR8/Xtu2bVONGjU0cuRI1axZUxs2bMiROwEAAAAAAAAAeYXdoe3MmTNlsVi0fPlyffDBB3rhhRf0wQcfaPny5TIMQzNnzky3Ta1atbR161Z9+OGHOnbsmFq0aOHU4gEAAAAAAAAgr7F7eISYmBj5+/srNDQ0zfKmTZvK399f//77r9XtLBaLXn75ZT311FP63//+l71qAUmKDHR1BRmLvOTqCgAAAAAAAHAbs7unbZEiRXTlyhUdP348zfJjx47pypUrKly4cIbblytXTkuWLHGsSgAAAAAAAAC4Q9gd2j722GMyDENPPPGEVq1apQMHDmjlypV68sknZbFY9Oijj+ZknQAAAAAAAABwR7B7eIR3331X69ev165du9S6dWtzuWEYqlChgt59990cKRAAAAAAAAAA7iR2h7YlS5bUjh07NGHCBK1Zs0bnzp1T0aJF9fDDD6t///6ZDo8AAAAAAAAAAMic3aGtJBUqVEijRo3SqFGjcqoeAAAAAAAAALijZSm0BQAAAAAAAGBd8OAVri7BppixrTNvBLdh90RkAAAAAAAAAICcZ1doO378eF29etWpB/7999+1cuVKp+4TAAAAAAAAAG53doW2b7zxhipVqqSJEyfq4sWL2Trgpk2b9Pjjj6thw4bavn17tvYFAAAAAAAAAHmNXaHt0KFDFRsbq9dee02l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EZUvX97VZSIPqVWrlkaMGGF13cKFC7Vv3z498sgjuVwV7gSvvfaaJkyYoNKlS6tt27YKCAjQnj17NHnyZM2dO1e//vqr7r33XleXCRuYiAxub82aNapSpYoqVKigsWPHasiQIZo2bZp69uzp6tKQhy1evFhFixZVaGhomuUbN25Uy5YtVaBAAZ08eVK+vr4uqhB5UXJysm7cuCEfH580y2/cuKGHH35Y69ev1/fff6/WrVu7qELcCRITE3X//ffL29tbVapU0ezZs7Vlyxbdf//9ri4NeUxKMBsTE+PSOnDn+eijj/Tqq6/qpZde0scffyxPT88062/cuCEvL/o3Ieddv35dZcqU0aVLl3Ts2DGVLFnS1SUhDzl16pTKli2r8uXLa8+ePQoMDDTXTZw4UQMGDFB4eLimTp3qwiqREbrqwO099NBDqlChgqvLwB3mqaeeShfYSlKTJk3UvHlzXbhwQVFRUS6oDHmZh4dHusBWkry8vNSuXTtJ0qFDh3K7LNxh3nnnHe3bt09Tp05NF2QAwO3u6tWrGjlypCpVqqSPPvrI6nWOwBa5ZenSpfrvv//0+OOPE9jC6WJiYpScnKxGjRqlCWwl6fHHH5cknT171hWlwU78NwKALPL29pbEC3rknuTkZK1atUqS+PoSctTOnTv1zjvvaNSoUapWrZqry8EdICEhQdOnT9eJEycUEBCg+vXrq2HDhq4uC3nY6tWrdeHCBYWHhyspKUnLli3TgQMHVKhQIT300EOqXLmyq0vEHWTKlCmSpN69e7u4EuRFVapUkY+PjzZv3qzY2FgFBASY677//ntJYixlN0fiAABZ8O+//2rNmjUqXbq0atSo4epykEddv35d7777rgzD0H///ae1a9fq77//Vnh4OC+skGMSEhLUvXt31apVS6+//rqry8Ed4tSpUwoPD0+zrH79+po7d65CQkJcVBXysh07dkiSPD09dd999+nAgQPmOg8PD/Xv31/vv/++q8rDHeTIkSNau3atypUrp1atWrm6HORBRYsW1dixYzVw4EBVrVpVTz75pDmm7c8//6yXXnpJ/fr1c3WZyAChLQDYKTExUd26dVNCQoLGjRvH14aRY65fv66RI0eav1ssFr322msaM2aMC6tCXjd8+HAdPHhQO3bs4PqGXBEeHq4mTZro3nvvVYECBXTgwAFNmDBBs2bNUsuWLRUVFaWCBQu6ukzkMWfOnJEkTZgwQXXq1NG2bdt0zz33aNeuXXr++ef1wQcfKCQkRC+++KKLK0VeN23aNCUnJ6tnz57830WO6d+/v8qWLavevXvryy+/NJc3btxYXbp04dujbo4xbQHADikvqDZs2KCIiAh169bN1SXh/7V37+E91/8fx++fzzY7GDs5xbSJYsmp8PVlZZZUlDZCfPe1OSWqi1CNyxr7+krJXFxfomhsSMjC1cl3DrEpcmUhFn0l5HLYbAybnd6/P1z7/Lb2+Qw7+Kz1uF3Xrov36/B+vg9jnl6f56sWc3d3xzAMCgsLOX36NIsWLWLZsmUEBQVx5coVe4cntdC3337Le++9x/Tp01WCQ+6a6OhogoODadSoEW5ubnTs2JH4+Hj++c9/8ttvv/Hhhx/aO0SphYqKigCoU6cOn332GV26dMHd3Z1HH32U9evXYzabmTdvnp2jlNquqKiIuLg4TCYTI0eOtHc4UovFxMQQFhbGtGnTOH36NNnZ2ezevZvc3FyCgoLYvHmzvUOUcihpKyJyC0VFRYwcOZI1a9YQFhZW6n8oRaqT2WzG19eXcePG8cEHH5CSksK///1ve4cltUxBQQHh4eG0b9+eyMhIe4cjwtixYwFISUmxcyRSGxVvxtO5c2eaNm1aqu2hhx7ivvvu43//+x9ZWVl2iE7+KpKSkjh16hTBwcG0aNHC3uFILZWUlER0dDSvvPIKkZGR+Pr64u7uTmBgIFu2bMHJyYnJkyfbO0wph9ZBi4iUo6ioiBEjRhAfH8/QoUNZsWIFZrP+v0vuvj59+gCwc+dO+wYitc7Vq1c5fvw4cHPlmTV///vfAUhMTCQkJORuhSZ/UQ0aNADg2rVrdo5EaqPWrVsD4OnpabW9+HhOTo7NPiKVpQ3I5G748ssvAejVq1eZtiZNmtCmTRsOHDjA1atXcXd3v9vhyW1Q0lZExIaSCdshQ4aQkJCgelNiN2fPngXAycnJzpFIbePs7MyoUaOstu3atYvjx4/Tv39/GjZsiL+//90NTv6S9u7dC6D3TapFcfLi6NGjZdry8/P55ZdfqFu3Lg0bNrzboclfREZGBps2bcLb25vQ0FB7hyO1WF5eHgAXL1602n7x4kXMZrP+fVGDKWkrImJFcUmE+Ph4Bg0axKpVq5SwlWp35MgR/P39cXNzK3X8+vXrTJo0CYC+ffvaIzSpxVxdXS0rfv4oIiKC48ePM3XqVLp163aXI5PaLC0tjXvvvbfMn3dpaWm8+eabAAwbNsweoUkt17JlS/r06cPWrVtZtmxZqZWOc+bMISsri7CwMG3OI9UmISGBvLw8wsLCcHZ2tnc4Uov16NGD//znP8TGxjJw4EBLeRiAJUuWcObMGXr06KH3sAbT30RS4y1btozk5GQADh06ZDlW/BHhwMBAfaxEqlxMTAwrV67E3d2dBx54gFmzZpXpExISQseOHe9+cFJrrVu3jtjYWAIDA/H396d+/fr8/vvvfPnll2RkZPDoo4/y2muv2TtMEZFKW7t2LbGxsTz22GP4+flRt25djh07xhdffEF+fj5Tp07lscces3eYUkstXryY7t27M2bMGD777DPLR4S3b9+On58fc+fOtXeIUostX74cUGkEqX6DBg3i/fffZ9euXTzwwAP0798fT09PfvjhB7Zv346rqyuxsbH2DlPKoaSt1HjJycmsXLmy1LGUlJRSm1PoLzypaidPngRu1nq0tfGTv7+/krZSpZ555hnOnj3Lnj17+Pbbb7l69SoeHh60b9+eF154gZEjR2rlj4jUCr169eLo0aMcOHCA3bt3c/36dRo0aEDfvn0ZP368pY63SHVo2bIl+/fv56233uKrr75i69atNGnShJdffpm33nqLRo0a2TtEqaX27dvH4cOH6dq1K+3atbN3OFLLOTg4sHXrVubPn8+6detYs2YNeXl5NG7cmLCwMKZNm0ZAQIC9w5RymAzDMOwdhIiIiIiIiIiIiIjcpC3QRURERERERERERGoQJW1FREREREREREREahAlbUVERERERERERERqECVtRURERERERERERGoQJW1FREREREREREREahAlbUVERERERERERERqECVtRURERERERERERGoQJW1FREREREREREREahAlbUVERERERERERERqECVtRURERP7E/P39MZlMrFixokybyWTCZDKxc+fOO5pzxYoVmEwm/P39qyRGERERERG5M0raioiIiFSSYRisX7+e0NBQ/Pz8cHV1xd3dnZYtWxIYGMikSZNITEzkypUr9g611psxY4YlWe3m5sbZs2dt9j158mSFE9tyayWfhYiIiIjcGSVtRURERCohKyuLXr16MXjwYD777DNOnTpFQUEBzs7OnDp1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",
      "text/plain": [
       "<Figure size 1400x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot spike rates as a comparison bar chart\n",
    "\n",
    "MODEL_NAME = 'VGG-11'\n",
    "DATASET = 'N-Caltech-101'\n",
    "\n",
    "n_layers = len(lif_spike_rate)\n",
    "\n",
    "width = 0.25\n",
    "\n",
    "x = np.arange(n_layers) + 1\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(14, 6))\n",
    "ax.bar(x - width/2, lif_spike_rate * 100, width, label='LIF')\n",
    "ax.bar(x + width/2, qlif_spike_rate * 100, width, label='QIF')\n",
    "ax.set_xlabel('Spiking Neuron Layer', fontsize=18)\n",
    "ax.set_ylabel('Spike Rate (%)', fontsize=18)\n",
    "\n",
    "ax.set_xticks(x)\n",
    "\n",
    "# increase tick size\n",
    "ax.tick_params(axis='both', which='major', labelsize=14)\n",
    "\n",
    "\n",
    "ax.set_title(f'{MODEL_NAME} Average Spike Rate Per Layer on {DATASET}', fontsize=20)\n",
    "\n",
    "plt.legend(fontsize=16)\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.savefig(f'./Graphs/{MODEL_NAME}_Average_Spike_Rate_Per_Layer_on_{DATASET}.png')\n",
    "\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Norse",
   "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
