{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "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 IdentityEncoder\n",
    "from SNN.models.classification import ITQIFVGGSNN, ITLIFVGGSNN\n",
    "\n",
    "from Datasets.CIFAR10DVS import CIFAR10DVS\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": 3,
   "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": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The directory [../../data//cifar10_dvs/frames_number_10_split_by_number] already exists.\n"
     ]
    }
   ],
   "source": [
    "model1 = SpikingConvolutionNetwork(\n",
    "    encoder=IdentityEncoder(),\n",
    "    snn=ITLIFVGGSNN(num_classes=10, 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=ITQIFVGGSNN(num_classes=10, method='asym_rectangle'),\n",
    "    decoder=decode_mean,\n",
    "    seq_length=10,\n",
    "    input_scale=1.0\n",
    ")\n",
    "\n",
    "dataset = CIFAR10DVS(\n",
    "    root='../../data/',\n",
    "    train=False,\n",
    "    download=True,\n",
    "    transform=transforms.Compose([\n",
    "        torch.as_tensor,\n",
    "        transforms.Resize((48, 48)),\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": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "DIR = '../../SNN/output/CIFAR10DVS/'\n",
    "\n",
    "LIF_weights = 'LIFVGGSNN_Dropout_Cosine_Augmentations_100_(2024-09-04)_(12-35-44)'\n",
    "\n",
    "QLIF_weights = [\n",
    "    'LSGQLIFVGGSNN_Dropout_Cosine_Augmentations_100_(2024-08-30)_(15-56-15)',\n",
    "    'LSGQLIFVGGSNN_Dropout_Cosine_Augmentations_100_(2024-08-31)_(01-44-49)',\n",
    "    'LSGQLIFVGGSNN_Dropout_Cosine_Augmentations_100_(2024-08-31)_(03-13-12)'\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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/CIFAR10DVS/LIFVGGSNN_Dropout_Cosine_Augmentations_100_(2024-09-04)_(12-35-44)/LIFVGGSNN_Dropout_Cosine_Augmentations_100_(2024-09-04)_(12-35-44).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": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded from ../../SNN/output/CIFAR10DVS/LSGQLIFVGGSNN_Dropout_Cosine_Augmentations_100_(2024-08-30)_(15-56-15)/LSGQLIFVGGSNN_Dropout_Cosine_Augmentations_100_(2024-08-30)_(15-56-15).pth\n",
      "Loaded from ../../SNN/output/CIFAR10DVS/LSGQLIFVGGSNN_Dropout_Cosine_Augmentations_100_(2024-08-31)_(01-44-49)/LSGQLIFVGGSNN_Dropout_Cosine_Augmentations_100_(2024-08-31)_(01-44-49).pth\n",
      "Loaded from ../../SNN/output/CIFAR10DVS/LSGQLIFVGGSNN_Dropout_Cosine_Augmentations_100_(2024-08-31)_(03-13-12)/LSGQLIFVGGSNN_Dropout_Cosine_Augmentations_100_(2024-08-31)_(03-13-12).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": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "qlif_spike_rate = np.mean(qlif_spike_rates, axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "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": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Spike Rate of LIF: 0.05128046210400271\n",
      "Mean Spike Rate of QLIF: 0.04044043907740653\n",
      "QLIF spikes 21.138699968442875% 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: 0.8479847631590947 mJ\n",
      "QLIF energy: 0.3608288107854588 mJ\n",
      "Times Difference: 2.350102701924455x\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": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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vvnmGzVv3lyPP/64W8ds166d3n333VTrFCtWzOH+uXPn6sqVK5Ikf39/xcTEaOrUqS7d1ZPcsmXLVKpUKUk3R7BGRERoxYoV+vbbbxUfH69x48apXLlyev3119PVb3JJnyElycvLS1WqVJG/v782b96crn4SEhL0xBNPaMuWLZKkf//73+rVq5eKFCmiTZs26d1339WZM2fUu3dvlS5dWi1btnQ75iR9+vRR3759rf9fuXJFFy9e1B9//KGVK1dqxYoVOnv2rN566y0tWrRIv/zyi4KDg636TzzxhAoWLKjLly9r+vTpevvtt1067pEjR7RhwwZJUrNmzVS8eHGrbN26dXryyScVFxcnb29vPf3002rbtq3Kly8vb29vnT59Wtu3b9fSpUv1v//9L8OPAYAcLntzxgCQO4SHh6d7FOXUqVOtNqNHj05R/t1331nlxYsXN6tWrUq1v/j4eDN9+nRTrlw507t3b4d1Tp48aYoXL271+/bbb5tr166l2u+uXbtM27ZtjZ+fn8NjlihRwkgyBQsWNLt27Uq1r71795rZs2c7LEsaZRcUFGTF9/LLLzvtKz0jbZP3OXfuXKd9ZsVI2169elnP4ahRo4wk4+3tnWLUBu4su3fvtkaq16xZ01y8eDHV+suXLzfr16+/PcE5kHRd3wkjbZ2NFjbGmAEDBljn0rp16yyLxdNH2jp7P9iyZYvJkyePkWTy5Mljzp49e3uDTCdG2sKYm6NWq1atal0Lzz//vImOjnZa//r16+azzz4zBQoUMPPmzbMrS89I227durkd86OPPmokmfvuu8/07dvXSDJFihQx169fT7Nt8pG2zl5fFi5caNUpVKiQuXHjhtux7t+/34wZM8asXr3aXL582Rjj3t9e8s+lffv2TVF+4MABExAQYCSZihUrOhz56orkn+/Ses/6888/Ta1ataz69evXT/EcdO/ePd2jod955x2rzaxZs+zK6tSpY32W++9//5tqPxEREea7775z6ZgAcifmtAWA26Br166y2WySpOnTp7vUZtq0aZJujnro0qWLXdmxY8f00ksvSZICAgK0fv16NWrUKNX+vL299cwzz2jXrl1OR5P26tVLp0+fliR98MEHGjFihPz8/FLt91//+pcWLlyoCRMmpCjbtGmTNa9c79699a9//SvVvqpUqaIOHTqkWqdatWpq1aqVpJvziZ04cSLV+q7o3r27NfIiPDzcbtRJVrp27Zp++uknSVLHjh3VtWtXeXl5KSEhQT/88MNtiQFZY+HChdZ19O6776pQoUKp1n/00UdVv3792xBZzjZy5EjrNWvVqlUuzbedm9SpU0cdO3aUJN24cUOrVq3K5oiAtA0ZMkR79+6VJPXs2VMTJ05UwYIFndbPkyePXn75Zf3+++8qW7bs7QrTcvLkSa1cuVKS9Mwzz1if4S5cuKBffvklU47Rtm1bNWjQQJJ06dIlbdu2ze2+KlWqpNdee01hYWEqUKCA2/189NFHkqQiRYpozJgxKcorVqyoIUOGSLo5h27S3WRZqWrVqtqwYYNq1aolSdqwYYO+/PJLuzrPPvus9W9XP6Mn1QsMDFS7du2s/Ul3j0k3R/E2bdo01X5CQkL03HPPuXRMALkTSVsAuA3uuusuKyGzbNmyNBcdSP6Bv0mTJipdurRd+SeffGItVvXee++pYsWKLsdSqFAhtW3bNsX+Xbt2afHixZKkunXrpvtWu65du6bYl/yW7/TEmJZ33nlH0s2k53vvvZfh/vz9/fXGG29Ikv744w8rkZrVFi5cqEuXLkmSunTpotKlS6tx48aSpKlTpzpsU6FCBdlsNpcSfCdOnJC3t7dsNpsGDRrksE5UVJRGjRql+vXrKzg4WHny5FHJkiXVtm1b/fzzz6kmsG9diOW3337TU089pbJly8rX11ehoaF29ffs2aN3333Xmh7Dz89PBQoUUKVKldStWzeXF1U5f/68Bg0apLvvvlv58uVT8eLF9eijj1pfAJMvNJPaolTXrl3TuHHj9Mgjj6hEiRLKkyePihUrpqZNm+q7775TfHy8S/E4klnX/q3ncv36dX300UeqXbu2AgMDFRAQoHr16umrr75SQkKC036SFra59TlxVWJiovr06WPF0q9fvxTXRkaupcySP39+3XXXXZKk2NhYnT9/3mE9d6/FpAVwevToYe0rX758igVxVq9e7bD9/Pnz9dRTT6lcuXLKmzevChUqpDp16mjEiBG6ePFixk7eRffff7/178jIyBTlt/M1IatdvHhRkydPVpcuXVS1alUVKFBAefLkUYkSJdS8eXONHz/e6SJFAwYMkM1mk7e3t0s/Dt53332y2WyqWrWqw/KEhAR9//33atOmjUqVKiU/Pz8VLVpUDRo00CeffKKrV6867btRo0ay2WzWj7MHDhxQv379VKlSJWvBKHcW4EtMTNT06dPVqlUr6zUwODhYjRs31ldffZXqAk7JF76Tbr6ejhkzRrVr11bBggVVsGBB3X///Ro3blyGXkvPnj1r/ShcsmRJffrppy63dTa1VFabPn26EhMTrVvjH3zwQet9wNl7uzuqV69u/fvYsWOZ1q879u/fr7/++kuS1KFDB+XPn99hveTTaN2OpK0k5cuXT9OmTbOu1Y8++shu4c9GjRqpXLlykqTZs2enuSjopk2brGk6nnrqKeXNm9cqy6rPvQBysewc5gsAucn48eOtW6k+++yzVOuOGTPGqjt16lS7ssTERGtxg4IFC5orV65kSnz9+/d3ekx3zZkzx+rzlVdeyVBfSbdGh4WFGWOMadeunXWLb0RERIr66ZkeYfjw4SY2NtaULFnSSDJVqlQxCQkJKdpk9vQIrVu3NpLM3Xffbe1LfkviH3/8kaLNsGHDjCRjs9nSjCH5dbRz584U5StWrEhzoYxWrVpZt0veKvnjN3To0BRtk9/G7urCIW+88Uaq5/THH3/YTeFx6/bCCy+4dOv6zp0701zYqm7dum5PU/Gf//zH6ufW23PTI/m5bN++3dx3331O423YsKHT5yojC5HduHHDdOrUyaozbNiwFHUyei25wpXpEYwxpkaNGtYxHU1LkZFr0dW2t05PcOHCBdOkSZNU2xQrVszlW3MdcWV6BGOM+eabb6x6t069cztfE1yR0ekRXFm8rlatWuaff/5J0fbPP/+06owaNSrV4+zatcuqO2bMmBTlkZGRdtelo61ixYrm77//dth/WFiYkW6+/82fP9/4+/unaJ/e96Tz58+b+vXrpxpTlSpVHL6/GmN/vZ06dcrUrFnTaT9t27Z1+J7qis8//9zq56233nKrj+Rux/QI9957r5FkmjVrZu1Lerx8fX3NuXPnUm3vyvQIxhjzyiuvZMr7jCPp/dtLPjVCWtOAVa5c2Ugy5cqVcyu29EyPkFyzZs2sdhs2bLArS/56tWDBglT7eemll6y6a9eutSvbtm2bVdauXTuXYwMAZxhpCwC3SYcOHaxf45OmPnAmqbxAgQL697//bVe2Z88ea/TYww8/LH9//0yJb82aNda/W7RokSl9Jt2OJknffvutfvvtt0zpV5JGjBghm82mGzduaOTIkRnuL1++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8uPi4tSpUydr7jtXbrsqV66cNV9aVFSUGjRoYN3y64wxJs0VgydMmGAljF977TWNHDkyzVFXyReIutWvv/6qDh06pDn37oULF/Tyyy9b/0++OFN6DB061EqmZMa8jDabzRpte+bMmRQrRadX0pez/PnzuzxS48knn5Qk/f333ylGReXJk8cqX7RokWbMmGEttuNsagTp5orYZcuWlXTzeb51IbNbrV+/PtWRM2mpVKmS9W9nj+HXX3+tBQsWOO0jb9681t/Gli1bHCZcExMT1bt3b127ds1pP82aNbMW1xozZow1/68zu3fvthaXSY8RI0Zo0KBB1vzFzuzatUsfffSRpJtTJbRt29Zp3Z07d2rMmDEp9sfHx6tXr17W32qfPn3SHa8jjz76qObPny8/Pz+dOHFCjRs31uHDh+3q3O5ryRXNmjWzRlHNnj3b7rbTzLgWpZs/vCVxlMxOUqhQIWs+7P/973/q37+/EhMTndY/ffq0Jk6cmOqxs4InPo8ZlfRcL1q0yOEUCIcOHdJLL73kcn+NGzdWhQoVJN2czic6OlqS86kRpJvzZiYtBjlr1ix98sknqR7jyJEj6VqI011J53327Fm7997kRowYYY1U79Wrl/z8/LI8Lmfef/99KyE4ceJE9erVK9XFruLi4jRu3DjVq1fPmj81qxhjrB8SQ0NDdd9996XZxsfHR48//rgkaeXKlS7/cHCrIkWKWHOiRkZGOvxx93Z67bXXJN38TDdo0KAU5YcOHdKoUaMk3Zy25HYkbffu3asGDRpYn0PDwsJceo9MWjDuzJkzeuGFF6z9aX1G37t3r5o1a5bma+i1a9f0wgsvWEledz/3AsgFDAAgW8TGxpqCBQsaSdZWuHBhc+3aNZf7GD58uF37Jk2amLFjx5oVK1aY7du3my1btphFixaZESNGmGrVqln1vL29zYkTJxz2uWnTJlO8eHGrbrly5cygQYPMggULzO+//2527NhhVq1aZb755hvTrl074+3tbdX94IMP7PpatGiRVVajRg0zdOhQM2/ePPP777+b7du3m6VLl5phw4aZYsWKWfXuu+8+ExcXlyKukJAQI8mEhYWl+pi8+uqrdo+JJDN58uQU9Y4cOWKVDx8+3Gl/iYmJplatWin6PHLkSKpx3CoyMtLYbDYjybRv397ldnv37rWO2bdv3xTlq1evtsoLFSpkJJnixYub+Pj4VPvduHGj8fPzs66HZ555xvz0009m69atZvPmzWbBggXm7bffNtWrVzeSzBdffJGiD1ceP2NuPob33nuvVb9Dhw5m0aJFZuvWrWb+/PnmySefNJJM/fr1U+3z/PnzpkSJEladrl27mqVLl5pt27aZ2bNnm4ceeshIMvfff79VJyIiIkU/Bw8eNEWKFLHqtG3b1kyfPt1s2rTJbN261SxZssS899575oEHHjCSzMCBA1M9P0cGDhxoPbbNmjUzo0ePtmLdunWrmTNnjnnhhRes50CSeeWVV1L0M3nyZKu8Tp06RpJ5+umnza+//mq2bdtmZs2aZXe+bdu2dRhPt27djCQTEhLisDy1x33x4sUmT548VvtbH9PMuJZckfQa4Owckps3b551Ts8995y1P7OuxejoaJM3b14jydSuXdssX77c/P333+bAgQPmwIEDJjY21qp77do1U69ePbvXwnHjxpn169ebHTt2mN9++8188cUXpl27diZPnjzmvvvuc+vxSf5+sGrVqnS3v52vCa5Kfv0///zzZvLkyWlu58+fN8YYM2bMGKtt5cqVzXfffWc2bdpk1qxZY4YPH24CAwNN3rx5Te3atV2+rt577z2794GKFSum2eb8+fPmrrvusto0bNjQTJw40WzcuNFs377d/Pe//zUfffSRadq0qfHy8nL4/hAWFubS+5+r4uPjzYMPPmj32eHnn38227ZtM7/88ov597//bZVVqFDBXL58OUUfya+31KxatSpD12WSQ4cOmcqVK1t9FStWzPTv39/Mnz/fbNq0yfz+++9m3rx5pn///qZcuXJWvXnz5tn1k/yaSuuzQbdu3dKMa+3atVb99LxXLFmyxGr34Ycf2pUlvV678lnjn3/+sV6LKleubBISElyOIbmffvrJ7u/o+eefd/q39+uvvzrsIz4+3u61s3379mbp0qVm06ZN5osvvrA+63l5eZklS5a4Facx9tdUnz59zO7du63t999/N7/++qv54IMPTLNmzazPXZLMAw88YM6ePevSMZJ/Zkvaqlatmma73bt3270+DBw40Pz444/mf//7n9m5c6dZsWKFef/990358uXtPmdfunTJ7ccDQM5G0hYAslGPHj3sPhD27t073X3MnTvX7gthapvNZjMtWrQwu3fvTrXPyMhI89hjj7nUZ9KX3UmTJpnExES7ftavX2/8/f1d7ufRRx81586dcxiTq0nbU6dOmfz589v1m5GkrTH2yWdXv0jd6t1337Xazpw5M11tq1ataiSZokWLmuvXr9uVJSYmmrJly9rF5ij558jGjRtTtHW2ff/99ynapydBs2PHDlO4cGGn/VevXt2cPHkyzT537txpgoODnfbTvXt3891331n/P3XqlMN+/v77b7vkXWrbiBEjXHo8k/voo4/sftBIbfPy8jL9+/d3+GU7eYJh+/btDn9ASNrq169voqOjHcaTkaStMcYsXLjQ+Pr6GkmmfPny5ujRo3blGb2WXJGepG1iYqL1Q5Wvr6+JjIy0yjLrWhw0aJDTPm5NTkVHR9slwlLbGjdu7Nbjk9GkrTG39zXBFcmvf1e3HTt2GGOMuXHjhmnWrJnTevny5TM//vhjmn8byZ04ccLu7/q9995z6Tz++ecf8/DDD7sUf48ePVK0z+ykrTE3k8nJE2yOtipVqjj84cuY25+0TYq5a9euxsvLK83H0dfX17z88sspkmGZnbTt2bOnVX/jxo0un8uNGzesH1qrV69uV5aepK0xxvTt29eqP2PGDJdjSC7p9dWVLbXr8OzZs6Zu3bpO2/r5+ZkJEya4FWOS5NeUK1twcLB57733HA4ISE3jxo3t+hk1alSabQ4fPpzq+8utW506dcyhQ4fcfSgA5AIkbQEgGyUfJSnJbNiwwa1+4uLizI8//mief/55U7VqVRMUFGR8fHxMQECAKV++vHnsscfMqFGjzOHDh9PV744dO8ywYcNM/fr1TenSpU3evHlN3rx5TcmSJc1DDz1kXnnlFfPf//431ZEdsbGxZuHChWbAgAEmLCzMlCpVyvj5+RkfHx9TpEgRU7t2bdO7d+80v8y5mrQ1JmUyJaNJW2OM3WhGV79IJXf33XdbX1icJdaceeutt6zjzp07N0X5ree7efNml/u+du2a+eabb0zr1q1NqVKlTJ48eUzevHlN2bJlTbNmzcx7771n9u3b57BtehM0kZGR5sUXXzQhISHG19fXFClSxNx///3mo48+MlevXnW5z7Nnz5qBAweaSpUqGT8/PxMUFGQaN25sfVkdO3as1U9Sv47Ex8ebGTNmmPbt25ty5cqZfPnymTx58piSJUuaRo0amWHDhplt27a5dG6OnDlzxnz//ffm+eefN3Xq1DFFixY1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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 = 'VGGSNN'\n",
    "DATASET = 'CIFAR-10 DVS'\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.replace(' ', '')}.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
}
