{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ejahns/miniconda3/envs/Norse/lib/python3.12/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "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 CopyEncoder\n",
    "from SNN.models.classification import ITQIFResNet34, ITLIFResNet34\n",
    "\n",
    "from Datasets.CIFAR10 import CIFAR10\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": 2,
   "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": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n"
     ]
    }
   ],
   "source": [
    "model1 = SpikingConvolutionNetwork(\n",
    "    encoder=CopyEncoder(seq_length=2),\n",
    "    snn=ITLIFResNet34(num_classes=10, method='asym_rectangle'),\n",
    "    decoder=decode_mean,\n",
    "    seq_length=2,\n",
    "    input_scale=1.0\n",
    ")\n",
    "\n",
    "model2 = SpikingConvolutionNetwork(\n",
    "    encoder=CopyEncoder(seq_length=2),\n",
    "    snn=ITQIFResNet34(num_classes=10, method='asym_rectangle'),\n",
    "    decoder=decode_mean,\n",
    "    seq_length=2,\n",
    "    input_scale=1.0\n",
    ")\n",
    "\n",
    "dataset = CIFAR10(\n",
    "    root='../../data/',\n",
    "    train=False,\n",
    "    download=True,\n",
    "    transform=transforms.Compose([\n",
    "        transforms.Resize((64, 64)),\n",
    "        transforms.ToImage(),\n",
    "        transforms.ToDtype(torch.float32, scale=True),\n",
    "        transforms.Normalize(mean=[0.4914, 0.4822, 0.4465], std=[0.2023, 0.1994, 0.2010])\n",
    "    ])\n",
    ")\n",
    "\n",
    "dataloader = torch.utils.data.DataLoader(\n",
    "    dataset,\n",
    "    batch_size=16,\n",
    "    shuffle=True\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "DIR = '../../SNN/output/CIFAR10ResNet34/'\n",
    "\n",
    "LIF_weights = 'ITLIFResNet34_CIFAR10_T2_(2024-11-14)_(20-44-50)'\n",
    "\n",
    "QLIF_weights = 'ITQIFResNet34_CIFAR10_T2_(2024-11-14)_(19-02-30)'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ejahns/Documents/discretized-qif-neuron-model-archive/src/Graphs/SpikeRateEnergyConsumption/../../AbstractModels/ConvolutionModel.py:588: 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/CIFAR10ResNet34/ITLIFResNet34_CIFAR10_T2_(2024-11-14)_(20-44-50)/ITLIFResNet34_CIFAR10_T2_(2024-11-14)_(20-44-50).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": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded from ../../SNN/output/CIFAR10ResNet34/ITQIFResNet34_CIFAR10_T2_(2024-11-14)_(19-02-30)/ITQIFResNet34_CIFAR10_T2_(2024-11-14)_(19-02-30).pth\n"
     ]
    }
   ],
   "source": [
    "model2.load_by_path(f'{DIR}{QLIF_weights}/{QLIF_weights}', None, None)\n",
    "qlif_spike_rate = get_spike_rate(model2, dataloader, device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Spike Rate of LIF: 0.29311977356122215\n",
      "Mean Spike Rate of QLIF: 0.12417914757956883\n",
      "QLIF spikes 57.63535633544276% 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": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LIF energy: 3.0008323229861467 mJ\n",
      "QLIF energy: 1.3982858643884328 mJ\n",
      "Times Difference: 2.146079281362555x\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": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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TZrIbrfLz89P5cqVU4MGDdS1a1fNmzdP0dHRme5j1KhRCggIkKQsE0iuOHTokAYNGqQGDRrIbrerSJEiqlGjhnr16pVhYthms6W5ja93797pJt3IzUnRUt+Ol9XERUlJSerXr59SUlI0YsQI1a5dO9fictxKWbduXTVu3FjdunWTzWZTUlKSFi5cmK7+xo0brcfro48+ynL/kyZNsur/9ttvTuvs2rVLzz33nG688UYFBQUpMDBQN954owYMGJDphFnz5s1LMzlLfHy8/ve//+m2225T6dKl0z2nCQkJWrFihV588UU1a9ZMJUqUsCbpat68uUJDQ/Xvv/9meUyStGnTJnXq1Enly5dXQECAatSooeeee06HDh2S9H+Tz7Ru3TrT/bhzLrvqzz//lCRVr17d7S/CUvpjOXjwoJ599llVr15dAQEBqlChgp544gn98ssvme4np6+zY8eOqXbt2rLZbCpWrJjWrVuXro6755InuXJtzsm52KtXL9lsNoWFhUmSwsLC0l3LMprQJSoqSpMmTVKLFi1UpkwZFS5cWBUqVNBDDz2kRYsW5clwFkFBQapbt66kK8PBnDt3Ll2dvLom5IX9+/frtdde03333afKlSvL399fQUFBqlWrlnr27Jnh6yYxMVHly5eXzWZT+/btXWrHcexTp051WufUqVP673//q6ZNm6pkyZLy9/dXlSpV9MQTT2SaeEs9eei8efMkSd98840eeOABVaxYUb6+vlle6zJy5swZjR49Wo0bN1bx4sUVEBCgkJAQ9ejRQ5s2bcp0W8dkeI6hCA4ePKh+/fopJCRE/v7+KleunB599NEsr01ZmTNnjnXL/gsvvKBWrVq5vO3TTz+do7bd9emnn0qS2rVrpzJlyqhHjx6Srgyhs3LlSo+0UaNGDWt4gKw+h+aFpUuXWn/37t3baR0fHx/rOblw4YLbib7Lly9r+fLlkq5MkpWR5ORkzZw5U5J0zz33qHnz5m61d7UXXnhBMTEx6tmzp0vnozFG9913n2w2m3x9fbVly5YM67799tvW633cuHFpytasWaOIiAhJVyZF8/XN+ciUx44ds74buJOEbtKkifX5/vPPP89xPADyQX53+QWA7HLldlxjrkxI4KjXsWNHp3Xi4uLMk08+menEAYGBgWb58uVOt9+4cWOmEzw4lhUrVqTb1nGLm+M2J8dt/5Kc3r7m6lAJ06ZNs4YdcLbYbDYzZsyYdNtldQxZtZsTp0+ftm5TLF26dJb1p0yZYiSZWrVqmcuXLxtjTK4MlXDq1ClTqFAhI8lMnDjRWu947pwN65CSkmKqVq1qJJnWrVtn2YZjIo5GjRqlK0tOTjaDBg0yNpstw+fE19fXfPjhh073nfr2+u3bt5tGjRpl+pymfgwzWkqVKmU2bdqU6TFNnjw5w5iLFStmVq9e7dJt7O6ey64qVqyYdc4lJia6vZ/Ux/Ldd99lOBmJj4+PmTFjRob7yex1ltVQCb/99pupXLmy9Rxt3bo1TXlOzyVXePLanJNz0ZVtnd1eunbtWlOqVKlMt3vggQfMxYsX3XyEXBsqwRhjbrvtNqvNU6dOWevz+prgipwMleDqhHYjRoxwuv3QoUOt19aJEycybWvQoEHW4/P333+nK//ss8+ynEjomWeecXqtSP3+PGfOHNOjR49027ozZMfq1auz/IzxwgsvZHj7s+N869mzp/nmm29M0aJFne6jUKFC5osvvsh2fA5NmjSxrsmHDh1yez8OuT1Uwvbt263tFy5caIy58t5dvXp1I8k8+uijWe7D1efVMdRSdifVckV2X3uOYRICAwMzfc/7+eefrf2OHTvWrdg2bNhg7WPdunUZ1tu4caNV791337XWx8XFmUOHDpkTJ06YpKSkbLX95ZdfGunKxHBnzpwxxrh2zpw8edJ6D6hRo4aJjo5OV2f//v0mICDASDLNmzdP9zj26dPHei2k3v7s2bPmjz/+MGfPns3WsRhjzAMPPGAkmR49eljrsjNUgjHG+q5TqVKlbLcPIP+RuAVQ4LiaHFi4cKFVz9msrSkpKaZDhw5WnYceesh8+umnZvPmzWbLli3mrbfeshJwhQsXNtu3b0+z/eXLl03FihWNdCUZNWzYMPP999+bnTt3mi1btpiFCxeaF1980VSqVMmlxO2pU6esL1V33313uvquJG5Tj0128803mw8++MCsXbvW7NixwyxYsMDcfvvtVvlbb72VZtt9+/aZ1atXW+Wvvfaa2bdvX5rln3/+yfDxzq7Lly+bI0eOmFmzZpmaNWumaTczR44csR6nH374wVqfG4nbN954w/oAfuzYMWv9Rx99ZLW1f//+dNsNHz7cpWTCnj17rP1MmzYtXfnzzz9vld91111mzpw5ZsOGDWbbtm3mo48+MvXq1bPKly1blm771Emam2++2dhsNvP000+blStXmp07d5olS5aY7777zqrfrVs3U6NGDTNkyBDz5Zdfmi1btpjt27ebRYsWmeeee84ai7lMmTIZnguOL0yOL01TpkwxP//8s/n555/NlClTTIkSJUyJEiWs8ewy+tKbk3PZVam/9L7wwgvZGjvP2X5q1aplihcvbux2u5k4caJ13K+//nqa5MuSJUuc7iez13dmidtt27ZZXzYrVqxofv3113Tb5/RccoWnrs3G5OxcPHHihNm3b59p2rSpkWSaNm2a7lp28ODBNNts2rTJ+pGgXLly5rXXXjMrVqwwO3fuNCtWrDDdu3e3Ys7JuLOufNlOTEw0xYsXt957UicG8vqa4IqcJG5/+OEHExgYaJ544gkzc+ZMs2HDBrNr1y6zatUq88Ybb1iPlyMherWDBw9a5al/XLtaQkKCKVOmjPVef7Uvv/zSSobXqFHDvPnmm2bVqlVm586dZvHixVbiRJIZNGhQuu1Tvz/ffPPNRpJp2bKlWbhwodmxY4dZu3atmT17drYem/DwcOs89/PzM4MGDTLr168327ZtMx9++KGVZJRkhg0b5nQfjsevSZMmJiAgwFSvXt28++675pdffjFbtmwxoaGhVhIqODjYnD59OlsxGmNMVFSUNVZsnTp1sr29M7mduP3Pf/5jfXaLjY211v/3v/+1XndZJdhcSdyePHnSqtewYcNsx5mV7L72Spcu7VIs586ds/bbuXNnt2KbMGGC9fnpwoULGdZL/V4fFhZm/vjjD/PYY4+l+dHWbrebHj16uPSjwPnz50358uWNJPPRRx9Z6109Z5YsWWLV69WrV5qyy5cvW6/vwMBAExERkW57xzwI1atXN8YYs2DBAusHesdSu3ZtM23aNKvjQWY+//xzI8mUKFEizeszu4nbN99802rfWdwAvBuJWwAFjivJgaSkJNO4cWOr3k8//ZSuzqxZs6wvRN9//73T/Zw7d876ItyiRYs0ZevWrbP27ywx65CYmGiioqLSrb86cWvM//UecnyATS2rxO2vv/5qfdAdN26c0wnBkpOTrQREUFCQOXfuXIZteGpystSy6l319NNPZ5k8a9eunZFkunbtmmZ9biRuGzZsaCVIUrtw4YLx9/c3kszQoUPTbbd3714rFmcJWYfMErypJ/XI6At/XFyc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TVLXsWNHbdiwQSVKlPDcQbjh8uXL1t+uTG7leC3ExcW51d6ZM2ckKcvjjo2Ntf6+fPmyxo8frzfffFM33HCDChcurBo1amjq1Kl6/fXXJV15X540aVK6/SQkJOjZZ5+VMUaDBg1S/fr13YpbunIef/bZZ/L19dW5c+f01FNPqVevXjLGqEKFChlOPHv1sRQtWlTr169Xt27dVKJECRUpUkR33XWXfvzxRzVs2FCStGTJEm3dujXdvjZu3Kg5c+bI19dXM2fOzPSzkCtKlixp/e2YSBBAAZLPiWMAyDZXJzO54447TGRkpNN9zJs3z+XeGqmXKVOmWPtISEgwNWrUsMqaNWtmJk6caDZt2uTSWJnOetwac+UXe8dtm6l7KmTW4zYyMtKt47n//vvT7MfVHrf//PNPhrclHjlyJMtjv9ratWutnoOvvvqq0zqOHrW33nqr0x6unuxxm5SUZI2RltF4lgkJCdYt/927d09XfuzYMat3xn//+9905c8995yRZPz9/dPdKpd6Uo/sLAMGDEizn6snInLF3r17Te/eva3jz2y5emxRRy+SG264Ict2HD3er+6t5Klz2R2XLl0yP/74o5k0aZJ5/PHHrdtpHUtgYGC6XjzG/N9ruUaNGlm24RiX8o477khXltHr25i0z+XLL79snVv33Xdfhrf2G+O5c8kVnrg2p5aTc9EY13vcOoZJyM5SpEiRbD8+xqTtAelsCQ4ONo888ojZuHFjmu3y85qQlZz2uI2JiTETJ040N998c5rexs6W1O/BqQ0YMMBI6ccsNebKJIeO7a8e/zkpKcn4+vpm+3G96aab0uwn9XtnZsPjuKpr165GSj/GsTOOW81tNlu6zx6O8y2rcUodk6m5cg27Wn73uM3OGLfnzp2zxg0ePHiw0zr//POPdR5mNAyLMa5N6FqpUqUM44uJicl0iAdXeHOPW8fjnNXwGannmihdunSGn58TExOt94KSJUum64HqOCeqVq2abniM1OXZOWcc4/Q6FpvNZlatWpVh/TNnzqSp/9JLL2VY99tvv83wdXP58mVz4403GinjuwKz2+M2ISHBau+ZZ55xaRsA3oMetwAKtAEDBlg9OMPDw7VixQr17NlTPj4++vnnn9W6dWvrV//UTp8+7VZ7ly5dsv728/PTihUrrN4u27dv16hRo3TnnXeqePHiat++vRYuXKjk5ORstVGiRAkNGjRI0pVePY6eQpnxxPFkx/vvv68GDRo4XXr37p3t/d199916+eWXJV3pqXfgwIE05T/++KPmz5+vQoUKaebMmfLxyd23rzVr1lg9Ehy9b67m5+enLl26SLrSYyImJiZNedWqVdWyZUtJStezMDExUV9//bUkqUOHDlbPQYfceD5d6e3z8ccfq0mTJpo7d65LPTKu7olz/vx5Scqy12JmdfL6XE6tSJEiatOmjUaMGKGvv/5af//9t5YsWaIqVapIutKbZuDAgRluX7Zs2SzbcPQUP3funNtxvvXWWzLGqEyZMlq8eLGKFi2aYd38ejzdvTY75PRczA53HqOctCdJFStWtB6fffv26ffff9fJkyd14cIFLVmyxLp25CRGKefXhNwWGRmpBg0aaNSoUdq7d2+W75cZPe59+/aVdKX356JFi9KUOXrhNm/eXHXr1k1Tdu7cOSUlJWU77tx+XB3Xh5IlS6brIXw1R097Y4x1Db5aZtcISdZ7anY/r0hSqVKlrL//+eefbG+fl7744gslJCRIyvi9vWzZsmrXrp0k6bPPPkvT49uZpk2bWq/jvXv3as2aNRozZozsdrv++usvtW/fXj/99FO67bZv357h5yjHnSSelLoX+NWfV5xx9B4NCgpyqz3HHSxZXStTx9W6desMewP7+vpaPaTPnTuXpnf4gQMHrF6477zzjsd6fo8cOVI1atSw/u/bt6/uu+++DOtf3dPecR45c/fdd1uv7e3bt6cpe/3113Xw4EFVqVJFr776qjuhp5P6efDz8/PIPgHkncw/CQCAlytbtmya26EaNWqkBx98UG3atFGvXr0UGRmpvn37atmyZWm2S/3lZMWKFQoJCXG5vdTq1q2rffv2acWKFVqxYoU2btyoQ4cOKS4uTqtXr9bq1av15ptv6rvvvnMpqeMwaNAgvfXWWzp//rzGjh2r+++/P9P6qY9n7NixTm/td8abbmvs2LGjpk6dqpSUFH3zzTcaNWqUVTZlyhRJV74gHTx4UAcPHky3/dGjR62/V6xYYSUGn3zyyWzH4riVUpIee+yxLOvHxsZq8eLF6W6T79atmzZu3KijR49qy5Yt1m22q1ev1tmzZ606V0v9fH744Ye64447XIo7s4RBoUKFMt32wIEDeu6555SUlKSyZctq6NChatu2rUJCQlSsWDHr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TokSJdSkSRNFRETo66+/zklzAAAAAAAAAHBdcDtxu2rVKn3wwQcKCgrSkiVLdOHCBZUpU8Zp3aeeekrGGK1du9btQAEAAAAAAADgeuF24nbmzJmy2WwaP368OnbsmGnd22+/XZK0b98+t9q6fPmyBg8erLvuuksVK1ZUQECAypcvrxYtWmju3LlKTExMt010dLQGDx6satWqyd/fXyEhIRo6dKhiYmLcigEAAAAAAAAA8orbidutW7dKkvr06ZNlXbvdruDgYJ06dcqttmJiYvTBBx/IZrOpQ4cOGjx4sB599FH99ddf6tOnjx588EGlpKRY9WNjY9WqVSvNmDFDderU0aBBg3TjjTdq+vTpatu2rS5fvuxWHAAAAAAAAACQF3zd3fDcuXOy2+0qVqyYS/V9fHzSJFezo2TJkoqKilLhwoXTrE9KStK9996rNWvW6Pvvv1eHDldmFp06dap2796t4cOHa/LkyVb9ESNGaMqUKZoxY4ZGjhzpViwAAAAAAAAAkNvc7nEbHBys6Ohop8MUXO3cuXOKiopS6dKl3WrLx8cnXdJWknx9ffXoo49Kkg4dOiRJMsZo9uzZCgoK0pgxY9LUHzNmjIKCgjR79my34gAAAAAAAACAvOB24rZBgwYyxlhDJmTm888/lzFGTZs2dbc5p1JSUrRq1SpJUv369SVJEREROnnypFq0aKHAwMA09QMDA9WiRQsdOXJEx48f92gsAAAAAAAAAOApbg+V8Pjjj2vDhg0KDQ3VmjVr5OPjPAe8Z88ejR49WjabTV27dnU7UElKSEjQxIkTZYzR2bNntW7dOh04cEC9e/fW3XffLelK4laSatWq5XQftWrV0urVqxUREaEqVao4rRMfH6/4+Hjr/+jo6BzFDQAAAAAAAADZ4Xbitl+/fnr//fe1fv163XvvvRo0aJCSk5MlXUmeRkZGasWKFfr4448VFxen22+/XZ07d85RsAkJCXr11Vet/202m1555RVNmjTJWhcVFSXpyoRozgQHB6ep58ykSZPStAMAAAAAAAAAecntxK2fn59Wrlyp9u3ba/369dqwYYNVVqdOHetvY4waNGigxYsXy2az5SjYoKAgGWOUkpKikydPasWKFRo1apS2bNmi7777zkrK5tTIkSM1ePBg6//o6OgMe+cCAAAAAAAAgKe5nbiVpGrVqmnnzp164403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ERERERERERHJDBu3RERERERERERERDLDxi0RERERERERERGRzLBxS0RERERERERERCQzbNwSERERERERERERyQwbt0REREREREREREQyw8YtERERERERERERkcywcUtEREREREREREQkMypzByAiIiIiqpIIp0pul27aHEREREREJsArbomIiIiIiIiIiIhkho1bIiIiIiIiIiIiIplh45aIiIiIiIiIiIhIZti4JSIiIiIiIiIiIpIZNm6JiIiIiIiIiIiIZIaNWyIiIiIiIiIiIiKZYeOWiIiIiIiIiIiISGbYuCUiIiIiIiIiIiKSGTZuiYiIiIiIiIiIiGSGjVsiIiIiIiIiIiIimWHjloiIiIiIiIiIiEhm2LglIiIiIiIiIiIikhk2bomIiIiIiIiIiIhkRmXuAERERERERERERGQkEU6V2Cbd9Dmo2ti4JSIiIiIiIiKiFwObkvQXwqkSiIiIiIiIiIiIiGSGV9wSERERERERkenxSkkiIoPwilsiIiIiIiIiIiIimWHjloiIiIiIiIiIiEhmOFUCEREZhl9xIyIiIiIiIjI5Nm6JiIiIiIiIqot/3CYiIiPjVAlEREREREREREREMsMrbomIiIiIiIiIiMhgntMPVmq7O9YmDvKSYuOWiIiISI4q85VbgF+7JSIiIiJ6SXGqBCIiIiIiIiIiIiKZYeOWiIiIiIiIiIiISGbYuCUiIiIiIiIiIiKSGc5xS0REREREROWrzLzbnHObiIjIqHjFLREREREREREREZHM8IpbIqLieDUJEREREREREckAr7glIiIiIiIiIiIikhk2bomIiIiIiIiIiIhkhlMlEBERERHRXxunSiIiIiIZYuOW6K+EH0qIiIiIiIiIiF4IbNwSERGR9PiHJCIiIiIionJxjlsiIiIiIiIiIiIimeEVt/Ty4NVbRERERGVxjERERET0QnqpG7fnz59HeHg4zpw5g4KCAjRv3hyTJk3CoEGDzB2NiIheZmySEBERERERUTW9tI3b6Oho9OjRA9bW1hgyZAgcHBywe/duDB48GElJSZg8ebK5IxIRERERERERERHp9FLOcfvs2TOMGTMGSqUSJ0+exBdffIGlS5fi119/RZMmTTBz5kwkJiaaOyYRERERERERERGRTi9l4/b48eP4/fffMWzYMLRq1Uq73MnJCTNnzkR+fj42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np6eSExMxLp16zBy5Ehzx5GFgIAAnDlzBpGRkdrpCoiqonnz5rhy5QpmzJhRqWY9ERERkZzwilsiIiIiko0TJ07gzJkzAIC33nrLzGnoRRYTE4MrV65AqVRWOE0CERERkRyxcUtEREREkho3bhzWr1+P5ORk7fQMaWlpWLNmDfr27QsA6NKlC/z9/c0Zk15gDx8+1M6l/O6778LT09OseYiIiIiqQmXuAERERET01xIbG4tVq1YBANRqNWxtbZGWlqZt4r766qvYuHGjOSPSC2rIkCGIjY1FcnIynj17BgcHByxcuNDcsYiIiIiqhFfcEhEREZGkIiMjMWrUKLz66quwt7dHZmYmXFxc8Oabb2L58uU4f/486tata+6Y9AJKTk7GvXv3YGdnh27duiEmJgYNGzY0dywiIiKiKuHNyYiIiIiIiIiIiIhkhlfcEhEREREREREREckMG7dEREREREREREREMsPGLREREREREREREZHMsHFLREREREREREREJDNs3BIRERERERERERHJDBu3RERERERERERERDLDxi0RERERERERERGRzLBxS0RERERERERERCQzbNwSERERERERERERycz/B9En5i7OIUfnAAAAAElFTkSuQmCC",
      "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 = 'ResNet-34'\n",
    "DATASET = 'CIFAR-10 (64x64)'\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()"
   ]
  }
 ],
 "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
}
