{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../..')\n",
    "\n",
    "from AbstractModels.SpikingConvolutionNetwork import SpikingConvolutionNetwork\n",
    "from AbstractModels.util.decode import decode_identity\n",
    "\n",
    "from SNN.Encoders import CopyEncoder\n",
    "from SNN.models.classification import LIFSpikeformer, QIFSpikeformer\n",
    "\n",
    "from Datasets.TinyImageNet import TinyImageNet\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": 10,
   "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": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "model1 = SpikingConvolutionNetwork(\n",
    "    encoder=CopyEncoder(seq_length=2),\n",
    "    snn=LIFSpikeformer(num_classes=200, method='asym_rectangle'),\n",
    "    decoder=decode_identity,\n",
    "    seq_length=2,\n",
    "    input_scale=1.0\n",
    ")\n",
    "\n",
    "model2 = SpikingConvolutionNetwork(\n",
    "    encoder=CopyEncoder(seq_length=2),\n",
    "    snn=QIFSpikeformer(num_classes=200, method='asym_rectangle'),\n",
    "    decoder=decode_identity,\n",
    "    seq_length=2,\n",
    "    input_scale=1.0\n",
    ")\n",
    "\n",
    "dataset = TinyImageNet(\n",
    "    root='../../data/',\n",
    "    train=False,\n",
    "    download=True,\n",
    "    transform=transforms.Compose([\n",
    "        transforms.ToImage(),\n",
    "        transforms.ToDtype(torch.float, scale=True),\n",
    "        transforms.Normalize(mean=[0.480, 0.448, 0.398], std=[0.229,  0.226, 0.225])\n",
    "    ]),\n",
    ")\n",
    "\n",
    "dataloader = torch.utils.data.DataLoader(\n",
    "    dataset,\n",
    "    batch_size=16,\n",
    "    shuffle=True\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "DIR = '../../SNN/output/TinyImageNet/'\n",
    "\n",
    "LIF_weights = 'SpikeFormer_LIFResNet19_T2_(2024-11-21)_(03-35-52)'\n",
    "\n",
    "QLIF_weights = 'SpikeFormer_QIFResNet19_T2_(2024-11-20)_(22-12-58)'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "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": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "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/TinyImageNet/SpikeFormer_LIFResNet19_T2_(2024-11-21)_(03-35-52)/SpikeFormer_LIFResNet19_T2_(2024-11-21)_(03-35-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": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded from ../../SNN/output/TinyImageNet/SpikeFormer_QIFResNet19_T2_(2024-11-20)_(22-12-58)/SpikeFormer_QIFResNet19_T2_(2024-11-20)_(22-12-58).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": 17,
   "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": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Spike Rate of LIF: 0.28595810245785064\n",
      "Mean Spike Rate of QLIF: 0.27452865879069904\n",
      "QLIF spikes 3.9968944991989734% 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": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LIF energy: 8.13655102187052 mJ\n",
      "QLIF energy: 8.199967037307053 mJ\n",
      "Times Difference: 0.9922663084927036x\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": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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xta1DqRXoUKFdPHiRYWHh6tVq1Y5btmjTz/9VNKdv00DAwPN5x29nwICAsyf8+fP7/b3XcmSJTVp0iR169ZNPj4+Scpq1aql559/Xk2bNtXmzZu1efNmzZ07V127drXZVvv27fXKK6/owoULWrhwIYlmAAAg22GpGgAAgGyoSZMmKlq0qOLj47VgwQK79RYsWKDbt2+raNGiaty4cSZGmHWcOXNGu3btkiS1a9fOZtJIYqGhoerZs2dmhAa41Ny5c5WQkCAvLy917dpV7du3lyQtXLhQcXFxbo4OaRUfH2/OdlGzZs0UByGCg4PVr1+/TIgsZytRooReeeUV8/effvrJjdFkPR4eHho9erT5+6pVq9wYDQBkTW+//bYkad++ffr222/dHI1rHTp0yJyp8bnnnnNzNGlnXebv7qQRq7x58+rLL780f1+8eLHdtgoWLKhmzZpJkqZNm+baQAEAADIBiSMAAADZkHW5Fen/lqKxxbpsxbPPPitPT0+n2//ll1/UrVs3lSlTRnnz5lW+fPlUtWpVDRw4UGfOnElWf/369bJYLOrRo4f5XOnSpc21tK2P9evXJ9lu27Ztevfdd9WwYUMVLVpU3t7eypcvnypVqqS+ffvqjz/+cDpme/755x/z53vvvTddbd29NvhPP/2k1q1bq1ixYvL19VWZMmXUv39/c8pjW6znytb5cNbatWsVEBAgi8WiihUr6uTJk8nqLF26VO3bt1epUqXk6+ur/Pnzq2bNmho+fLiuXLmSpv0669q1axo9erQefvhhFSxYUD4+PipRooSeeeYZ/fDDDw63bdiwoSwWixo2bChJOnLkiPr3769y5copb968slgsioyMtFn36NGj6tOnj8qUKSM/Pz+FhYXphRde0IkTJ5Ls48CBA+rRo4fKlCkjX19flSxZUn379tX58+edOr60ntvu3bvLYrEoLCxMkvTvv//qnXfeUeXKlRUYGJiua0L6v76gSZMmCg4OVpcuXSRJly5dsrnMxuzZs81rce3atSm237t3b1ksFvn4+Ng9ztT2HVYRERFmLJIUFRWlESNGqEaNGsqfP78sFotmzpxp1o+JidGiRYv04osvqnr16goKClKePHkUHBysBg0aaNy4cbp27VqKxyRJy5cvV7NmzRQcHKy8efOqfPnyGjhwoM6ePSvpztIsFoslxYSNPXv2qE+f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nj2bikiTu3jxosaPH68lS5boyJEjSf4pbKtuYsePH1dMTIzNuoULF0428GD9x3eHDh108eJFbdmyRTt37tSOHTu0efNmc2B89erVatSokbZt22ZzcFO6889LR2rXrm3+vH//fnMAIDVu376tzp076+uvv5YkvfvuuxoxYoTd+olfw2LFijm9H0ev4YwZM9S9e3en2jlw4ID5c506dRzWrVOnjlauXKnr16/r2LFj5qBDYuXKlZOvr69T+y5XrlyKg2hXr15V+fLlHdaxunr1apIyV5/bgIAAlSlTxul2HLly5Yo5mNi5c2d5eCT/bkDnzp315ptvKj4+XrNnz052HT333HP66quvFBsbq8WLF+vFF19MUj5//nxJUkhIiJmoZpURfcf999/vVBtbtmzRZ599pp9++kmXL1+2W+/uvkP6v+u1evXqNs+ZVdWqVeXt7a1bt24lK9u7d68SEhIk3TnHnTt3diru9PSbjRs3VuPGjRUdHW32Ybt27dLGjRvN5KZdu3apfv362r17t93rtUaNGjYT0KyqV69uHrd1IDstBgwYoE8++UTSnQSNKVOm2B2odtfnkCP169dX7969U6yXnmvRWfHx8dq3b58kadKkSWbiRkoy6vwUKlRIzZo108CBA5O8Z93ZJ2S09NyzSFKJEiXUtGlTrVy5UjNnzjQHka2syQA+Pj7JkmVOnDhhDtQOHjxYgwcPdirmjD6v1r60dOnSZoKULd7e3qpRo4bWr1+f5H7hbhUrVnS4P+tg7N2f01lNuXLlHH62pHQcL774oqZMmaLo6GgtWbJEXbp0McvOnj2rVatWSZK6dOnisC93hUKFCpnx2mK9f7r33nuduhezd8wxMTH67LPPtHDhQh08eNBuYrGU/P2V+JpylNgtSTVr1tT3339vs8zaf/31119OJQdIdxKFL1++bDfhKbEePXpo9OjROnbsmEaOHKmuXbvK29vb4TZZre+3SvxZlxmJI/7+/maCYmY5c+aMWrRooatXr8pisWj69Ol2E9DvlvicxMTEZMo5AgAAcAVmHAEAAMjmnnrqKeXNm1fR0dH6/vvvtXTpUl29elX+/v566qmnnGrj/Pnzadq3rW9BOmv37t2qWLGiRo0apcOHDzscgJFkJnZY9ejRQ1WrVrX5mDhxosO2ChUqpDZt2mjkyJFas2aNzp8/r3HjxpmJCgcPHjQHO21J6Z/DRYoUMX92NIjoyOnTp82kkRYtWjhMGpHc8xomlvg4Uzo/RYsWtbldYqn5B2vevHkdllsHbxzVSzzAc/dghavPbeIklfRauHChmdRg71u2hQsXVpMmTSRJc+fOTfZeq1u3rkJDQyVJ8+bNS1J2/vx589vhnTp1SjYQlhHXnTOvfUREhOrVq6evv/46xffY3X2HdCfhRpLDgU5J8vT0tDtg5s73XL58+dS8eXMNGzZMy5Yt07lz5zR9+nTz3P37779677337G6f0nvUy8vLPO609mGSzH60SpUqmjp1qsPZDdx1PkeOHGl+E3nXrl1asmSJ2rZtK+nOt7ybNGmimzdv2t0+vdeisy5fvuzUt9rvlt7zU7NmzSTf1j506JDOnTunCxcuaM6cOcmSD9zVJ2S09N6zWFkT8/7++29t3LjRfD42NtZM0mvbtm2yY86q59V6zTszaG797Hf0PnH289xRUkFW4OxxWJMP71a7dm1zxgtrQpHV7Nmzzb7A0SwvruKKe6zE9Wy9dpGRkapataqGDBmi33//PcXX9+73l/UzXUr5c91ReUZ/Dnl5eWnYsGGS7iSDTZs2LcVt3NX3pyRxcnd6PtuyqsuXL6tJkyaKjIyUJH3++eep+iJA4nOSeDYqAACArI4ZRwAAALK5gIAAtWvXTvPmzdOcOXPMwYx27drJ39/fqTYS/4N2+fLlCgsLc2o7ZwYKbLl165Y6dOigS5cuKU+ePHrllVfUpk0blS9fXgUKFDCnYT527JjKli0rSSkO0qRHQECA3nzzTQUEBKhPnz6SpG+++SbZt4GtnP0WYnoUKVJE9957r7Zs2aIff/xRH3/8sd5880279RO/hnv27HH6n5QlSpRId6x3c8X5Se/0+a7k6nPrymOzLlMjSQ888ECK9SMjI7Vx40Y1aNDAfM5isejZZ5/VqFGjtHHjRp0+fdqcyvvrr782ByxsLReREX1HSudn3bp1Gj58uCSpTJkyeuutt1SvXj2VKlVK/v7+5revhw0blmLCVXokPvZJkybpkUcecWq7jBgE9/HxUY8ePRQSEqJmzZpJkr799ltNnjzZ5rfeM6MPk+4sqbFkyRIdOHBAr732mj7//HO7dTP7c8iqePHiSb7F/OCDD+qpp57S8OHDFRERod27d+udd97Rp59+mmzbzLwWE5+fF198Ua+99ppT26X0bfaUpPZb3u7oEzKaK+9ZWrVqpSJFiujcuXOaMWOGudzF0qVLzcFvW8kAic/rsGHDnF7KzdF9oCvPa2b1KbmJ9X2+fv16RUZGmu8layLJww8/nOIMLdlFly5ddPz4cVksFvXo0UOdOnXSfffdp+DgYHl7e8tisSghIcG8ZjPqbwLr+6xatWqaO3eu09ulZvmT559/Xh9++KEOHz6sDz74QD179nS4/Iy7+v6UJE7ASU+CqbNiYmJ0/PjxdLdToUKFFO/jr169qmbNmungwYOSpBEjRqhfv36p2k/ic2JdpgsAACA7IHEEAAAgB+jatavmzZunNWvWJHnOWffcc4/5c/78+TN8KuCff/7ZXON84sSJyZbGsHL0j8j169e7PK4ePXqof//+un37to4ePWq33rlz5xy2k7jc0fTejvj6+mrlypVq0qSJtm3bprfeekuenp56/fXXbdZP/BoGBwdnSEKII4mP89y5cypZsqTduomnz07r+clM7j639hw5ckTbtm1L9XazZ89Okjgi3UkKGTVqlBISErRgwQK99dZbkv5vmZqKFSvaTEzJ7L5DkqZMmSLpTgLGtm3b7H572FH/UaBAAZ09e9Zc+sGe+Pj4JN9kTizxsefNmzfTp1C3pWnTpipZsqROnjypK1eu6NKlSzbPT0p92O3bt83zl5736IIFC9ShQwctXbpU//vf/+Tl5aUJEybYrOuOa8mR9957TytWrNDOnTs1ceJE9evXL9lyV664Fp2V+HUwDMPt58eerPY6uoIr7lms8uTJo65du2rs2LH65ptv9PnnnysgIMBMBihVqpSeeOKJZNslPq958uTJMufVel2m1KdI//fZnx0+97OC559/Xm+//bZiY2M1c+ZMRUREaNu2bTp06JCkzJltJDMcOnRImzdvliQNGTJEI0eOtFkvpc90qwsXLjhcmtDR5771fXbt2rUMe495enoqPDxczz33nE6fPq2vvvrKYTJIVu37E3/e2btPcqWdO3cmWy4xLY4fP+4wofHGjRtq1aqVdu7cKUkaOHCg3S8SOGI9J4ULF3Z66U0AAICsgKVqAAAAcoDHH39cxYoV0+3bt3X79m2FhITo8ccfd3r7GjVqmD9v2bIlzXE4+41T6ze4JKljx45261nXGs8s3t7e5j+NHR2L9Z+JzpSn5x+8gYGBWrVqlWrVqiVJGjBg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u4qMjFS7du1UqFAhHT16VFOmTNG6detUt27ddE/LbBiG1q5dq7Vr1+ree+9VmzZtVKdOHZUoUUJ58+bVxYsXtWPHDk2ZMkXHjx+XJJUqVcoc5LClZs2a2rVrl2rWrKl33nlHVatWVVRUlBYvXqxJkyZJurPMzLhx49IVe2IFChTQ2rVr9fjjj+u3335T79695enpmWTw4P3339eGDRu0fft2ffrpp1q/fr1eeuklVa9eXf7+/rpy5YoOHjyon376SStXrlTVqlXNwStXmDBhgtatW6crV66oZ8+e2rx5szp27KgCBQro0KFDGjdunPbt2ydJ6tChg5o3b+6yfWc0d5/buyVO/Hj66aed2sbX11ctWrTQ119/rbVr1+rs2bMqWrSoWV6iRAk1aNBA69ev1xdffGEmQdhbpsbKFX1HanTt2lXLly9XTEyMGjRooEGDBpkz8vz6668aP368zp49q4cffthcauduISEhCg8P15AhQ3T06FE9+OCDGjRokGrWrKnY2FitXr1aH3/8sUJCQhQTE6MLFy7YHEBo0aKFXnvtNX366afauHGj7rvvPvXp00f16tXTPffco5iYGB09elSbNm3St99+qytXrqhbt26pPuYdO3aoVatWKl68uNq2bauHH35YoaGhCgwM1H///ae9e/dq+vTp5qBtUFCQRowYYbe9atWq6Y8//tCDDz6owYMHq3bt2oqNjdWPP/6oCRMm6Pbt2/Ly8koxcSY1fHx8tHTpUrVu3Vpr167VBx98IE9PT/Nb11LmX0vOaNmypapXr659+/Zp/vz5ioiIMAf3XXEtStIjjzyiX375RTt37tTo0aPVvHlz+fv7S5L8/PxUvHhxSVKRIkU0a9YsPfPMM/r3339Vs2ZNde/eXc2bN1eJEiUUFxenU6dOaceOHVq8eLGOHTum5cuX6/7778/Qc3S3rPg6Jnbt2jW7A9SJlSpVSo899liG3LO0b99er776qqKioswErpSSAapWrapx48ZpwIAB+uOPP1SlShX16tVLjz32mIoUKaKbN28qMjJSW7du1eLFi/Xvv/9q//795gwwGcHb21uTJ09Wq1atFB0drbp162rgwIF6/PHH5enpqV9//VWjR482Z3MbN26cChUqlGHx5DQWi0U9e/bU0KFDzaVT7r33Xj366KNujsx1atSooSpVqujAgQOaNGmSrly5oi5duqhYsWI6deqU5s6dq8WLF6f4/oqIiNA333yjs2fP6vXXX9fu3bv13HPPKTg4WEePHtWnn36qX3/9VbVr1zYTHWx9rs+fP1+1a9fW5cuX1bFjR82dO1cdO3ZUuXLl5OnpqfPnz2vv3r1avny5tm3bpjfffFOtWrVK9XFbLBYNHz5cbdu2tZm8mpir+v5HHnlEx48f17JlyzRp0iTVrVvXnIUkX758Kly4cKqOoU2bNpo1a5b++ecfHT16VPfee2/qTkIW8dZbb5kzJlWpUkVDhgxJcVYnR0turVu3TpJUqFAh1atXz3WBAgAAZAYDAAAA2cIvv/xiSDIkGTNmzEj19jNmzDC3/+WXX2zWuXXrltG3b1/DYrGYde09SpcubbONt99+2+42ife7atUqw9fX127dhg0bGgcOHEjXMRuGYRw7dswoUKBAisdjfdSsWdP4+++/bbZlrRMeHm6Eh4fbbSNfvnzG+vXrbbaR+HW09Tp069bNkGSEhoba3P7ChQtG1apVDUmGh4eHMWvWrCTl0dHRxlNPPeXUsTZq1ChZ+4mvk7Sc8z179hghISEO9/vUU08ZN27csLl9gwYNDElGgwYNUtyXs3VDQ0MNSUa3bt0c1kv8+tqS3nOb0mvrrOvXrxv58uUzJBkVKlRI1bZff/21GeO4ceOSlU+ZMiXJcXh5eRnnz59Psd309h2J30/O6NGjh932PT09jU8++STFNhMSEozevXvbbadQoULGzp07jZIlSxqSjD59+thtZ/jw4YaXl1eKx+7v729cv37dqWO0unHjhlG0aFGn+7By5coZu3btstlW4vfClClT7Mbs7e1tLFiwwGYbx48fd9hHpHTer1+/bjz22GNmnREjRiQpd8XnUEpS288lft/06tUrSZkrrsVTp04ZBQsWtNmGrf5t2bJldusnfnh4eBg///xzWk6Rw/07I7P7BGdYr39nH23atDG3zYh7lr59+5r1g4KCnO4bJk+ebOTNmzfF+L29vY0jR44k2Tale5C0mjlzpuHj4+PwvfDhhx/a3d5az97nr1Vq7hGclZprPXHfcfz48TTHl5rr+/Tp04anp6dZ/4MPPkhxG2dY70nsHYuz9yyuuBfbu3evw3v1qlWrGmfOnEnxOtm3b58RHBxst53u3bsb06ZNM38/e/aszXb++usvo0qVKk71E8OHD7d77px5fWvWrJmkPUf3qunt+/fu3Wv3fZrSPbItcXFx5v2JrfNgT+L7iLTs19VS+9mQ0utaunRpQ5LRr1+/TDoCAAAA12GpGgAAAJjy5MmjiRMn6rffftMrr7yiqlWrKigoSJ6engoKClL16tX1wgsvaPHixXa/iTV69GhNmTJF9evXV8GCBeXp6WmzXtOmTbVr1y49//zzCgkJUZ48eRQcHKwGDRpo8uTJWrdunfmN6/QoXbq0zp07p59++klDhgzRE088oVKlSsnPz09eXl7Knz+/qlatqm7dumnZsmXavn273WU5EouIiNCqVavUsmVLFSlSRN7e3goLC9PLL7+sgwcPqkGDBumO3ZZChQpp3bp1qly5shISEtSjRw/NmzfPLA8MDNSSJUu0adMmvfjii6pQoYICAwPl5eWlggULqlatWurXr59+/PFHrV271uXx1ahRQ3/99ZdGjRqlOnXqKH/+/PL29lZISIieeuopLVu2TEuWLDG/4ZiduPvcWi1dutScrt7Z2UasWrRoIT8/P0m2l6t55plnzCVcpDtTbAcHB6fYriv6jtSYPn265syZo/r16yswMFA+Pj4KDQ1Vly5d9Ouvv+q1115LsQ2LxaKvvvpK33//vZo0aaKCBQvK19dX9957r1599VXt3btXNWvWNM91UFCQ3XaGDRumw4cP6+2331bNmjXNvi8wMFCVKlXSc889p1mzZunff/81z7+zfH19dfr0aW3ZskXDhw9X8+bNVaZMGfn7+8vT01P58uVTxYoV1bFjR82fP18HDhwwZ71w5MUXX9SmTZvUoUMHhYSEyNvbW8WLF1fXrl21d+9ederUKVVxOsvPz0/Lly83+8j33ntPo0aNMssz+1pyxtNPP62KFStKurOUQuLlP1xxLRYvXlw7duzQCy+8oHvvvTfF/rFVq1Y6fvy4xo0bZ842kSdPHvn5+al06dJ68sknNX78eEVGRqpRo0bpO/g0yoqvY3pkxD1L4mWMOnXq5HTf8NJLL+nYsWMaPny46tatq0KFCsnLy0v+/v4qX768nn76aX311Vc6ffp0ps0A0K1bNx06dEivvfaa7rvvPvn7+8vPz09ly5bVSy+9pL1792rw4MGZEktOExISoscff1yS5OnpmaZZq7I666xOffr0UWhoqPLkyaOCBQuqdu3aGjdunHbs2OHU0o/W2bTefPNNlStX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efPmeuONN5Sdne1ov2bOnKk777xTdevWVYUKFRQWFqarrrpKgwcP1v79+x3NOt+OHTsUFhYml8ulBx980NGsxMTEIv/mdu3a5Xi/du7cqf79++f9Ll5++eVq06aNZs+e7VhWcbXE5XIVWbus9is5OVl9+/ZVXFycQkJCVL16dbVv396jv3GrWevWrVOXLl1UuXJlBQUFKS4uTs8++6xOnTpVZI43n7/e1g2rWXbqhpUsu3XDar/s1A274yUrdcNqlp264W2/vKkbVrPs1A1v+uVt3fAmy9u64c1Y2tu6YTXLTt2wkmW3bljtl526YXfuY6VuWM2yUze87Zc3dcNqlp264U2/vK0b3mR5WzcKU9y82M5cxUqW3bmKp1lOzFWs9MvuXMVK1vmszlWsZNmdq1jJyuXtXMVKlt25itV+2ZmrWM3ytnZYPceVmZmp0aNHKy4uTsHBwapWrZoGDBigQ4cOFdsHK1m///67EhMT1blzZ1WvXl0ul0uxsbHFZljNMsboq6++0kMPPaRGjRopIiJC5cuXV+PGjTVmzBhlZGQ42q+vvvpK9957r+Lj4xUZGany5csrPj5e//znP7Vt2zZHs86XkpKS91recsstjmYVd15x+fLljvfr0KFDGjx4cN7vYqVKlXT99dfrjTfecCyrqH1zf1atWuVYvw4cOKDHHntMV155pUJDQ3X55ZerZcuWev/994v9/LKatWXLFv39739XdHS0goKCFBMTo8cee0xHjx4tMudcnp6vdmKs4UmWU2ON4rKcHGt40i+nxhrefL/g7VjDkyynxhpW+mV3rOFJllNjDU/75cRYw9Msb8ca3nz35G3dsJplp25YybJbN6z2y07dsPtdoZW6YTXLTt3wtl/e1A2rWU7VDacElFgSCvXMM89o9+7dqly5sqpWrardu3f7JOfVV1/V+PHjVbduXXXo0EFVqlRRcnKy5s2bp3nz5umDDz5Qjx49HMlKS0vTG2+8oWuvvVadOnVSlSpVlJKSoq+++kr/+Mc/9NFHH+mrr76Sn59v1i79/PPPGjlypEJDQ5Wenu748SMiIjRo0KACj1uZxHrCGKMHH3xQb7/9turWrat7771XFSpU0IEDB7RixQrt3r1bNWvWtJ3TpEkTjRw50u22Tz75RL/88os6duxoOyfX448/rgkTJqhq1arq2rWrwsPD9cMPP+id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We4888wzRpIZOXKkR/tbyVq3bp2pWrWq6dChg/n+++9Nenq6+f33383gwYON5P7em95mTZ482UgyQUFB5u9//7sZOnSouf766025cuXyJlQfffSRR1lFff46XTesfNbbrRtWxxV26obVLDt1o6gsp+uGt2Mzb+pGUVlO1w2r/bJTN4rLcrJuFJfldN0obCzti7rh6bjdibphZY5gt25YybJbNwrL8kXd8Gae5W3dKCzLF3XDSr/s1o2ispyuG0Vl2a0bVubFdmuHnTm41dphd75vpXbYzbJSO6xk2a0dTp0z8aR2WMmyWzvs9stK7bCaZad2WM1ycsyR6/xzXE4sHPE0yx2rC0fsZK1fv95UqFDBREVFmZ9//tmnWSdOnDDr1q0znTp1MkFBQWbmzJmOZd16663msssuM3/99VfeY1YWjljJKszPP/9sgoODTcWKFb36R4TnZ+3fvz+vZjz22GMF9r/nnnuMJPP+++/bznIn92+td+/elo9fXFZycrKJj483zZo1M6tWrTInTpwwe/fuNWPHjjX+/v7m+uuvt7zIvbCshQsXmsDAQOPn52fuuusu88QTT5gOHToYSaZhw4ZGkhk3bpzb41k5X213rGHn3LjVsYbd8/BWxhp2s6yMNaxk2R1rOPVdhidjDStZdscadvtlZaxhNcvOWMNqltPnNwr77skX5zc8/Z7LifMbVr5Ts3t+w0qW3fMbhWX54vyGN99Lent+o7AsX5zfsNIvO+c3nMDCkQtMSS0cyc7Ozptw3n///SW6aunjjz82ksyTTz7pyPGysrJMXFycadKkiTl9+nS+bSW5cGT16tVGkrnrrrscOd7jjz9upLNXy3CnXr16RpJJSUlxJO9cixYtMpLMzTff7Pixv/76ayPJDB48uMC2P/74w4SEhJh69eo5lpeRkWESExPNFVdcYcqVK2eqVKliBgwYYLZt22YkmVq1atk6flF/s1988YWRZB599FG3z3300UeNJI8/qC/UhSNffvmlCQoKMjVq1DC///67T7POlZqaaqKjo0316tUL/O17k5WYmGj8/PzM2rVr8z1e0gtHjPl/f9+eLrArKuvnn3/OG+i4e3+ef/75QgdBVrPOl52dbWrUqGH8/PzM7t27PTq+p1mnT582tWvXNtWrVzfp6ekFtnft2tVI8vgqRp70a8GCBaZ169YmLCzMhISEmJtuusmsWrXK3H777UaSWbp0abE5xX3+Olk3rH7W26kbVrPs1A07YxirdaO4LCfrht2xmZW6UVyWk3XDar/s1I3ispysG572y4m6cb7zx9JOjzeKyjqfE/8ix9Msu+MNK1nn8ma8UVSW0+ONorKKY3W8UVSW0+ONorLOZ3e8UVSW0+ONorJyeVs3rM6L7dQOu3NwK7XDbpaV2uHkuYXiaofVLDu1w+lzJkXVDqtZdmqH3X5ZqR1Ws+zUDm/75fSY4/xzXLnv1e233+52/5deeslIMu+++66lHHdZ7ji1cKS4rO+++85ERkaaiIgIs379ep9mnSsrK8s0btzYhIaGmkOHDtnOmjp1qpFkZs+enW8/JxaOWD3/2a5dOyPJ/Pjjj7az0tLS8mqGu8+nGTNmGMn9ohKrWe5cf/31lr4ospLVokULExISYv74448C+w8aNMhIMjNmzHAkyxhj1q5dazp16mQiIyNNUFCQ+dvf/mY+/fTTvM//9957z+3xrJyvtjtPsXNu3Oo8xU6W1XmKU+f8PZmnWMmyO09x8ruM4uYpVrLszlPs9MvqPMVKlt15ijf9cmqsUdR3T06f37DyPZfd8xtWsuye3/D2+ztvzm8UleX0+Q0730taPb9RVJbT5zes9MvJ8xve8hPKnJycHPXt21fTpk1Tz549NXXqVPn5ldyvQu69upYvX+7I8dLS0pScnKzNmzerXLlycrlceT/Tpk2TJF1//fVyuVyaN2+eI5nu5N7rLT093ZHj1a9fX9LZ+3O5k/v4qVOnHMk71+TJkyX55v5ZX331lSSpTZs2BbZFR0crPj5e27dvV1pamiN5QUFBGjlypH777TdlZmbq0KFDeuutt7R//35JUrNmzRzJcefce/y6U9w9+y4GX375pe666y5VrlxZy5YtU506dUosOzw8XNddd53279+v7du32z7epk2blJOTo+uuuy5fHcn9XX3rrbfkcrnUtWtX21nFya0nJ0+etH2sunXryt/fX5L7euLLWrJw4ULt27dP7du3V61atRw99tatW7Vz5041b95c5cuXL7A9933btGmTY5m33nqrli1bphMnTujkyZNasWKFWrZsqZ9//ll+fn5q2rRpkc/35PPXqbpRkp/1VrPs1A27/bJSNzzJcqpuOPF+eVo3PMlyqm540y9v64YnWU7VDSv9sls33Dl/LO3L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5/1/VlaWDh8+nO9v96WXXnL7r0qtZB09elTt27fXsWPHdMstt+jrr7/W119/ne94kZGRhdZDq/1KSEjQ1VdfrUaNGqlGjRpKT0/Xjz/+qFWrVikwMFDvvfdevn9dbSfLDqtZzZo1U6NGjdSoUSNVr15dR48e1YoVK7Rt2zbVqFEj7xLtTmTdcMMNGjJkiCZMmKBGjRrpjjvuUFZWlubPn69Dhw5pzJgxhf5tefsafvbZZ/rrr79011136bLLLvPJazhx4kR17txZ/fv310cffaRrrrlGKSkpedndunVTu3btHMmaN2+enn76abVt21bVqlXToUOH8nKee+45de7cuci+WTlfbXesYSXL7ljD0ywnxhqeZjkx1ijJ7xes9MvuWMNKv+yONbx5Db0da3ia5cRYw0q/nJqnePLdk1NzFE+ynJqjFJfl5ByluCwn5yglefULT/rl1BzFk345NUex8hr6eo7isVJbsoI8uf9ioLCf3r17l0iOiviX1lZ99913pn///uaqq64ykZGRJiAgwFSqVMm0adPGvPXWWz692sm5nL7iyPLly80999xj4uLiTHh4uAkICDDR0dGmS5cuBVZ2OmXPnj2mT58+Jjo62gQGBpqaNWuaRx55xOMV7lasW7fOSDLXXnut48c+V0ZGhhk7dqy55pprTPny5U1AQICpXr26uf/++82vv/7qaNbIkSNNw4YNTYUKFUxwcLBp0KCBeeaZZ9yukvWU1b/ZY8eOmUGDBpmaNWuawMBAU6tWLTN06FBz/PhxR7NyV3IW9eNElic5xa3M9TQrLS3NPPvss+amm27K+xsIDQ01V111lRk8eLDZu3evo6+hO1ZWyHqalZqaah555BGTkJBgqlSpYgICAkyFChXMtddea1544QVz8uRJx/uVlZVlJkyYYK666ioTFBRkwsPDTYcOHczy5csdzzLGmAYNGhhJlv+mrWYtXrzYdOrUyVSuXNn4+/ubiIgIc9NNN5kZM2Y4mrVkyRLTrl07c9lll5nAwEATHR1tevToYTZu3Gg7x93nr7d1w2qWnbphJctu3bCSZbduODFe8rRuWMmyWze86Ze3dcPb19CbuuFNlrd1w2qWnbrhzVja27phNctO3bCSZbduWMmyWzecmPt4WjesZNmtG970y9u64e1r6E3d8CbL27phNctO3ShKUfNiO3MVK1l25yqe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6ZVXXtHVV1+txYsXF9v+m2++WfPnz9epU6fk7+/vWccBAAAAAHAAC0cAAAAAAChBCQkJeV/iDx06VNu2bfP6WKNGjdKhQ4f08ccfKz09Xampqfr111/VqlUr5eTkaODAgdq4caPtNh87dkwdOnTQp59+qpo1a2r16tW64YYbLB/nhx9+0LBhwzRs2DAdOnRIKSkpOnbsmJ599llJZ6+4MG3atALP++ijj/Tyyy9Lku677z7t27dPKSkpOnHihN5++22tX79eb7zxhr1OnmPcuHF57Vm4cKGl544cOVKvvPKKLrvsMr322ms6cuSITpw4oVOnTmnZsmW65ppr9Ntvv+muu+7y2VU5XnvtNf3444+aMmWKjh8/rqNHj+qvv/5So0aNJElPP/20Zs2aJZfLpREjRujIkSM6evSoDh8+rKefflqS9OGHH2rEiBGFZnz22Wd65513NGHCBKWkpCglJUWHDx9Wv379JEnTp0/X0qVLfdI/d6pVq6aRI0dqw4YNOnnypI4ePapTp05px44deuyxxyRJQ4YM0aZNm/I9r0ePHoqKitLx48c1a9Yst8c+fPhw3lVYBg4cmG/b119/rV69eik7O1tPPvmkdu7cqVOnTik9PV1bt25V9+7ddeLECXXv3r3QK4/8+eefGjp0qHr37q09e/bo2LFjOnXqVJGvPwAAAAAATmLhCAAAAAAAJSg2Njbvy/WffvpJ8fHxatq0qR555BG99957+vnnn2WM8ehYqampmj17trp3766AgABJUoMGDfTVV18pLi5OZ86csf3l8759+9SyZUutWrVKV111ldasWaMrr7zSq2MdO3ZMI0aM0JgxY1S5cmVJUnh4uEaNGqW77rpL0tkFC+cyxuT1oX379poxY4aqV68uSQoODlb//v31xhtvKCUlxdsuFnDdddfpzjvvlCQNHz7c4/dj165dGjt2rEJCQrR48WI9/PDDqlixoiQpMDBQrVu31ooVK1SjRg1t3LhRn332mWNtPldaWpo++OAD9enTJ+9WR5UqVVLFihW1f/9+TZo0SdLZK6qMHj1akZGRkqSoqCj997//1ZAhQyRJEyZM0B9//OE2IyUlRW+99ZYGDx6s8PDwvIx33nlHf/vb3yQVfC99acCAAUpMTNTf/vY3lStXTpLkcrlUu3Zt/e9//9PDDz+s7Oxsvfbaa/meFxISot69e0uS3n77bbfHnjZtmk6fPq3LL79cnTt3zns8JydHjzzyiHJycvTaa69p/PjxebeBcrlcql+/vj7++GN17txZx48f14QJE9wePyMjQ126dNGUKVNUs2ZNSZK/v7/q1q1r+3UBAAAAAMATLBwBAAAAAKCEvf766xoxYoRCQ0NljNGmTZv0+uuv65///KcaNmyo6OhoDRkyRH/++WeRx2nRooVuvvnmAo+HhIToiSeekCQtXLhQqampXrXz119/1Q033KBffvlFLVq00KpVq1SjRg2vjiVJQUFBevzxx91uy73tzY8//pjv8c2bN2v79u2Szl4p49xbruTq3bu3atWq5XW73BkzZoz8/f21efNmjxdATJ06VdnZ2brlllvUuHFjt/tUqFBBXbt2lSQtWrTIqebmc9VVV+mOO+5wu23OnDk6c+aMgoODC70VzzPPPKOgoCBlZWXpk08+cbtPzZo18xZcnC93ccX572Vp6tSpkyRp9erVBbbl3q5m7dq1+umnnwpsnzx5siTpH//4hwIDA/MeX7lypZKTk1W5cuW8xWDu9OrVS1LR7/fw4cM96AUAAAAAAL7BwhEAAAAAAEpYQECARo8erf379+v9999Xv3791Lhx47wrJRw6dEgTJ07U1VdfrfXr1xd6nLZt2xa7LScnx6vb1SQlJally5bau3evunTpom+++UZRUVGWj3Ouq666SmFhYW63VatWTZJ09OjRfI/ntj0wMLDQ2+O4XC61atXKVtvOFx8fr759+0qSRowYoaysrGKfk5SUJElavHixoqOjC/2ZMmWKJGn37t2OtjlXixYtCt22YcMGSWdvmZR7pZDzRUVFqVmzZvn2P9+5t1w6X2Hvpa/t2LFDjz/+uP72t78pMjJS/v7+eVf/uO222ySdvYLO+erXr682bdpIkt55551821atWqWtW7fK5XKpf//++bblvt+pqamqVq1aoe937vMKe79DQkLUtGlTe50HAAAAAMCGgNJuAAAAAAAAZVVERITuv/9+3X///ZLO3rJi9erVeuWVV/T555/r8OHD6tatm5KTkxUcHFzg+bm3bHHn3G2HDh2y3LZnnnlGktSoUSPNmTNH/v7+lo9xvgoVKhS6LfdWO2fOnMn3+F9//SXp7G1QchfWuFPUa+GtxMREzZw5Uzt27NCbb76pf/3rX0Xuf+DAAUlSenq60tPT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",
      "text/plain": [
       "<Figure size 2200x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot spike rates as a comparison bar chart\n",
    "\n",
    "MODEL_NAME = 'Meta-SpikeFormer'\n",
    "DATASET = 'Tiny ImageNet (T=2)'\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=(22, 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",
    "# increase tick size\n",
    "ax.tick_params(axis='both', which='major', labelsize=14)\n",
    "\n",
    "ax.set_title(f'{MODEL_NAME} Average Spike Rate Per Layer on {DATASET}', fontsize=20)\n",
    "\n",
    "ax.set_xlim(0, n_layers + 1)\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
}
