{
 "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 ITLIFDVSGestureNet, ITQIFDVSGestureNet\n",
    "\n",
    "from Datasets.DVS128Gesture import DVS128Gesture\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": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The directory [../../data//dvs128_gesture/frames_number_10_split_by_number] already exists.\n"
     ]
    }
   ],
   "source": [
    "model1 = SpikingConvolutionNetwork(\n",
    "    encoder=IdentityEncoder(),\n",
    "    snn=ITQIFDVSGestureNet(num_classes=11, 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=ITLIFDVSGestureNet(num_classes=11, method='asym_rectangle'),\n",
    "    decoder=decode_mean,\n",
    "    seq_length=10,\n",
    "    input_scale=1.0\n",
    ")\n",
    "\n",
    "dataset = DVS128Gesture(\n",
    "    root='../../data/',\n",
    "    train=False,\n",
    "    download=True,\n",
    "    transform=tonic.transforms.Compose([\n",
    "        torch.from_numpy,\n",
    "        # transforms.Resize((64, 64), interpolation=transforms.InterpolationMode.NEAREST),\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/DVSGesture/'\n",
    "\n",
    "LIF_weights = 'LIFVGGSNN_DVSGesture_(2024-09-03)_(01-06-18)'\n",
    "\n",
    "QLIF_weights = [\n",
    "    'QLIFVGGSNN_DVSGesture_(2024-08-27)_(18-42-23)',\n",
    "    'QLIFVGGSNN_DVSGesture_(2024-08-31)_(10-15-37)',\n",
    "    'QLIFVGGSNN_DVSGesture_(2024-08-31)_(10-47-52)'\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": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded from ../../SNN/output/DVSGesture/LIFVGGSNN_DVSGesture_(2024-09-03)_(01-06-18)/LIFVGGSNN_DVSGesture_(2024-09-03)_(01-06-18).pth\n"
     ]
    },
    {
     "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"
     ]
    }
   ],
   "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/DVSGesture/QLIFVGGSNN_DVSGesture_(2024-08-27)_(18-42-23)/QLIFVGGSNN_DVSGesture_(2024-08-27)_(18-42-23).pth\n",
      "Loaded from ../../SNN/output/DVSGesture/QLIFVGGSNN_DVSGesture_(2024-08-31)_(10-15-37)/QLIFVGGSNN_DVSGesture_(2024-08-31)_(10-15-37).pth\n",
      "Loaded from ../../SNN/output/DVSGesture/QLIFVGGSNN_DVSGesture_(2024-08-31)_(10-47-52)/QLIFVGGSNN_DVSGesture_(2024-08-31)_(10-47-52).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",
    "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.27199894858095053\n",
      "Mean Spike Rate of QLIF: 0.13198196292259382\n",
      "QLIF spikes 51.477031947675265% 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.094755549043973 mJ\n",
      "QLIF energy: 0.7244620795049719 mJ\n",
      "Times Difference: 1.5111288499627535x\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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p59+ynA5Bw8eNJ9//rnDaXFxceb222+31tO9e3cTExOT4fL2799vunTpYiSZo0ePOvVa8pKz79v1KmWvv2LFilk9wy5cuJDuPNd7j9vDhw8bDw8PI8mMHz/e6t3Su3fvHF8X8taTTz7pdG+bEydOmIkTJ+ZNYQ5cbz1u09uehw8fNsHBwVa7LVu25Fo97tzjNr3jYVJSkmnXrp3Vrl+/fnlboAvocYub5bx1+fLlZvLkyWb79u1Wb+FOnTplqcdt586dzWeffZbu1Urx8fFWz2FJZtasWQ7b9e7d22ozYMAAh20+/vhjq03Lli0zrS0z0dHRpmTJktYyhw4dmulVVzt37jStWrUyvr6+2V5/TqPHLQBjjGGMWwC57o477lBkZKRq1aolSYqMjNQnn3ySqs3zzz9v/Xvu3LlOLdfeLjg4OE2vqa1bt0q62ivioYceynA5ISEh6tq1q8NpAwcO1J9//ilJevHFFzVlyhQFBQVluLyKFStq+vTpWrp0qQoUKODUa0HueP311yVJx44d06RJk/K5mtwzd+5cJScny8vLS88//7zatWsnSfrqq68Yb/k6lpSUZPX2rF27dqY9gYoXL67evXvnQWU3tnLlyumll16y/r9q1ap8rMb9eHh4aMyYMdb/ly9fno/VADnvej5vbdasmXr06KFatWrJy8u1i2tnzJihF154Qb6+vg6n+/v7p7p/wIIFCxy2s/cMttlseuuttxy26dOnj4oUKSJJ2rBhg0v1ptS9e3cdP35ckjR27FiNGDEi3ddhd9ddd2np0qWaOnVqttcPALmB4BZAnvDz89OcOXOsu42PHz8+VaDUqFEjVahQQZI0f/78TMOmTZs26e+//5YktWvXLlVA+u+//1r/vvXWW12u+fjx4/r8888lSeXLl9f48eOzNH+rVq1UqFChDNssXrxY7dq1U4UKFVSgQAEVKlRItWvX1ogRIzK98cvff/+tl156SdWqVVPBggXl4+OjMmXKqGbNmuratavmz5+vhIQEq7395ix2I0aMSHOTjpTBUMqb+GR044jM7jTfuXPnVDeFOXr0qAYOHKg777zTupnWL7/8kmqepKQkzZo1S48++qjKlCkjX19fFS1aVPXr19cHH3xgXXaXmSeffFJ33XWXpKsn8PHx8U7Nl56YmBiNHj1a9erVU/HixeXj46PSpUurVatWWrBg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dn366afl6emZ7nRn2I8PNpvNYc127dq1U3BwcKp5HHn44YdVokQJh9MKFiyoypUrS5L279/vaskuuZ7OW/PCn3/+qS5dukhKewM3R6KjozVjxox098ddu3Zp5syZ6d7gz1kp35vMzttffvnldM/bJ02alKptTpyb2s/b//jjD23evDlLrys/+fj4WOeJjtg/l6pUqZLqhp6O2LfNli1buFEZ4AKCWwB5KuWJlaM7zBYpUkQtW7aUJK1bty7N3aq/+eYbJSQkSMr87q82m01PPfWUIiIidOLECS1evFhvvvmmHn74Yfn5+VntVqxYocaNG6e5+3fBggUlXf2SllNS3vG5dOnSae4Om/Jh/zIsybrLvSQ99thjKlSokCSpTZs2atKkicLDw7Vt2zYlJSXlWK05LTAw0LpzsCP2bXPhwgV5eXlluG0effRRa76U2yYjDz/8sBo0aCBJ+vjjj3X69Gmn5rPXtWLFigxrstlsGj9+fJZqyo6zZ89aXwbbt28vD4+0H+nt27e3vpzbQ96U7KFIQkKCFixYkGb6l19+KUkqU6aMGjdunGpayn35gQceyHC7pPzim9G2ueuuu9KdllJkZKSefvppFS1aVCVKlNBtt92W6ovX1KlTJV29o/u1fvvtN0lSzZo1HW4zu+rVq1tfxq8VFRWl5ORkSVe3cWb7hb2O7OwXDz/8sH788UedPn1aP/zwg0aMGKFWrVpZgYh09T1p0KCBjh49mu5yatWqlSb8TalmzZrW687sbvAZ6du3r4YMGSLpakD6zTffpBs45sa+lF0NGjRQjx49Mm2XnX3RWUlJSdqxY4ck6bPPPst0f7P/LefW9ilWrJiee+45bd26VZ06dbKez89jQm47deqU3njjDVWpUkUFCxZUxYoVVa1aNet9tp+32Nteq1y5cmrWrJkkaebMmWmmz5gxQ5Lk6+ubJqw+dOiQFdINHjw40/ff/j7k9na1H0srVqyY4Y+aPj4+qlWrVqp5HKlatWqG6ytSpIgkx+FpbrqezltzW3R0tFq0aKHz58/LZrNp+vTpuv3229Nt/+eff+ree+/Vl19+qYCAAE2aNEmHDx/W5cuXdezYMc2ePVtly5bV999/rwceeEBr165NNX98fHyqH8KufaRkP2e3z5dTcuLctH379vL29lZCQoLq1aunVq1aafLkyfrtt99kjMmxWnNa5cqVVaBAgXSn27fNX3/9lelxqU+fPpKudkY5c+ZMntQP3EgIbgHkqZRfaOwn4dey93QzxuiLL75INc3em8HX11dPP/200+stVqyYWrdurbffflsrV67UiRMnNH78eOuE5Pfff9eHH36Yap6iRYtKutpD8/Lly+ku+8MPP5S5OvSMjDE6cOBAum1PnDjhdM0pXbhwIVVdS5cuVdmyZWWM0Zo1a9SvXz/Vrl1bRYoU0RNPPKHvv//epfXkJnvYnJ6c2DaZGTVqlKSrX8Tee+89p+ZxpS57L9Xc9NVXX1n7pb1n7bVKlCihpk2bSpLmzp2b5gtCvXr1FBISIklp/tZOnDhh9Y565pln0oScufF+FS5cONP5hw8frvr16+vrr7/O9OTf0ftw9uxZScq097Snp2e6x6i82FfTExQUpEceeURDhw7V0qVLdfz4cU2fPt3adkePHrUCU0fS69Fm5+XlZb3u7Hy5sh9Pq1WrpmnTpmXYuy+/tufbb7+t3bt3a/fu3dq6dasWLlyoxx9/XNLVnkRNmzbVpUuX0p0/u/uis86cOeNSD6Xsbp/atWtb22f37t3as2ePjh8/rpMnT2rOnDlpwr/8Oibktm3btqlq1aoaPXq0/v7770yDlvTe627dukmS/vnnH0VERFjPJyQkWD+SPf7442les7tuV/s+n9kxRZJKlSqVah5H/P39M1yG/TMor3+gvp7OW3PTmTNn1LRpUx08eFCSNGHCBD3zzDMZzvP888/rv//+k7+/v9atW6devXqpXLly8vb2VsmSJdWxY0dt3LhRJUuWVGxsrDp06GCF3NLV3pnp9Yy9todncHCw9aNkZr2RFy9enOq8fc2aNem2zYm/v6pVq2revHkqXLiwrly5ou+//169evVS9erVVaJECXXs2FHr1q1zaT25KbPjRH6eCwE3m/S7XABALoiKirL+XaVKFYdtWrZsqaJFi+r06dOaM2eO3njjDUnSwYMHtX79eklXLxfNzhePwMBA9e/fX4GBgerZs6ekq70i3nrrLatNjRo19M8//yg5OVm7du1S7dq1XV6fXcovHNu3b091eWVGypUrl+r/DRo00L59+7Rw4UL98MMPioiI0JEjRxQbG6tFixZp0aJFatasmb799ttMvwzllcwuy7Rvm2LFimV4En2tihUrOt02LCxMTZo00c8//6yJEyeqX79+KlmypFN1PfLII06HvXkhZQ/au+++O9P2Bw8eVEREhMLCwqznbDabOnTooNGjRysiIkL//fefypYtK0n6+uuvrbDI0eXKKffl7777TqGhoU7VndGX/Mz2kdWrV2vEiBGSpEqVKum1115T/fr1VaFCBQUEBFhf2oYOHWqF9Lkh5Wv/7LPPVLduXafmy40QytfXV126dFGZMmXUvHlzSdK3336rKVOmOOxRnNElrTmpbdu2WrhwoX777Te98sormjBhQrptc2NfckbZsmVTXdlwzz336IknntCIESM0fPhwbdu2TQMHDtRHH32UZt683BdTbp9u3brplVdecWq+9HqMOysgICDV9slMfhwTctvly5f11FNP6fTp0/L29tZLL72k1q1b67bbblPhwoWtXuT79++3LoFPL9ht1aqVSpYsqePHj2vGjBnWpcOLFy+2flByNORAyu06dOjQDC9dTimjy8Vzcrvm1TElv1xP56255fz582revLl+//13SVd/BO/du3eG8+zcudPqkfnss8+m2zO3dOnSeumll/TWW28pOjpay5cvz3A4n4zcdddd2r59u44cOaJTp05ZwxRlR06dm7Zt21YPPfSQ5s+frxUrVmjdunU6efKkTp06pblz52ru3Lnq1KmTpk+fnuHVQHnJ2fP2GjVqaO7cuU4v136eCcB5BLcA8tRPP/1k/bt+/foO23h7e+uZZ57RJ598oj179mjr1q2qXbt2qh6DGY0/mRVdunRRnz59dOXKFe3bty/VtLCwMH377beSpOXLl+dIcGvvxStd7fF3bSCbFQUKFNCzzz5rhWoHDhzQsmXLNGHCBP39999asWKF3nzzTYWHh7u0/JQnjvbLwh3JqUvS7Nvm/Pnzuv3223PtC/uoUaP0888/68KFCxozZkym26do0aKKjo7W5cuXsxRi5Ka9e/dq48aNWZ5v9uzZqYJb6eoXqtGjRys5OVnz5s3Ta6+9Jun/hkmoWrWqw2A45b5cqFChPNk29svOCxcurI0bN6bbazajXl2FCxfWsWPHMu2Rk5SUZIUp10r52v39/d1iv2jWrJnKly+vw4cP6+zZszp9+rTD7XP8+PEMl3PlyhVr+6XXu8wZ8+bN01NPPaXFixdr4sSJ8vLySvdvLT/2pYwMGTJEy5Yt05YtWzRp0iT17t1bt912W6o2ObEvOivl+2CMyfft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796dps3hw4et4Xf8/f3TDafdzfV83poTjDHq3r27FixYIOnq+KwzZszIUu/PWrVqWWOZLly40Oq5fK3t27dr8uTJkq7uI02aNMlW7VOnTrWugnjttdc0atSoTK+WyugcMCfOTRcvXpzhOcLhw4e1Z88eSWnP24sWLWqNV57Z50TdunWtHxfCw8Md/iAwbtw46ztCdjVt2lT33nuvtdzMrvLbvXt3hj8cA8iAAQAXrFmzxkgykkyvXr3M7t27rcfGjRvNjz/+aMaOHWuaNm1qbDab1fb+++83J0+edGodhw4dSjWvJHPHHXdkOt/u3but9rfeeqvp37+/+frrr82vv/5qduzYYVatWmXeffddU7FiRatdhQoVzLlz5xwub+/evaZy5cpW22LFipmXXnrJfPPNNyYyMtLs2LHDREREmOnTp5sOHTqYAgUKpNo217p06ZK57777rDY1atQwEydONOvXrzdRUVHm559/NhMmTDCtW7c2Pj4+5p577kk1f6dOnYy3t7dp0aKF+fDDD82qVavM9u3bzdq1a80nn3xibr/9dmvZ4eHhadb/7LPPGknG19fXTJ482ezevdvs3bvX7N271xw/fjxV28GDB1vLqlu3rlm8eLHZvn27+fHHH03Xrl2Nh4eHqVu3rtVmxowZadbXqVMnI8mEhIRk+t6dPn3aVKpUyVpew4YNzbRp08yGDRvM9u3bzU8//WTGjx9vHnroIePh4WHatm2bZhnDhg2z5j9w4EC664qKikqzf4WFhTlsu2HDBuPr62skGU9PT/Pss8+ab775xmzdutVs3rzZLFmyxAwdOtRUr17dSDITJkxIs4w333zTWs/o0aPNjh07rO1+5MiRTLeNXdeuXa3l7N692+n5nnrqKav+o0ePppneqFEjI8kUKlTIWv7EiRMzXGZycrJp06aN1f6WW24x7733nvnll19MVFSUWbt2rfnss89M+/btTUBAgClatGiaZaR8vzLzzTffWG3LlCljPv74YxMZGWkiIyPNuHHjTOnSpY3NZjMPPPBAhst89913U/3tT5o0yWzevNmsW7fOvPXWW8bPz8+Ehoaa4sWLG0mmc+fODpfzyiuvWMspVaqUGT58uFm1apWJiooy69evNzNnzjT/+9//TOHChY0kc/78+UxfY0rnz5+3ll+2bFnTu3dvM3fuXLNu3TqzY8cO88sv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ezVjxowMlxkTEyNJCg4Odjg9KCgoVbtrjR49WsHBwdajfPny2awcAAAAAAAAAJznlZ2Z77zzTq1fv16fffaZBg8erEceeUTt27dXeHi4ihcvnlM1SpI2bNig8ePHa/jw4apWrVqOLvtagwcPVr9+/az/x8bGEt4CAAAAAHJc6KBl+V1Crjg4pmV+lwAA1z2Xetxeq0ePHvrzzz/Vrl07ffnll6pataqmT5+eE4uWJF25ckWdOnXSXXfdpUGDBmXa3t7TNr0etfahD9Lrkevr66ugoKBUDwAAAAAAAADIK1nucRsREaGVK1fq5MmTKl68uB5++GGFhYWpZMmS+uqrr9SpUye9+OKL6t69u2bPnq0pU6botttuy1aRcXFx1ni0Pj4+Dts88MADkqRFixZZNy1LbwzbzMbABQAAAAAAAID85HRwm5SUpA4dOmjBggWSJGOMpKvjwT7xxBP66quv5OnpqUceeUR//PGHhg4dqo8++kg1atTQoEGD9MYbb8jb29ulIn19ffW///3P4bSIiAjt3btXjz32mIoXL67Q0FBVrlxZZcqUUWRkpOLj4xUQEGC1j4+PV2RkpCpWrMjwBwAAAAAAAADcktNDJYwZM0bffPONAgIC9Oqrr2rSpEnq27evAgMD9e2332r06NFWWz8/P40bN06bN29W9erVNWLECNWoUUMREREuFenn56dp06Y5fNStW1fS1XFpp02bppo1a8pms6lbt26Ki4vTqFGjUi1r1KhRiouLU/fu3V2qBQAAAAAAAABym9M9bmfPni2bzabvvvtOYWFh1vOtW7dWo0aNNHv2bL311lup5qlZs6Y2bdqkCRMm6K233lKTJk105cqVnKs+A6+//rqWLFmisWPHKioqSnfffbe2b9+ulStXqk6dOnr11VfzpA4AAAAAAAAAyCqne9wePHhQAQEBqUJbSWrYsKECAgL077//OpzPZrPp5Zdf1h9//KFWrVplr9osCAgI0Nq1a/Xqq6/qzz//1Pvvv689e/aof//+Wr16tfz8/PKsFgAAAAAAAADICpuxD1abidKlS+vEiRP6999/VbZsWev5I0eOqEKFCipZsqSOHj2aa4Xmp9jYWAUHBysmJkZBQUH5XQ4AAAAA4AYROmhZfpeQKw6OaZnfJQA37t9XgQ75XULuGB6T3xXkiazkjE73uG3RooWMMXrssce0fPly/f333/rxxx/VunVr2Ww2PfLII9kuHAAAAAAAAACQhTFu3333Xf3yyy+KiopSy5b/98uZMUYhISF69913c6VAAAAAAAAAALjZOB3clixZUtu2bdMHH3ygVatW6dSpUypatKgefvhh9e3bV4ULF87NOgEAAAAAAADgpuF0cCtJhQoV0siRIzVy5MjcqgcAAAAAAAAAbnpOj3ELAAAAAAAAAMgbBLcAAAAAAAAA4GacCm7HjRunixcv5uiKt27dqh9//DFHlwkAAAAAAAAANwKngtuBAweqUqVKCg8P17lz57K1wvXr1+vRRx/Vfffdpy1btmRrWQAAAAAAAABwI3IquH3jjTcUGxur1157TaVLl9aTTz6phQsX6sSJE5nOm5iYqC1btmjIkCG65ZZbFBYWph9++EF16tTR448/nt36AQAAAAAAAOCG4+VMo7ffflu9evXSG2+8oS+//FLffvutFi1aJEkqX768atSooeLFi6tIkSLy9fXV2bNndebMGe3fv187d+7U5cuXJUnGGN1yyy0aNWqUnnnmmdx7VQAAAAAAAABwHXMquJWksmXLatasWRo9erSmTJmi6dOn68iRI/r333/177//ymazpZnHGHN1JV5eatmypXr06KFmzZo5bAsAAAAAAAAAuMrp4NauTJkyGj58uIYPH67ffvtNERER2rRpk6Kjo3Xy5EldunRJRYsWVfHixXXHHXeoYcOGqlevngoWLJgb9QMAAAAAAADADSfLwW1K1apVU7Vq1fTiiy/mVD0AAAAAAAAAcNNz6uZkAAAAAAAAAIC8Q3ALAAAAAAAAAG6G4BYAAAAAAAAA3AzBLQAAAAAAAAC4GYJbAAAAAAAAAHAzBLcAAAAAAAAA4GYIbgEAAAAAAADAzRDcAgAAAAAAAICbIbgFAAAAAAAAADdDcAsAAAAAAAAAbsYrJxaya9curVixQocOHdLFixf1+eefW9MSExN18uRJ2Ww2lS5dOidWBwAAAAAAAAA3tGwFtzExMeratasWL14sSTLGyGazpQlua9SoobNnz2rnzp268847s1UwAAAAAAAAANzoXB4qITExUY888ogWL14sf39/tWzZUgUKFEjTzt/fX126dFFycrIWLFiQrWIBAAAAAAAA4GbgcnD7+eefa+PGjapUqZL++usvLV26VMHBwQ7btm3bVpIUERHh6uoA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rfLly+vq1auODgdweQEBARozZkyh46GhoXc8FqAsMQxDzz33nBYtWqSwsDD17dtXfn5+Onv2rL7++mudOnVKNWrUcHSYsAM2J0OZtXXrVtWqVUshISGaPn26JkyYoCVLligiIsLRoQEubePGjQoODlabNm0KHN+9e7c6dOggX19f/d///Z88PT0dFCHgunJzc5WTk6Ny5coVOJ6Tk6NOnTpp586d+u9//6uuXbs6KEKg7MjOzlazZs3k4eGhWrVqaeXKlfrmm2/UrFkzR4cGuKS85OzJkycdGgdQFs2ZM0djxozRqFGjNHfuXLm5uRVoz8nJkbs7azPLIpZroMzq2LGjQkJCHB0GUOb06NGjUNJWklq1aqV27dopOTlZR44ccUBkgOszm82FkraS5O7uru7du0uSTpw4cafDAsqkN954Qz/99JM++OCDQv8ABgDAWaSnp2vq1Km67777NGfOHKs/s0jall08WQBAqfHw8JDELw5AacvNzdUXX3whSapXr56DowFc3w8//KA33nhDMTExeuCBBxwdDlBmZGZmaunSpTp79qz8/f3VpEkTPfroo44OC3BpW7ZsUXJysiIjI3X9+nV9/PHHOn78uAIDA9WxY0fVrFnT0SHCjviXNQCgVJw+fVpbt25VlSpVVL9+fUeHA7i0rKwsTZs2TYZh6OLFi9q2bZvi4+MVGRmpDh06ODo8wKVlZmZq4MCBatSokV555RVHhwOUKefOnVNkZGSBY02aNNGHH36osLAwB0UFuLbvv/9ekuTm5qYGDRro+PHjljaz2ayXXnpJb7/9tqPCg52RuAUAlFh2draeffZZZWZmasaMGXzkFCihrKwsTZ061fK9yWTSuHHj9OabbzowKqBseO2115SQkKDvv/+en1dAKYqMjFSrVq1Ur149+fr66vjx45o9e7ZWrFihDh066MiRI/Lz83N0mIDLuXDhgiRp9uzZevjhh7V//37VrVtXBw8e1PDhwzVr1iyFhYVp5MiRDo4U9kCNWwBAieTm5ioiIkK7du3SsGHD9Oyzzzo6JMDl+fr6yjAMXb9+XYmJiZo3b54WL16stm3bKi0tzdHhAS7rm2++0dtvv61JkyZRdgQoZdHR0Wrfvr3uuusu+fj4qFGjRlq+fLmeffZZnTp1Su+9956jQwRcUm5uriSpXLly2rRpk5o0aSJfX1+1atVK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2rx5s5o3b64PPviglCKVMjIy9Mwzz2jBggUKCgrS1q1bbynx/FczZ85Up06d9PnnnysnJ0dZWVmKj4/XlClT1KVLF12/ft3qeePGjVO3bt20Y8cOpaamysPDQ8eOHdOrr76qjh07Kjs7u6S3KEnq0qWL2rRpI0mFVkPfitzcXI0ePVotW7bUqlWrdPr0aXl4eOjq1av67rvvNH78eDVu3FinTp0qlXitycjIUNu2bTVu3Dj9+OOPMpvNBTb7ysrKUt++fdWzZ099+umnSkpKkq+vr5KSkvTpp5+qR48e6t+//01f0xdeeEG9evXS7t27ZRiGpczHmDFjFBkZabf7s2bOnDkaOnSo1q1bp59//tly/PTp0/rwww/VvHlzzZ07t9B5zz33nCRp1apVunbtms3x33vvPUlSx44ddd999xVoW7VqlerUqaM5c+bo2LFjysnJkST98ssvmjt3rurVq6ctW7bcNP4OHTpo8+bNSk9Pl5ub263dOAAAwF+QuAUAACimJk2aWJJoefVti2vq1Km6cOGC1q5dq6tXryo1NVXHjh1TmzZtlJubqxEjRuiHH34occwpKSkKDw9XbGysatSooT179qh58+a3Pc6PP/6o8ePHa/z48bpw4YKSk5OVkpKi1157TdKNFYfLli0rdN6aNWs0a9YsSVL//v115swZJScn6/Lly1q0aJH279+vd999t2Q3mc/06dMt8XzxxRe3dW50dLTmzp2ru+66S/PmzdPFixd1+fJlpaena8eOHXrooYf0yy+/qEePHnZblTpv3jwdPnxYS5YsUVpami5duqQ///xTDRo0kCRNnDhRH330kUwmkyZPnqyLFy/q0qVLSkpK0sSJEyVJH374oSZPnmzzGh9//LHee+89zZ49W8nJyUpOTlZSUpKGDh0qSVq+fLm2b99ul/uzpmrVqoqOjtaBAwd07do1Xbp0Senp6frtt980evRoSVJUVJQOHjxY4Lw+ffooKChIaWlp+uijj6yOnZSUZFmFPGLEiAJtX331lQYOHKjr16/rlVde0e+//6709HRdvXpV8fHx6tWrly5fvqxevXrZXHl7/vx5jR07VoMGDdLp06eVkpKi9PT0Il9/AAAAmwwAAAAU27BhwwxJhiTDZDIZDz30kDFq1Cjj/fffN44cOWLk5uYWeX5ISIjl/K1btxZqv3btmlGrVi1DktGlSxeb5y9ZsqRQW964O3bsMAzDMBITE40HH3zQkGQ8+OCDRmJiotWYlixZYkgyQkJCCrVFR0dbxo2OjrZ6fo8ePQxJRseOHQscz83NNWrWrGlIMjp16mT1tcm7tiSjTZs2VscvSl58+WPv3r27Iclo1KhRgWv+/vvvhV6j/G1ubm6Gt7e3cejQIavXSktLM6pXr25IMmJjYwu0tWnTpsjXKH+s1u4z73xJxscff2z1/DNnzhju7u6GJGPChAlW+0RFRRmSDA8PD+Ps2bMF2gYNGmS5hrX3j2EYxiOPPGJIMoYOHWrzPmzJ/14pTc8//7whyRgyZEihtjFjxhiSjGbNmlk99+233zYkGXfffbeRlZVlOX79+nXLPFu4cKHNaz/11FOGJGP06NEFjud/3/bo0aN4NwYAAPAXrLgFAAAogfnz52vy5MkqX768DMPQwYMHNX/+fA0ZMkT169dX5cqVFRUVpfPnzxc5TosWLdShQ4dCx729vfXyyy9Lkr744gulpqYWK85jx46pefPm+umnn9SiRQvt3r1b1atXL9ZYkuTp6alx48ZZbcsru3D48OECxw8dOqQTJ05IurFSNP9H/vMMGjRI99xzT7HjsmbatGlyc3PToUOH9OGHH97SOUuXLtX169f12GOPqWHDhlb7+Pn5qVu3bpKkL7/8srTCLeDBBx/Uk08+abVtw4YNysnJkZeXl81SEJMmTZKnp6eys7NtbtBWo0YNDRo0yGrbU089Janws3Skrl27SpL27NlTqC2vXMK3336rI0eOFGpfvHixJGnw4MHy8PCwHN+1a5cSEhJUsWJFy0pjawYOHCip6Oc9YcKEW7gLAACAmyNxCwAAUALu7u6KiYnRH3/8oRUrVmjo0KFq2LChypUrJ0m6cOGC3nnnHdWrV6/IDbLat29/07bc3NxilUuIi4tTy5YtlZiYqKefflpbt25VUFDQbY+TX97GTdZUrVpVknTp0qUCx/Ni9/DwsFmewWQyWerSlpY6depY6rROnjz5lmroxsXFSZK2bNmiypUr2/xasmSJJNmtzm2LFi1sth04cEDSjZId/v7+VvsEBQWpcePGBfr/Vf6SH39l61na22+//aZx48bpkUceUWBgoNzc3GQymWQymdSlSxdJ1utK165dW+3atZP0v1q2eXbv3q34+HiZTCYNGzasQFve805NTVXVqlVtPu+882w9b29vbz388MMlu3kAAID/z93RAQAAAJQFAQEBGjBggAYMGCDpxqZSe/bs0dy5c/XJJ58oKSlJPXv2VEJCgry8vAqdX61aNZtj52+7cOHCbcc2adIkSVKDBg20YcOGUtksyc/Pz2abu/uNXzHzNnbK8+eff0qSgoODLYlta4p6LYprypQpWrVqlX777TctWLBAL774YpH9z549K0m6evWqrl69etPxi9oMqyTuuusum21574WbvV55K6ttvXdu5VmW1oZxtyI2Nlb9+vVTZmam5Zi/v7+8vLxkMpmUlZWl5ORkm8/lueee044dO7Ry5Uq99dZblvm2aNEiSVKnTp107733Fjgn73lnZ2ffdHW8JKWnp1s9HhwcLLOZtTEAAKB08FsFAACAHXh5ealjx476+OOPLR9DP3PmzG1vkFUa+vfvL5PJpMOHDzvFJkm2VnfaU7Vq1SzJ2tdff11Xrlwpsv/169clSa+++qoMw7jp186dO+0Sd2kk2V3JxYsXFRERoczMTLVv3147d+7UtWvXlJqaqvPnz+vcuXNat25dkWN0795dd999t5KTk7V27VpJUnJysqVUxPDhwwudk/e8H3300Vt63oZhWL323+15AQAA+yJxCwAAYGf5E0W//PKL1T5//PGHzfPztxW1AtOWYcOGaeHChTKZTHrzzTf1yiuv3PYYpaFSpUqSpKSkJGVlZdnsV9RrURLjx49XUFCQLly4oFmzZhXZt3LlypKKXwIhb6VqRkaGzT7FrVecJ++9YK1kQH557cV579xpn332mdLS0hQUFKRPPvlEbdq0kbe3d4E+586dK3IMDw8PDRkyRNL/yiWsXLlSGRkZqly5sqVub34lfd4AAAD2QOIWAADAzvLXgvX09LTaZ8eOHTbPz2szm8166KGHihXDsGHD9P7778tsNmvmzJkaO3ZsscYpibzan9nZ2dq7d6/VPoZhaNeuXXa5flBQkGUTr1mzZllKN1iTV1t269atRSZfi7qWJCUmJtrss2/fvtseN7/8tWttJYFTUlIK1MJ1dnmvV+3ateXj42O1z9atW286zvDhw2U2m7Vnzx79/PPPlgRuZGRkgU3J8uQ973PnztmsBQwAAHCnkbgFAAAopt9//13Hjx+/ab9ly5ZZ/mxr46I9e/ZY/bh9RkaGZXVo586dFRgYWKxYpRtJqyVL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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 = 'DVSGestureNet'\n",
    "DATASET = 'DVS128-Gesture'\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
}
