{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "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 ITQIFResNet19, ITLIFResNet19\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": 9,
   "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": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of parameters: 12630858\n",
      "Files already downloaded and verified\n"
     ]
    }
   ],
   "source": [
    "model1 = SpikingConvolutionNetwork(\n",
    "    encoder=CopyEncoder(seq_length=2),\n",
    "    snn=ITLIFResNet19(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=ITQIFResNet19(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.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": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "DIR = '../../SNN/output/CIFAR10/'\n",
    "\n",
    "LIF_weights = 'LSGLIFResNet18_(2024-09-05)_(09-21-17)'\n",
    "\n",
    "QLIF_weights = [\n",
    "    'QLIFResNet18_(2024-08-31)_(22-15-55)',\n",
    "    'QLIFResNet18_(2024-09-01)_(19-44-30)',\n",
    "    'QLIFResNet19_zheng_SGD_Cutout_Cosine_350_(2024-08-27)_(03-32-02)'\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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/CIFAR10/LSGLIFResNet18_(2024-09-05)_(09-21-17)/LSGLIFResNet18_(2024-09-05)_(09-21-17).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": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded from ../../SNN/output/CIFAR10/QLIFResNet18_(2024-08-31)_(22-15-55)/QLIFResNet18_(2024-08-31)_(22-15-55).pth\n",
      "Loaded from ../../SNN/output/CIFAR10/QLIFResNet18_(2024-09-01)_(19-44-30)/QLIFResNet18_(2024-09-01)_(19-44-30).pth\n",
      "Loaded from ../../SNN/output/CIFAR10/QLIFResNet19_zheng_SGD_Cutout_Cosine_350_(2024-08-27)_(03-32-02)/QLIFResNet19_zheng_SGD_Cutout_Cosine_350_(2024-08-27)_(03-32-02).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": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "qlif_spike_rate = np.mean(qlif_spike_rates, axis=0)"
   ]
  },
  {
   "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.24896440517207225\n",
      "Mean Spike Rate of QLIF: 0.13290398319274813\n",
      "QLIF spikes 46.6172752282033% 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: 0.9589186441498814 mJ\n",
      "QLIF energy: 0.5284692519561071 mJ\n",
      "Times Difference: 1.8145211676942106x\n"
     ]
    }
   ],
   "source": [
    "lif_energy = approximate_energy_consumption(model1, dataloader, 2, lif_spike_rate)\n",
    "qlif_energy = approximate_energy_consumption(model2, dataloader, 2, 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": "iVBORw0KGgoAAAANSUhEUgAABW4AAAJOCAYAAAAnP56mAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAACcgUlEQVR4nOzdd3gUVf/+8XtDGmlLL6EkgKBSHoogKCWAX1BBmqAC0gUBRaWIFEWCoICgERULIkWKiCBNFFAeIFIEpKOiQQjSlJ6QAKnz+4Nf9smSTbLZbLJLeL+ua68Lds7MfHZ2Mru5c+Yck2EYhgAAAAAAAAAAbsPD1QUAAAAAAAAAAKwR3AIAAAAAAACAmyG4BQAAAAAAAAA3Q3ALAAAAAAAAAG6G4BYAAAAAAAAA3AzBLQAAAAAAAAC4GYJbAAAAAAAAAHAzBLcAAAAAAAAA4GYIbgEAAAAAAADAzRDcAgAAIN+YTCaZTCaFh4dnWDZv3jzL8ujo6HyvDQAAAHAnBLcA4KY2b95sCTBuffj5+alChQp67LHHNGfOHCUkJLi63Ew1b97cUnehQoX066+/Ztk+Ojo6y2DHnV25ckU//PCD3nzzTXXo0EHBwcGW19K8efMcbevff//Va6+9pvvuu09FihRR4cKFValSJfXu3Vs7duzIk/oNw1DlypUtNT/77LN5sh+4RlJSkhYtWqROnTopNDRUfn5+8vLyUvHixVWnTh09/fTT+uCDD/Tnn3+6ulS3VlCuzXkpNDTU5vHx8vJSiRIl1KRJE4WHh+vMmTOuLtVu6T/LAElKTU3V6tWrNXDgQNWqVUulSpWSl5eXihUrplq1aqlfv35auXKlkpKSbK6f3TkVHh6e6bXG1iOzP3bFx8crMDDQ0u6tt96y+zVmti9vb2+VLl1aYWFhevPNN3Xu3Dm7t5mVhIQE/fzzz/rggw/Us2dP3X333fLw8HD4Z+/EiRMaMWKE7rnnHvn7+6tYsWJq0KCBpk2bpmvXrjmlZgDIcwYAwC1t2rTJkGTXo0aNGsbx48ddXbJNYWFhVrV26dIly/bHjx+3tB0/fnye1JR+H3PnznXadkNDQzN9j8LCwuzezqpVq4ygoKBMt2UymYzRo0c7re40W7ZssdpPkSJFjOvXrzt9P8h/R44cMWrWrGn3NSUv3/esfr7nzp1rWe6u1zR3uzanXWNzco3JayEhIXYdn6CgIOObb75xdbl2Sf9ZBmzevNmoVauWXed5cHCwze8a2Z1T48ePt/tak9U1c/78+Vbt7rnnHrtfp737LlasmLF+/Xq7t5uZPn36ZLmfnFi9enWW36WqVatmREVF5bpmAMhrngIAuL3Bgwfrueees/z/3LlzOnz4sKZNm6ZTp07p119/Vfv27bVv3z4VKlTIhZVmb/ny5Tpw4IBq167t6lKczjAMy79Lly6tBg0a6Ntvv83RNn766Sd16dJFSUlJ8vHx0QsvvKC2bdsqMDBQR44cUUREhPbs2aMpU6aoWLFiGjlypNPq/+KLLyRJAQEBiouL05UrV7R69Wo9+eSTTtsH8t/FixfVsmVLS+/GsLAw9ejRQ9WrV5efn58uX76sw4cPa9OmTVq3bp2uX7+ep/Wk/zm53RWka3NeCA4O1vr16y3/T0pKUnR0tObOnas1a9YoNjZWXbt21c8//6y6deu6sFLAfnPnztXAgQMtPWkbNWqkxx9/XHXq1FHx4sUVExOjv/76S999953Wrl2rM2fOaOjQoerTp4/D+5wzZ44aNGiQZZty5crZfP7Wz/YjR45o165duv/+++3ef/369TV37lzL/69evaqjR4/qo48+0s8//6xLly7p8ccf16FDh1SpUiW7t3ur9J8PgYGBqlevnv744w/9888/OdrOvn379NRTT+n69esKCAjQmDFj1KJFC12/fl1LlizRZ599pj///FNt27bVL7/8osDAQIdrBoA85+LgGACQifS9ujLreRobG2vVy/Prr7/O3yLtkNajJDAw0PD29jYkGe3bt8+0/e3c43batGnGsmXLjL///tvyXNp+7OkNl5qaaukVWahQIePHH3/M0CYhIcFo1aqVIcnw9fW12lduXL9+3TCbzYYkY8SIEUb16tUNSUbbtm2dsn24zssvv2z3z1RsbKwxY8YMIzExMX+Ku8Xt1uPWHa7N7tzjNiQkJNM2w4cPtxyfxx9/PP+KcxA9bmEYhvHjjz8aHh4ehiTD398/25/t48ePG0899ZRhNpszLMtJj9tNmzY5VO/Jkyct9U6fPt0oWrSoIcl4/vnn7Vo/u+8wqampRpcuXSzt7N1uZpYsWWLMnTvXOHz4sJGSkmIYhmM/e02bNjUkGZ6ensb27dszLH/77bfz/LsmADgLY9wCwG0sMDBQr732muX/P/74owuryVqxYsXUv39/SdLq1av1yy+/uLgi53v55ZfVuXNnVahQwaH19+zZo8OHD0uSunbtqoceeihDG29vb82cOVOSdOPGDc2YMcPxgtNZuXKlYmJiJElPP/20evToIUlav36908aug2usWrVK0s1e4K+//nqWbQMDA/Xiiy/Ky8srP0orsG6na7OrTJgwQYULF5YkbdiwQampqS6uCMjatWvX1KNHD6WmpsrDw0Nr165Vly5dslwnNDRUS5Ys0fvvv59PVVpbuHChUlNT5enpqV69eumJJ56QJC1ZsiTTsXdzwmQyacqUKZb/5/Za99RTT6lPnz6qUaOGPDwciyp27dqln376SZL0zDPP6IEHHsjQZsSIEbr33nslSTNmzHDKsQCAvEJwCwC3uVq1aln+ffLkySzbbtq0Sb1791blypXl5+enoKAg1apVSyNHjsx2kpgzZ85o9OjRqlevnsxms7y8vFS6dGnVqlVL3bp107x58xQbG5vlNsaOHStfX19JyjZAssfRo0c1bNgw1apVS2azWYULF1blypXVp0+fTINhk8lkdRtf3759M0y64apJ0dLX/Oijj2barmrVqqpSpYqkm0NPOEParZTVq1dX3bp19fTTT8tkMik5OVmLFy/O0D4yMtJyvD777LNstz958mRL+99++81mm71792rQoEG6++67FRAQIH9/f919990aPHhwlhNmzZs3z2pyloSEBL333ntq1KiRSpQokeE9TUxM1Jo1azRkyBA1aNBARYsWtUzS1bBhQ4WHh+vChQvZviZJ2rp1qzp37qwyZcrI19dXlStX1qBBg3T06FFJ/5t8JrvJ6Rw5l+31999/S5IqVark8C/CUsbX8scff+jZZ59VpUqV5Ovrq7Jly+rJJ5/Uzz//nOV2cvtzduLECVWrVk0mk0mBgYHauHFjhjaOnkvOZM+1OTfnYp8+fWQymbRlyxZJ0pYtWzJcy0JDQ22uGxMTo8mTJ6tx48YqWbKkvL29VbZsWbVr107Lli3Ll+EsAgICVL16dUlSXFycLl26lKFNfl0T8sPhw4c1adIkPfzwwypfvrx8fHwUEBCgqlWrqnfv3pn+3CQlJalMmTIymUx65JFH7NpP2mt/++23bbb5559/9Oqrr6p+/foqVqyYfHx8VKFCBT355JNZBm/pJw+dN2+eJOmbb75RmzZtFBwcLE9PzxxPxJnm/Pnzeu2111S3bl0VKVJEvr6+Cg0NVc+ePbV169Ys102bDC9tKII//vhDAwYMUGhoqHx8fFS6dGl16tQp22tTdubMmWO5Zf/5559XWFiY3ev26tUrV/t21IIFCyRJrVu3VsmSJdWzZ09JN4fQWbt2rVP2UblyZfn7+0vK/ntofli5cqXl33379rXZxsPDw/KeXLlyRZs2bcqP0gDAMa7u8gsAsM2e23ENwzD27dtnadehQwebba5fv2507do1ywkf/P39jdWrV9tcPzIyMssJHtIea9asybBu2i1uabfMvvTSS5b2tm5fs3eohGnTphleXl6Z1mIymYxx48ZlWC+715DdfnMqbZv23MY8adIkS/sffvghy7YPPvigpe2JEydyVeM///xjFCpUyJBkvPXWW5bn0967unXrZlgnNTXVqFixoiHJaN68ebb7SBsCok6dOhmWpaSkGMOGDTNMJlOm74mnp6fx6aef2tx2+tvrd+/ebdSpUyfL97R3797ZngPFixc3tm7dmuVrmjJlSqY1BwYGGuvXr7frNnZHz2V7BQYGGpKMEiVKGElJSQ5vJ/1r+e677wx/f3+b9Xp4eBgRERGZbiern7Pshkr47bffjPLly1veo507d1otz+25ZA9nXptzcy7as66toQp+/PFHo3jx4lmu16ZNG+Pq1asOHiH7hkowDMNo1KiRZZ///POP5fn8vibYIzdDJdg7oV1mk06OHDnS8rN16tSpLPc1bNgwy/E5e/ZshuULFy7M9Gc37fHMM8/YvFak/3yeM2eO0bNnzwzrOjJkx/r167P9jvH8889bbp2/Vdr51rt3b+Obb74x/Pz8bG6jUKFCxpIlS3JcX5p69epZrslHjx51eDtp8nqohN27d1vWX7x4sWEYNz+7K1WqZEgyOnXqlO027H1f04ZasjUkRG7l9GcvbZgEf3//LD/ztm/fbtnu66+/7qxyAcDp6HELALe533//3fJvW72rDMNQly5dtGTJEklSu3bttGDBAm3btk07duzQjBkzVLFiRcXHx6tLly4ZevclJCSoa9euio2NVWBgoF555RV9//332rNnj3bs2KHFixdryJAhmU6KcasxY8bIz89PkjRu3DiHXvO0adM0cuRIJSUl6T//+Y8+/vhj/fjjj/rll1+0aNEiPfDAAzIMQxMnTsxwe+KhQ4esJsuZ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XmZ23NP+qHf16lVLuJomrRduw4YNVb16datlly5dsoS6OZHXxzXt+lCsWLEsJ5GSZOlpbxhGpn/AyOoaIckSYOb0+4okq8nz/v333xyvn5+WLFliCS0z+2wvVaqUWrduLUlauHChVY9vW9JPfnjw4EFt2LBB48aNk9ls1unTp/XII4/op59+yrDe7t27M/0elXYniTOlD9hv/b5iS1oIn/47FQC4m6w/IQEAbqFUqVKqWbOm5f916tTRY489phYtWqhPnz6Kjo5W//79tWrVKqv10v9ysmbNGrtn+701mKlevboOHTqkNWvWaM2aNYqMjNTRo0d1/fp1rV+/XuvXr9e7776r7777zq5QJ82wYcM0Y8YMXb58Wa+//roeffTRLNunfz2vv/66zVv7bbkdbmu8VZcuXdSlSxddu3ZN//zzjzw9PVWuXDlLkJv+1sYaNWo4tI/0vWwef/zxbNvHx8dr+fLlGW6Tf/rppxUZGanjx49rx44dltts169fr4sXL1ra3Cr9+/npp5/qwQcftKvurAKD9EG3LUeOHNGgQYOUnJysUqVKaeTIkWrZsqVCQ0MVGBho6R05Z84cy6272f1C6wh3OpcLFSqkjh07qkqVKqpfv74SExP13//+V5cuXbL0UEsvq2EdnKlz585avny5zp8/r549e2rp0qWZhjt5cS7Zw9Frs5T/52LaMXr00Uf19ttvO7ydnPDy8rI6PtlxxTUhP/Ts2VPHjx+XyWRS37591bVrV917770qWbKkvL29ZTKZlJqaaqk1s/e5Xr16qlu3rvbt26e5c+eqV69ekm7e7v7bb79JytjbVrI+rv3799dLL71kV91Z3WruzOOaX9eU3KhVq5Y8PDyUmpqqvXv3urqcLKX/bK9Xr1627aOjoxUZGamwsLBM2/j7+1v9LNeqVUutWrXSk08+qQcffFBXr17V008/rcOHDysoKCh3LyAXfH19Vbx4cV28eFGnTp3Ksu3ly5ctwW3aHy4BwB0R3ALAbax3795as2aNli9frtWrV+u///2vWrZsaVmevodIkSJFcvQL9K3Swp2OHTtKunkb/7p16zRz5kzt2bNHe/bs0cCBA7VixQq7txkUFKSXX35Zr776qn755RetWrVKtWvXzrR9+teT00DAEeHh4ZbblF3Fz8/P5u32e/bskXTzlxRHblmNjY21GSZl54sv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93qNGzfWXXfdleH5e+65xyl1AQAAAAAAAHmF4Bb5rkSJEpKkf//91672586ds/y7ZMmSdu+nf//+6tOnT45qAwAAAAAAANwBQyUg3913332SpL179yo5OTnb9rt27ZIkmc1mVapUKU9rAwAAAAAAANwBwS3yXbt27eTh4aGYmBitWrUqy7aGYWjBggWSpA4dOsjDg1MWAAAAAAAABR8pGPJdlSpV9OSTT0qSRo4cqStXrmTa9qOPPtLBgwfl7e2tV155JZ8qBAAAAAAAAFyL4BYuMXPmTIWGhur48eNq2bKlfv31V6vlycnJevfdd/XSSy9JkmbNmqUaNWq4olQAAAAAAAAg3922we3UqVNlMplkMpn0888/Z1geGxur4cOHKyQkRD4+PgoNDdXIkSMVFxfngmpxq2LFiumnn37Sfffdp3379qlWrVq6//771a1bN3Xo0EHBwcEaMWKE/P399emnn6p3796uLhkAAAAAAADIN56uLsARhw8f1vjx4+Xv76/4+PgMy+Pj4xUWFqb9+/erdevW6tatm/bt26fp06dry5YtioyMlK+vrwsqTyc8xrX7dwPly5fXrl279NVXX+mrr77S7t27tX//fiUlJUmS/Pz8tHfvXlWpUsXFlQIAAAAAAAD567brcZuUlKTevXurTp066tSpk802b7/9tvbv369Ro0Zp/fr1mjJlitavX69Ro0Zp9+7dioiIyOeqkRkPDw9169ZNK1eu1OnTp5WYmKgrV66obt26unbtmp577jklJCRkWK9Pnz4yDEPR0dEZlkVHR8swDPXp0yfvXwAAAAAAAACQB2674PbNN9/Ur7/+qjlz5qhQoUIZlhuGodmzZysgIEDjxo2zWjZu3DgFBARo9uzZ+VUuHGA2m7V+/Xrde++92rBhg5566iklJye7uiwAAAAAAAAg39xWwe3evXv15ptvavz48apevbrNNlFRUTpz5owaN24sf39/q2X+/v5q3Lixjh07ppMnT+ZHyXBQyZIl9eOPPyo8PFx16tTRnj17XF0SAAAAAAAAkG9umzFuExIS1KtXL9WpU0evvPJKpu2ioqIkSVWrVrW5vGrVqlq/fr2ioqJUoUKFTPeV/vb82NjYXFQORwUHB2v8+PGuLgMAAAAAAADId7dNj9vXX39dUVFRmjt3rs0hEtLExNyc9MtsNttcHhQUZNXOlsmT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I++YDMMwXF1EXtm1a5fGjx+v7du3KykpSbVq1dLw4cP11FNPubo0AAAAAAAAAMhUgQ5uAQAAAAAAAOB2VCDHuAUAAAAAAACA2xnBLQAAAAAAAAC4GYJbOMXChQs1cOBA1a9fXz4+PjKZTJo3b56ry3KJ06dP67333lPr1q1VsWJFeXt7q0yZMurcubN27tzp6vLy3Y0bNzR8+HA1a9ZMwcHB8vX1VZkyZdS4cWPNnTtXSUlJri7RLUydOlUmk0kmk0k///yzq8vJV6GhoZbXfuujefPmri7PZVasWKFWrVqpePHi8vX1VaVKldStWzedPHnS1aXlm3nz5mV6bqQ9HnroIVeXmW8Mw9A333yjFi1aqGzZsvLz89Pdd9+tgQMH6tixY64uL9+lpqbqww8/VL169eTn56egoCA1a9ZMq1evdnVpeSqn37liY2M1fPhwhYSEyMfHR6GhoRo5cqTi4uLyr+g8kpNjsX//fo0dO1YPP/ywSpYsWSA/Y+w9HklJSVq+fLl69+6te++9VwEBAQoMDFTDhg318ccfKyUlJf+LzwM5OT8WLVqkTp06qUqVKgoMDFRAQIBq1KihYcOG6fTp0/lbeB7Jze9rx44dU0BAgEwmkwYNGpS3heaTnByP8PDwLL+LREdH52vtecGR8+P48eMaMGCA5fOldOnSatGihb7++uv8KToP5eR4ZPdd1WQy3dbf33N6bkRFRalv376qWrWqChcurHLlyqlVq1YF/vtZXvJ0dQEoGF577TWdOHFCJUqUUNmyZXXixAlXl+QyH3zwgaZOnaoqVaqodevWKlmypKKiorRy5UqtXLlSixcvvqMmyIuLi9PHH3+s+++/X23btlXJkiV1+fJlff/99+rXr5+WLFmi77//Xh4ed+7fkQ4fPqzx48fL399f8fHxri7HJcxms4YOHZrh+dDQ0HyvxdUMw9CgQYM0a9YsValSRV27dlVgYKDOnDmjLVu26MSJE6pQoYKry8wXderU0fjx420uW7ZsmX799Vc9/PDD+VyV67z88st69913VbZsWXXs2FFBQUE6cOCAPvvsM3355Zfavn27atas6eoy84VhGHryySe1fPlyValSRc8884wSEhK0atUqdejQQR988IGGDBni6jLzRE6+c8XHxyssLEz79+9X69at1a1bN+3bt0/Tp0/Xli1bFBkZKV9f33ys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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 = 'ResNet-19'\n",
    "DATASET = 'CIFAR-10'\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
}
