{
 "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 IdentityEncoder\n",
    "from SNN.models.classification import ITQIFVGGSNN, ITLIFVGGSNN\n",
    "\n",
    "from Datasets.NCars import NCars\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",
    "import tonic\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": [],
   "source": [
    "model1 = SpikingConvolutionNetwork(\n",
    "    encoder=IdentityEncoder(),\n",
    "    snn=ITLIFVGGSNN(num_classes=2, 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=2, method='asym_rectangle'),\n",
    "    decoder=decode_mean,\n",
    "    seq_length=10,\n",
    "    input_scale=1.0\n",
    ")\n",
    "\n",
    "dataset = NCars(\n",
    "    root='../../data/',\n",
    "    train=False,\n",
    "    download=True,\n",
    "    transform=transforms.Compose([\n",
    "        tonic.transforms.Downsample(\n",
    "            sensor_size=NCars.sensor_size,\n",
    "            target_size=(48, 48)\n",
    "        ),\n",
    "        tonic.transforms.ToFrame(\n",
    "            sensor_size=(48, 48, 2),\n",
    "            n_time_bins=10\n",
    "        ),\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": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "DIR = '../../SNN/output/NCars/'\n",
    "\n",
    "LIF_weights = 'LIFVGGSNN_NCars_(2024-09-04)_(15-08-52)'\n",
    "\n",
    "QLIF_weights = [\n",
    "    'QLIFVGGSNN_NCars_(2024-08-31)_(04-39-36)',\n",
    "    'QLIFVGGSNN_NCars_(2024-08-31)_(07-27-34)',\n",
    "    'QLIFVGGSNN_NCars_(2024-09-02)_(09-45-11)'\n",
    "]"
   ]
  },
  {
   "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: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/NCars/LIFVGGSNN_NCars_(2024-09-04)_(15-08-52)/LIFVGGSNN_NCars_(2024-09-04)_(15-08-52).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/NCars/QLIFVGGSNN_NCars_(2024-08-31)_(04-39-36)/QLIFVGGSNN_NCars_(2024-08-31)_(04-39-36).pth\n",
      "Loaded from ../../SNN/output/NCars/QLIFVGGSNN_NCars_(2024-08-31)_(07-27-34)/QLIFVGGSNN_NCars_(2024-08-31)_(07-27-34).pth\n",
      "Loaded from ../../SNN/output/NCars/QLIFVGGSNN_NCars_(2024-09-02)_(09-45-11)/QLIFVGGSNN_NCars_(2024-09-02)_(09-45-11).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": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "qlif_spike_rate = np.mean(qlif_spike_rates, axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def difference_percentage(x: float, y: float) -> float:\n",
    "    return (x - y) / x * 100\n",
    "\n",
    "# make a method to determine how many times x is greater than y\n",
    "def times_greater(x: float, y: float) -> float:\n",
    "    return x / y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Spike Rate of LIF: 0.06193283681289081\n",
      "Mean Spike Rate of QLIF: 0.01718418115982273\n",
      "QLIF spikes 72.25352164678175% 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": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LIF energy: 1.090159913905518 mJ\n",
      "QLIF energy: 0.2588495952865098 mJ\n",
      "Times Difference: 4.21155734355646x\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": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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pH9qg1tjjPn444+t+77++usk27gyuP3333+tN2bvvPOOdX9kZKTJmTOnkWQGDRqUZLs//vjDqmHMmDEO91GjRg0jyVSuXDlJ29atW42vr6+R7qyv++6775rly5ebPXv2mOXLl5uuXbta+3n66aftjh/fXrVqVevP6dOnm507d5pNmzYl+oDixx9/NLlz5zbPPPOMmTJlitm4caPZu3evWbNmjXn//fcTBSzTp0+3u7/Lly8nerParVs3s3r1arN7927z7bffmocffthIMnXr1nX4PB0+fNgEBQUZSSYwMNAMGTLELF682Ozevdv88MMP5tVXX7Wem7p165rbt287fJztSRg43XfffWk+XxKOU7t2bSPJdOrUyaxatcrs3r3bzJ0717pfkmnXrp3dcdIa3F6/ft089thjRrrzYcGkSZOSbOuKc8kZzgS30dHR1rqVQUFBdvuk51y8du2aOXTokHn33XetPj/88IM5dOhQolvC1+1bt25Zr6/e3t6mW7duZt68eeaXX34xW7ZsMWPGjLHC0nz58iUblKXE2eA2fp1OKfGHdJn9muCM9Aa3xYsXN3Xr1jWjR482K1asMLt27TLbtm0zc+bMsc7rhL9X7hb/mpLwwzV7Xn/9dSPdWSv17g97Lly4YEqUKGEkGX9/f9OvXz/z/fffm127dpkNGzaYIUOGWOdsmTJlzJUrV5KMHx9cli5d2uTJk8cEBwebcePGmW3btplffvnFfPLJJ6larzgmJsY6tvjj//77783u3bvNsmXLTLt27ay2smXL2g3qE55v9erVM35+fqZ///7mxx9/NHv27DFz5841FStWtPpMmTLF6fqSO/74f/tnz561HrNmzZol6Z9ScBscHGwkmdy5c5uYmJg01xXvueeeM2XKlDGDBg0y8+fPN9u3bze7du0yCxYsMH379rXW5Q0ODjb//vuv3THiX3cqVapkvL29TalSpcynn35qfvnlF7N169ZEHx7Ef4Dn6+trXnnlFbN8+XKza9cus2PHDrNw4ULz5ptvmnLlyhHcAkAyCG4BAMl65plnrDcTf/75p90+CWfuPP/880na58yZY7Xbm/mWVvFBVfHixV02pjHGtG7dOtEMkNq1a5vhw4ebVatWpeqN5t3BrTHGdOzY0XqzfOTIkUT90xLc3rp1yxQvXtxIMuXLl0/yhs6Vwe2kSZOssY4d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NWvWpCo4dYXevXtbwe2RI0dStW2ZMmXUs2dPffnll1q0aJH279+f7nq6dOmi9957T3/++afee+896+uy6TV79uxUb7Np0yb9888/iUKowMBAtW7dWgsWLNCCBQv06aefytfXV+vXr7dmESW37mCBAgV0+vRp3b59O1XhTlr9+eef1rIgQ4cO1bvvvmu3n6MZXQlnIZ0/f97hm1FHs8bjg+xr165lyrGnxMvLSy+88IK2bdsmyfG5/++//zo87oSzxxJ+PTk1HnroIQ0ZMkRPPPGEzp07p2bNmmnjxo26//777fbP7HPJkaJFi2rKlClq06aNIiMj9d///jfJtxpccS6mRsIPToKDg9MdyGYUT3oeXeXLL7+UJJUrV04///yzcubMabefM891165d9dZbbykqKkozZ87UyJEj9csvv+jPP/+UZH+2rfR/z//Vq1dVsWJFjwi0E742pDTjNOHs0bS+pmS0wMBAvfHGG/rvf/+r3bt3a+nSpYk+4LanYcOGWrRoka5fv65NmzY5XA4mJTNnzlRMTIy8vb21adOmZJeNcNVrSkLNmjVTs2bNJEkXL17UunXrNHXqVP300086evSoOnXq5NIP+AEgq2CpBABAip577jnrDVz8rL/4gMHX11fPPvtsstvabDYrVI2MjLTWS02vhGHxp59+mmEzHpNTtGhR6+9pmQU0bNgw+fn5yRiT4lqhzvD29rbWpDtz5owmT56c7jGvXr2qJUuWSLrzhmvevHkOb1988YWkO7Nz7F2kLD6YvXTpkvUV0fhlEgICAtS2bVu7dcSv37l7927dvn073ceVkoTLV8Sv3WtPwvVA71a5cmXr7ylduMnROPHHfuzYsQxdazU1nD33d+3a5XCc+PZcuXI5fWEuexo1aqTly5crZ86cOnv2rJo0aaLDhw/b7ZvZ51JKWrdurQYNGki6c+G+33//PVG7K85FyfnXqIRr5caH857I055HV4h/rtu2bZtsaGuMcXjRrXj58+fX008/LenOGuXGGGv989y5cyd7LsU/rlFRUSmeU5klYTC/Y8cOh3137txpdztP079/f+tbQiNGjEjx/y8Jv8Hy4Ycfpmvf8edZtWrVHK71m9HPf4ECBdSpUyetX7/e+t2/f//+ZF+7ASA7I7gFAKQoJCREjz76qCRp1apV+vXXX7V+/XpJd77entIangMHDrQu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3b59u+rWreuSHebKlUv/+c9/1K9fP4WFhblkTAAAAAAAAADISpyaceuq0Dah3Llzq3Llyi4fFwAAAAAAAADudU4FtwAAAAAAAACAzJNhwe358+d1/vz5jBoeAAAAAAAAALIslwa3J0+eVLdu3ZQ3b14VKVJERYoUUd68edWtWzf9888/rtwVAAAAAAAAAGRZLgtujxw5ogcffFDffPONrl69qoIFCyp37tyKjIzUN998o1q1aunw4cOu2h0AAAAAAAAAZFkuC24HDx6s8+fP67///a8uXbqkf//9V5GRkTp06JAaN26sCxcuaMiQIa7aHQAAAAAAAABkWU4Ht9euXXPYvn79ej322GMaPXq0goKCrPsrV66sBQsWyMvLS+vXr097pQAAAAAAAACQTTgd3FaqVEnLli1Ltv327dvKly+f3baAgAD5+voqOjo69RUCAAAAAAAAQDbjdHB748YNPfXUU2rfvr1Onz6dpL1GjRpatmyZtm7dmuj+uLg4DR8+XFFRUapevXq6CwYAAAAAAACArM7p4Pavv/5S165dtXjxYlWqVEmfffZZovYRI0bo1q1batSokerUqaNnn31W7dq1U6lSpfS///1PXl5eevvtt11+AAAAAAAAAACQ1Tgd3BYoUECzZs3SunXrVKhQIfXv318PP/ywDh06JElq3ry5Fi5cqOLFi2v37t2aP3++li1bppMnT6po0aL67rvv1LJlyww7EAAAAAAAAADIKnxSu0HTpk116NAhjR49WhMmTFCtWrU0YMAAjRw5Um3btlXr1q21Z88eHTt2TJJUunRpPfjgg/L29nZ58QAAAAAAAACQFTk94zYhf39/vfvuu9q7d69q166t//3vf6pSpYrWrl0rLy8v1a5dW506dVKnTp1Up04dQlsAAAAAAAAASIU0BbfxKleurK1bt2ry5Mm6dOmSHn/8cXXt2lXnz593VX0AAAAAAAAAkO2kK7iN16dPH/3xxx/q2LGj5s6dqwoVKmj69OmuGBoAAAAAAAAAsp1UB7ebN2/WsGHD1KdPHw0bNkybNm2SJBUuXFjffvutVq5cqcDAQPXu3VuNGzfW33//7fKiAQAAAAAAACArc/riZLGxserSpYsWLFggSTLGSJLGjh2rp59+Wt9++628vb31+OOP6/fff9fw4cP10UcfqVq1aho8eLCGDh0qX1/fjDkKAAAAAAAAAMhCnJ5xO27cOH3//ffKnTu3Xn/9dX3++ecaMGCA8uTJo0WLFmns2LFW35w5c2rChAnauXOnqlatqlGjRqlatWravHlzhhwEAAAAAAAAAGQlTge3s2fPls1m0/Lly/X++++rb9++ev/997V8+XIZYzR79uwk21SvXl07duzQhx9+qJMnT6pp06YuLR4AAAAAAAAAsiKng9uwsDDlzp1bjRo1SnR/w4YNlTt3bv3zzz92t7PZbOrfv79+//13tWnTJn3VAgAAAAAAAEA24HRwmz9/fl2/fl2nTp1KdP/Jkyd1/fp15cuXz+H2xYsX1+LFi9NWJQAAAAAAAABkI04Ht0888YSMMWrbtq3WrFmjv//+W6tXr9aTTz4pm82mxx9/PCPrBAAAAAAAAIBsw8fZju+99542btyoffv2qVWrVtb9xhiFhobqvffey5ACAQAAAAAAACC7cTq4LVy4sPbs2aMPPvhA69at04ULF1SgQAE1b95cAwYMSHGpBAAAAAAAAACAc5wObiUpb968euedd/TOO+9kVD0AAAAAAAAAkO05vcYtAAAAAAAAACBzENwCAAAAAAAAgIdxKridMGGCbt686dId7969W6tXr3bpmAAAAAAAAACQFTgV3P7nP/9RmTJlNGnSJF25ciVdO9y6datat26tunXrateuXU5vN2fOHPXp00e1atWSv7+/bDabZs6cmWz/yMhIDRw4UKGhofL391epUqX05ptv6tq1a+mqHwAAAAAAAAAymlPB7dChQxUZGak33nhDISEh6tChgxYuXKhz586luG10dLR27dqlt99+W2XLllWjRo20atUq1a5dW+3atXO60GHDhmnq1KkKDw9XSEiIw77Xr19Xo0aNNGnSJFWoUEEDBgzQ/fffr4kTJ6pp06a6deuW0/sFAAAAAAAAgMzm40ynd999Vy+//LKGDh2quXPnatGiRVq8eLEkqUSJEqpWrZqCg4OVP39++fv76/Lly7p06ZKOHTumAwcO6Pbt25IkY4zKli2r0aNHq3PnzqkqdNq0aSpfvrxCQ0M1btw4DRkyJNm+//vf/7R//3795z//0bhx46z7Bw8erPHjx2vSpEkOtwcAAAAAAAAAd7IZY0xqNjh9+rSmTp2q6dOn6+TJk/83kM2WpG/80D4+PmrVqpX69Omjli1b2u2bGvHB7YwZM9Sj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yy+/jIeHB+XLlycmJoZvvvmGjIwMpkyZwssvv2ztMKWMWrp0KW3btmX48OFs27bN/Ljw3r178fDwYP78+dYOUcqwlStXAiqTICWvf//+fPrppxw4cIBnn32Wnj174uLiwi+//MLevXtxdHQkJCTE2mHKAyhxK6VeZGQkq1evznUsKioq14YV+qUnxen8+fPA/bqP+W0E5enpqcStFLsePXpw+fJlDh06xA8//MDt27epVKkSTZs25a233mLo0KFaASQiZULHjh05c+YMx44d4+DBg9y9e5cqVarQrVs3Ro8eba7rLVISvLy8OHr0KDNmzGDXrl3s3r2bGjVq8O677zJjxgyqVatm7RCljDpy5AinTp2idevWNGnSxNrhSBlnY2PD7t27WbhwIZs2bWL9+vWkp6dTvXp1fH19mTp1Kg0bNrR2mPIABpPJZLJ2ECIiIiIiIiIiIiLyP9oeXURERERERERERKSUUeJWREREREREREREpJRR4lZERERERERERESklFHiVkRERERERERERKSUUeJWREREREREREREpJRR4lZERERERERERESklFHiVkRERERERERERKSUUeJWREREREREREREpJRR4lZERERERERERESklFHiVkRERORvzNPTE4PBwKpVq/K0GQwGDAYD+/fvf6Q5V61ahcFgwNPTs1hiFBERERGRR6fErYiIiEgRmUwmNm/eTJ8+ffDw8MDR0RFnZ2e8vLxo3749EyZMIDw8nFu3blk71DJv5syZ5oS1k5MTly9fzrfv+fPnC53clgfLeS9ERERE5NEpcSsiIiJSBElJSXTs2JEBAwawbds24uLiuHfvHvb29sTFxREVFcXChQvp27cvW7duLfbze3l5Ub9+fSpVqlRsc1aqVIn69evj5eVVbHNaQ0pKCrNmzbJ2GCIiIiIihaLErYiIiEgRDB48mO+//x4bGxsmTpxITEwMaWlpJCQkkJKSwq+//sq8efNo1qxZiZx/z549REdH06dPn2Kbs0+fPkRHR7Nnz55im9NavvjiC2JiYqwdhoiIiIjII7O1dgAiIiIif1exsbHs3LkTgNmzZxMYGJir3dbWlqZNm9K0aVMmT55MSkqKNcJ8ItWuXRtXV1dOnDjB1KlT2bJli7VDEhERERF5JFpxKyIiIlJIx48fN/+5V69eD+zv6OiY51jOzcWSk5OZ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hX0pRERERB6aErciIiIihWRnZ0dWVhbffPMNQ4YMoU6dOtjb2+Pm5oa9vT3PP/88q1atAu6vtA0PD893x/mgoCCqVq1K//79cXZ2xsXFhYYNG7J3714MBgOffvqp+dH4ovLx8WHdunXY2tqyZMkSRo0a9diStz4+PuaVvmFhYbi7u1O5cmUqVqxIQEAA//jHP8wJNwcHhxKJwc/PjwYNGjyw3/Tp05k+fToGg4GwsDCaNGmCk5MTVapUwcHBgRYtWhAUFMTFixfzbLj27LPPMm3aNOB+grh27dq4uLhQsWJF/Pz86NSpE6NHjy7ytcyZM4cBAwZgMpkIDg7Gzc2NypUr4+bmxuzZswEYNGhQgauLH4eqVasW+OXt7Q1AvXr1eP/99wHYunUr7u7uuLi44OzszMCBA3F2dmbx4sUPdc5u3brh4eFh/rulTcly6ty5M5s3b6ZChQocPnyYLl26UL58efP99vLyYtSoURw9etQqG+yJiIjIk0eJWxEREZFCevXVV4mNjWXRokX079+fhg0bYm9vT1JSEk5OTtSrV48BAwawceNGfvrpJ2rWrJnvXK6urhw5coTAwECefvpp0tLSqFy5Mm+88QZRUVH5PuJdWAMHDmTjxo3Y2dmxfPlyRowY8diStwsXLmTr1q14e3tToUIF0tLSaNiwIfPnz89VWqAoZSEKYmNjw5w5cx7Yz2AwEBwczIkTJxg9ejQNGzbExsaGmzdv4urqStu2bXn//fc5dOiQuUZqTrNmzSIsLIw2bdpQvnx5MjMzad68OcuWLWPr1q3Y2NgU+VrKlSvHl19+yZYtW3j99ddxc3MjOTkZNzc3Xn/9dbZu3cr69est1nUtrebOncuaNWto3bo1jo6OZGRkULduXaZOncqxY8cK/D7KyWg00rdvX4B8NyX7q969e3P27FmCgoJo3bo1zs7OJCUlYW9vT7NmzQgICCA8PNycXBYREREpSQbT4/qELiIiIiJ5eHp6cuHCBUJDQ/Hz87N2OKVCu3btOHToEMHBweZyBSKF0aRJE06dOsWUKVMeKlkvIiIiUppoxa2IiIiIlBrff/89hw4dAuC1116zcjTyd7Z//35OnTqF0Wh8YJkEERERkdJIiVsREREReazeffddVq1axZUrV8zlGZKSkli+fDm9evUCoFOnTrRq1cqaYcrf2NWrV821lN988008PT2tGo+IiIhIYdhaOwARERERebJERUWxdOlSAOzt7XFyciIpKcmcxH3uuedYs2aNNUOUv6m33nqLqKgorly5wr1796hQoQJz5861dlgiIiIihaIVtyIiIiLyWAUHB+Pv789zzz2Hs7MzycnJuLq68tJLL7Fw4UJ++uknatWqZe0w5W/oypUrXLp0ifLly9OlSxf2799PnTp1rB2WiIiISKFoczIRERERERERERGRUkYrbkVERERERERERERKGSVuRUREREREREREREoZJW5FREREREREREREShklbkVERERERERERERKGSVuRUREREREREREREoZJW5FREREREREREREShklbkVERERERERERERKGSVuRUREREREREREREoZJW5FRERERERERERESpn/By51w96Zwhb1AAAAAElFTkSuQmCC",
      "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 = 'NCars'\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
}
