{
 "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 CopyEncoder\n",
    "from SNN.models.classification import ITQIFResNet19, ITLIFResNet19\n",
    "\n",
    "import torch\n",
    "\n",
    "from torchvision.transforms import v2 as transforms\n",
    "from torchvision.datasets import CIFAR100\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": 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": [
      "Total number of parameters: 12653988\n",
      "Files already downloaded and verified\n"
     ]
    }
   ],
   "source": [
    "model1 = SpikingConvolutionNetwork(\n",
    "    encoder=CopyEncoder(seq_length=2),\n",
    "    snn=ITLIFResNet19(num_classes=100, 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=100, method='asym_rectangle'),\n",
    "    decoder=decode_mean,\n",
    "    seq_length=2,\n",
    "    input_scale=1.0\n",
    ")\n",
    "\n",
    "dataset = CIFAR100(\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": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "DIR = '../../SNN/output/CIFAR100/'\n",
    "\n",
    "LIF_weights = 'LIFResNet19_CIFAR100_Cutout_autoaugment_(2024-09-20)_(21-46-24)'\n",
    "\n",
    "QLIF_weights = [\n",
    "    'QLIFResNet19_CIFAR100_Cutout_autoaugment_(2024-09-18)_(20-10-19)',\n",
    "    'QLIFResNet19_CIFAR100_Cutout_autoaugment_(2024-09-19)_(07-57-43)',\n",
    "    'QLIFResNet19_CIFAR100_Cutout_autoaugment_(2024-09-19)_(21-36-25)'\n",
    "\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: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/CIFAR100/LIFResNet19_CIFAR100_Cutout_autoaugment_(2024-09-20)_(21-46-24)/LIFResNet19_CIFAR100_Cutout_autoaugment_(2024-09-20)_(21-46-24).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/CIFAR100/QLIFResNet19_CIFAR100_Cutout_autoaugment_(2024-09-18)_(20-10-19)/QLIFResNet19_CIFAR100_Cutout_autoaugment_(2024-09-18)_(20-10-19).pth\n",
      "Loaded from ../../SNN/output/CIFAR100/QLIFResNet19_CIFAR100_Cutout_autoaugment_(2024-09-19)_(07-57-43)/QLIFResNet19_CIFAR100_Cutout_autoaugment_(2024-09-19)_(07-57-43).pth\n",
      "Loaded from ../../SNN/output/CIFAR100/QLIFResNet19_CIFAR100_Cutout_autoaugment_(2024-09-19)_(21-36-25)/QLIFResNet19_CIFAR100_Cutout_autoaugment_(2024-09-19)_(21-36-25).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.25960086495011936\n",
      "Mean Spike Rate of QLIF: 0.17965170989080437\n",
      "QLIF spikes 30.79695249654762% 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": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LIF energy: 0.9505136718385189 mJ\n",
      "QLIF energy: 0.7702606368269997 mJ\n",
      "Times Difference: 1.2340156388544672x\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": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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tGTJEkk3eqnb6+3o6+trXrc8qV2t14dr166Z72kZ2bVrlySpcuXKDk06lRusQyQZhqH//ve/bokhK2l7237wwQdZvrdbh0tYtmyZ00OjDBgwQBUqVJAkTZ8+3e4YzXmpcePGkm7cJWT9kduezZs3m383atTIZp2vr6/q168v6cZwXpldM631+Pn5qW7duk7HDQA5QeIWADzYnXfeqSeeeELSjdslv/nmG3NdnTp1zNu9Zs6caTNLrqv4+PiYvTSuX7+uixcvZmv7oKAgjRgxQtKNmbSXL1+eYdkCBQqoVatWkm6Mz/rbb785FXPaSSfSTipxq0g7mdszzzzjVB3WL3eFCxfWyJEj1blz50wfL774oqQbEyQtXLgwXX3WxO7Zs2f1zTffaOXKleb4iBnN6l68eHE1bNhQ0o3euY70YM0p6ziPmU0uc/r0aXMGdnusM3SnpqamG9c3rczGDXTVuewIR3s7GYZh3gJssVgyHFrFMIxMJ7OZO3euuc//+7//y16wN7FYLPrggw/MsT0/++wz9ezZ05zAysod51JWMrs2S645F6X/Xc+yupY9+uijkqS4uDizh6an8cTnMafSji2b2XP94YcfOlRfaGioOnbsKEmaN2+eli1bpri4OEn2h0mwsj7/hw4dUnR0tEP7ym1prw+zZ8/OsNyOHTvMoSByek3Jib59+5pj7b733ns2ib+sLFiwILfCMhmGYb4/V69eXQMHDszyvX3QoEGSbtyFs3LlSqf26+Pjo5EjR0q6cY5Pnz7dJcfjLOudYZIyvNalpqaa72OFChXSAw88kGE98fHx+uKLL+zWc+LECX377beSbnw2cHayWADIKRK3AODhRo8ebfZSSnsbppeXl9nT68iRI+rZs2emX+7j4+P17rvv2iyz3m6WkWvXrplfXoKCghyasOlmTz/9tDmZ0ZQpUzItO2rUKBUoUECpqanq2LFjpmOPpaSkaNGiRenKFC1a1Oyx8+eff2Y73tx06dKlTCfCmDJlij799FNJUs+ePdP1EnFEbGysOYlI27ZtHeqxW6tWLVWqVEmS/S+gbdq0MXt6LVq0yExolilTJtPbL8eMGSPpxrnXsWPHTBP/SUlJeu+993L0A0TlypUl3biddPv27enWX758WV27ds2051H79u3NsZyjoqLsnkMxMTEaP358prG44lx2RJMmTbRo0aIs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cP+OyOtrgiOs57+jj5o1a5rb7tu3zyhcuHCGZWvUqGGcOnUqW+fVlClTbF5zx48fd+g4Vq9ebRQpUiTL+L28vIzvvvvOZtujR4+a6+fMmZON1stcdHS0ERISkmk8zzzzjJGSkmJ3e+v51qtXr0z306tXrxydl2lt2rTJqF69ukPnQvny5Y3FixenqyPtOWVP2s8UGzduzDSey5cvm2141113ZetYli5dau7n5mu3dXlkZGSW9SQmJhrFihUzJBlFixY1Ll26lK04DMP2+urII7PzcPXq1ZmeV3feeadD76mvvPJKpp+fW7VqZVy5ciXbxwoArsRQCQBwC6hXr56aN28u6caYmbt37zbX+fj46P3339dPP/2k5557TjVq1FBoaKgKFCig0NBQ1apVS08++aSWLVuWbqzNF198UcuXL9egQYPUsGFDlS9fXv7+/vL391dERISeeOIJffnll1q5cqUKFizodPz+/v56+eWXHS7fv39/HTlyROPHjzdv6/b29lZgYKDuvPNOdejQQR9++KFOnjxptzdG69attWHDBrVt21ZhYWFOTfCVG+666y69++67at++ve644w4FBwcrICBAFStWVI8ePRQdHa3Vq1c7Pav2jh07zNvhH3nkkWz1iKxXr57Kly8vSVqyZImSk5Nt1jdr1sy8bVu6MbNzrVq1sqzXYrHolVde0R9//KGXXnpJdevWVZEiRVSgQAEFBweratWq6tatm+bNm6fTp0/n6DyTbowRvHbtWrVo0UKFCxeWr6+vypYtq8cee0zr16/PtLdpWi+//LI2b96sdu3aqUSJEvLz81N4eLj69u2rH3/8Ua1atVJ8fLwkZdrbKqfnclb279+vvXv3asqUKWrbtq3uvPNOBQcHy8vLS0FBQapUqZLatWunjz/+WL///rtatmyZZZ2tW7fWjz/+qD59+ig8PFy+vr4qUaKEOnTooK1bt2bYgymnvLy8NG/ePHXu3FmSNGvWLA0aNMjsQZ7X55IjMrs2u+JcDAoK0vbt2/XCCy/o7rvvVkBAQKblGzZsqJiYGH344Ydq3bq1wsLC5OvrK39/f5UrV04tWrTQa6+9pkOHDqlnz545O3gneeLzmBO1atXS/v37NXDgQIWHh8vHx0dFihRR/fr1NW3aNO3atcvm2umIHj16mH83b97c4Z74bdq00dGjRzVt2jSzd7+P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GDBAX3zxhd26evbs6WwYAAAAAAAAAJDvOJ247d27tywWiyTJMAxt27ZN27ZtS1fOMAzFxcVp6NChduuxWCwkbgEAAADAAREj1+a4jtjJrV0QCQAAyG1OJ27Lly9vJm4BAAAAAAAAAK7jdOI2NjbWhWEAAAAAAAAAAKycTtwCAADAOdzqDAAAACArXu4OAAAAAAAAAABgy+U9bq9du6Z169bp999/l5+fn+rUqaPGjRu7ejcAAAAAAAAAkG85nLi9dOmSVqxYIUnq1KmT/Pz80pX58ccf1aFDB504ccJmeYMGDfTFF1+oVKlSOQwXAAAAAAAAAPI/hxO3GzZsUO/evVWrVi317Nkz3fozZ86oVatWOnfunAzDsFm3c+dOPfroo9q1a1fOIwYAAAAAAADgOaJCXVBHXM7ryGccHuP2+++/lyR17drV7vopU6bo33//lST16tVL27Zt008//aQhQ4bIMAzt2bNHy5Ytc0HIAAAAAAAAAJC/OdzjdteuXbJYLHrooYfsrl+0aJEsFovatGmjOXPmmMvffPNNnT9/XvPmzdPy5cvVsWPHnEcNAAAAAAAAAPmYwz1uT58+LW9vb1WtWjXdul9++UVnzpyRJD3//PPp1r/wwguSpH379jkbJwAAAAAAAADcNhzucfvPP/8oJCREXl7pc73WsWt9fX3VuHHjdOurV68ui8WiU6dO5SBUAAAA5EcRI9fmuI5YfxcEAgAAAHgQh3vcpqSkKD4+3u66PXv2SJLuvvtu+fr6plvv7e2twoUL68qVK06GCQAAAAAAAAC3D4cTtyVKlND169f1559/plu3Y8cOWSwW1atXL8PtExISFBgY6FyUAAAAAAAAAHAbcThxW6dOHUnSzJkzbZbHxMRo//79kqTIyEi72x47dkzXrl1T2bJlnQwTAAAAAAAAAG4fDiduu3TpIsMwNH36dE2dOlW///67NmzYoMcff1yGYSgwMFBt2rSxu+2WLVsk3RjrFgAAAAAAAACQOYcTt48//riaNGmi69eva+TIkapatapatGihAwcOyGKxaOjQoQoODra77WeffSaLxWJ34jIAAAAAAAAAgC3v7BRetWqVevTooS+//NJcZrFY1K9fP73yyit2t4mJidG6deskSa1atcpBqADgeVwyE/rk1i6IBAAAAAAA5CfZStyGhoZq9erVOnz4sDmubb16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mfr16/PBBx8U2Kd37940a9bM/OE0sH79eiIiImjfvj1eXl64urry119/sWvXLpKSknjuuecYP3681jGFRtatW0dERATPP/88np6eODk5cfbsWXbu3ElOTg5Tpkzh+eef1zqmWX322We0bduWESNGsGXLFnx9fYmLi2P//v14enoyb948rSNqwpJHMAAMGDCAzz//nIMHD1K/fn169uyJm5sbx48fZ//+/Tg4OBAREaF1TLNq3bo1tWrVws/PD3t7e44dO0ZMTAx169Zlw4YN/9o/mhanzfXOO++wdetW5s6dS1xcHC1atOD48ePs2bMHf39/xo0bp8UllKri1Ed8fLyxA9vwGG98fDwhISHG8y1fvtw8wcvAo9ZFfHw8ffr0ISsri8DAQNauXVvgXF5eXvnq5Un0qPWRlJSEn58fLVu2xNfXlxo1apCcnMyPP/7I8ePHcXV1NU5n9SST39fyK8794evri7+/P35+flStWpVr166xd+9erly5QuPGjf8VbbPi3B+DBg0iKiqKjRs30rRpU7p27UpqaiqbNm0iMzOTlStX4u7ursl1lJaSfF5WrlxJTk4Or7zyCra2tmbNW5YetS7s7OyYN28eI0eOpFu3brz44ov4+vqSmJhIVFQUd+7cYeLEiQX+CCIegRKiFAQHByug0K/g4GCtI5rNw+oCUJGRkVrHNJsff/xRjRgxQjVs2FC5ubkpa2tr5eHhoTp06KAWL16scnJytI5Ybhjune+//17rKGYTExOjBg4cqHx8fJSrq6uytrZWVatWVb169VK7d+/WOp5mLl26pEJCQlTVqlWVjY2NqlWrlnrzzTfVtWvXtI6miaNHjypAtWrVSusomsrMzFSzZ89WzZs3V46Ojsra2lrVqFFDDR06VJ05c0breGYXFhamGjdurFxcXJS9vb3y8/NT06ZNU6mpqVpHK1PFbXOlpKSocePGqVq1aikbGxtVu3ZtNXHiRHX79m1tLqCUFac+oqOjH9pGe5I9al08Sj0EBARoei2l4VHr486dO+q9995Tzz//vPHnrpOTk2rYsKEaP368unz5srYXUkoe9/c1w30zcuRI8wQuY49aH6mpqerNN99U/v7+qnLlysra2lq5uLioVq1aqY8++kjdvXtX2wspJcW9P3JyclRERIRq2LChsrOzU66urqpLly4qJiZGmwsoZSX5vPj5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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-100'\n",
    "\n",
    "n_layers = len(qlif_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
}
