{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c730d809-4b95-4fa4-945d-09103a1bbbbe",
   "metadata": {},
   "outputs": [],
   "source": [
    "# NOTE: reduced implementation might require slightly different parameters for same results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "182c286f-8a28-4500-a9ee-ec48956e6b0e",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# Imports\n",
    "import os\n",
    "import h5py\n",
    "import random\n",
    "\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.optim.lr_scheduler import CosineAnnealingLR\n",
    "from tqdm import tqdm\n",
    "\n",
    "from shd_data_loader import SHD, SHDAdding, random_val_split_SHD_data, visualize_training_batch\n",
    "from shd_download_utils import get_shd_dataset\n",
    "from expressive_leaky_memory_neuron import ELM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "7db9cf83-f768-4733-bbb2-37cbec34db27",
   "metadata": {},
   "outputs": [],
   "source": [
    "general_seed = 0\n",
    "os.environ['PYTHONHASHSEED'] = str(general_seed)\n",
    "random.seed(general_seed)\n",
    "np.random.seed(general_seed)\n",
    "torch.manual_seed(general_seed)\n",
    "torch.cuda.manual_seed(general_seed)\n",
    "torch.backends.cudnn.deterministic = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1eda040f-79d8-4020-8a1f-6163c729cebe",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Available at: ./shd_data/shd_train.h5\n",
      "Available at: ./shd_data/shd_test.h5\n"
     ]
    }
   ],
   "source": [
    "# Data download config\n",
    "data_path = \"shd_data\"\n",
    "get_shd_dataset(\"./\", data_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "b5f923ae-d15f-4266-a0a5-fc303b0fc1cc",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# Dataset config\n",
    "dataset = \"shd\" # \"shd\", \"shdadding\"\n",
    "data_seed = general_seed\n",
    "valid_fraction = 0.2\n",
    "bin_size = 10\n",
    "num_classes = 20 if dataset == \"shd\" else 19\n",
    "num_input_channel = 700"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "6ad3529a-aa27-4463-b7bb-fbe266f88f91",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Model config\n",
    "lambda_value = 5.0\n",
    "num_memory = 100\n",
    "mlp_num_layers = 1\n",
    "memory_tau_min = 10\n",
    "memory_tau_max = 1000\n",
    "learn_memory_tau = True\n",
    "num_synapse = num_input_channel\n",
    "num_output = num_classes\n",
    "delta_t = bin_size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "0cfccb70-6006-4dea-8e1c-750276e2bec0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Training config\n",
    "learning_rate = 5e-3\n",
    "num_epochs = 10\n",
    "batch_size = 8\n",
    "dropout= 0.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a8de4b45-ed6d-4e80-a93d-ba37924ce29d",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# Open the downloaded dataset\n",
    "train_file = h5py.File(os.path.join(data_path, 'shd_train.h5'), 'r')\n",
    "test_file = h5py.File(os.path.join(data_path, 'shd_test.h5'), 'r')\n",
    "\n",
    "# Split the dataset into training and validation sets\n",
    "x_train, y_train, x_valid, y_valid = random_val_split_SHD_data(\n",
    "    train_file=train_file, \n",
    "    valid_fraction=valid_fraction, \n",
    "    seed=general_seed\n",
    ")\n",
    "\n",
    "# Extract the testing dataset\n",
    "x_test = test_file['spikes']\n",
    "y_test = test_file['labels']\n",
    "\n",
    "# Initialize datasets\n",
    "if dataset == \"shd\":\n",
    "    train_dataset = SHD(X=x_train, y=y_train, batch_size=batch_size, bin_size=bin_size, shuffle=True, test_set=False)\n",
    "    valid_dataset = SHD(X=x_valid, y=y_valid, batch_size=batch_size, bin_size=bin_size, shuffle=False, test_set=False)\n",
    "    test_dataset = SHD(X=x_test, y=y_test, batch_size=batch_size, bin_size=bin_size, shuffle=False)\n",
    "    \n",
    "    batches_per_epoch = len(train_dataset)\n",
    "    valid_batches_per_epoch = len(valid_dataset)\n",
    "    test_batches_per_epoch = len(test_dataset)\n",
    "else:\n",
    "    batches_per_epoch = 2000\n",
    "    valid_batches_per_epoch = 500\n",
    "    test_batches_per_epoch = 2000\n",
    "\n",
    "    train_dataset = SHDAdding(X=x_train, y=y_train, batch_size=batch_size, bin_size=bin_size,\n",
    "                              batches_per_epoch=batches_per_epoch, shuffle=True)\n",
    "    valid_dataset = SHDAdding(X=x_valid, y=y_valid, batch_size=batch_size, bin_size=bin_size,\n",
    "                              batches_per_epoch=valid_batches_per_epoch, shuffle=False)\n",
    "    test_dataset = SHDAdding(X=x_test, y=y_test, batch_size=batch_size, bin_size=bin_size,\n",
    "                             batches_per_epoch=batches_per_epoch, shuffle=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "6f0496c9-8374-494d-aa5c-403623cfcc4e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABKUAAASmCAYAAAD/KRjlAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOzde3QV9b3//9cmQBQMESLmIgEDhqpclIIiWIueIFbleDsVjljFy/kuLGpNIQWxXghFEFwH6Kmi0iqxWkVttZVzaI/xAmppq6bea6kXxBsxVdMENSYI8/uDH/t0m71hJp/5zGXv52Mt1iI7s/d8ZmZnz3u/5/15T8JxHEcAAAAAAABAgLqFPQAAAAAAAADkHpJSAAAAAAAACBxJKQAAAAAAAASOpBQAAAAAAAACR1IKAAAAAAAAgSMpBQAAAAAAgMCRlAIAAAAAAEDgSEoBAAAAAAAgcCSlAAAAAAAAEDiSUgBCVVdXp0Qioeeee86X10skErrssst8ea1/fs358+d3+flXX321Jk+erIMOOkiJREIXXHBB2uVeffVVzZw5U+PGjVPv3r2VSCS0fv36Lq8XAADkllyIq/72t7/p3/7t39S3b1/16tVLY8eO1cMPP+zfAAEEiqQUAFi2fPlyffzxxzrttNPUs2fPjMs999xz+vWvf61+/fqpqqoqwBECAABE39tvv61x48Zp06ZNuvXWW/XAAw+of//+OuOMM/SrX/0q7OEB6ILuYQ8AALLdtm3b1K3brmsAd911V8blzjvvPE2fPl2S9Mtf/lJr164NZHwAAABxcMMNN+jzzz/X//7v/+qggw6SJH3rW9/SiBEj9P3vf19nnnlmMuYCEA/8xQKIvC+++EKzZ8/WkUceqcLCQvXr10/jxo3Tb37zm4zPue222zR06FDl5+fr8MMP15o1azot09jYqBkzZmjAgAHq2bOnKioqVFtbqy+//NLX8bsNjgiiAACAbXGOq37/+9/riCOOSCakJCkvL08nn3yy3n33XT3zzDO+rQtAMKiUAhB57e3t+uSTT1RTU6ODDjpIHR0devTRR3XWWWdp9erVOv/881OWf/jhh/XEE09owYIF6t27t1auXKlzzjlH3bt317e//W1JuwKno48+Wt26ddO1116rIUOG6A9/+IMWLlyot99+W6tXr97jmA4++GBJu8rIAQAA4iLOcVVHR4f69evX6fH8/HxJ0ksvvaRjjjnG5Z4AEAUkpQBEXmFhYUows2PHDlVVVam5uVkrVqzoFDx99NFHevbZZ1VcXCxJOuWUUzR8+HDNmzcvGTzNnz9fzc3NevXVVzVw4EBJUlVVlfbdd1/V1NToBz/4gQ4//PCMY+renY9PAAAQP3GOqw4//HCtX79en376qfbbb7/k408//bQk6eOPP3b1OgCig7kiAGLhgQce0LHHHqv99ttP3bt3V48ePXT77bfrtdde67RsVVVVMnCSdpV1T506VW+88Ybee+89SdJ///d/64QTTlBZWZm+/PLL5L+TTz5ZkrRhw4Y9jueNN97QG2+84eMWAgAABCOucdVll12mlpYWnX/++Xrrrbf04Ycf6pprrtHGjRsl0QoBiCP+agFE3oMPPqgpU6booIMO0t13360//OEPevbZZ3XRRRfpiy++6LR8SUlJxsd2X0H78MMPtXbtWvXo0SPl37BhwyTtuioIAACQbeIcV1VVVWn16tV68sknNWTIEJWUlOjBBx/Uj370I0lK6TUFIB6YfwIg8u6++25VVFTovvvuUyKRSD7e3t6edvnGxsaMjxUVFUmSDjjgAI0cOVLXX3992tcoKyszHTYAAEDkxD2umj59us4991y9/vrr6tGjhw455BAtXrxYiURCxx13nG/rARAMklIAIi+RSKhnz54pgVNjY2PGu8Q89thj+vDDD5Ol5jt27NB9992nIUOGaMCAAZKkyZMna926dRoyZIj69u1rfyMAAAAiIBviqu7du+uwww6TJLW0tGjVqlU6/fTTNWjQIOvrBuAvklIAIuHxxx9Pe8eVU045RZMnT9aDDz6omTNn6tvf/rbeffdd/ehHP1Jpaalef/31Ts854IAD9C//8i+65pprkneJ+etf/5py++IFCxaovr5e48eP1/e+9z197Wtf0xdffKG3335b69at06233poMtNI55JBDJMlV/4MNGzbo73//u6RdgdyWLVv0y1/+UpI0YcIE9e/fX5L0+eefa926dZKkP/7xj8nnfvTRR+rdu3eyLwMAAMCeZGtc1dTUpP/8z//Uscceq4KCAv31r3/V0qVL1a1bN918880u9w6AKCEpBSAS5s6dm/bxzZs368ILL1RTU5NuvfVW3XHHHRo8eLCuvPJKvffee6qtre30nNNOO03Dhg3T1VdfrXfe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UgMGDHA1Dq70AQCATPyIE4if4osqIAAAvLNWKfXFF19o1apVevTRRzVy5Ej16NEj5ffLli1z/VobNmzQpZdeqqOOOkpffvmlfvjDH2rSpEn6y1/+ot69e0uSli5dqmXLlqmurk5Dhw7VwoULdeKJJ2rTpk0qKCiQJFVXV2vt2rVas2aNioqKNHv2bE2ePFkNDQ3Ky8vzuomxwxV/BI33HAB4Q/wUXySfAACwx3Ol1AknnJD5xRIJPf74410ezN///ncdeOCB2rBhg775zW/KcRyVlZWpurpac+fOlbTrql5xcbGWLFmiGTNmqKWlRf3799ddd92lqVOnSpI++OADlZeXa926dTrppJP2ut5cudIHAAC88yNOIH6KLyqlAADwzlql1BNPPGE0sD1paWmRJPXr10+StHnzZjU2NmrSpEnJZfLz8zVhwgRt3LhRM2bMUENDg7Zv356yTFlZmYYPH66NGze6CqoAAABsIn6KL5JPAADY4zkpZYvjOJo1a5a+8Y1vaPjw4ZKkxsZGSVJxcXHKssXFxdqyZUtymZ49e6pv376dltn9/K9qb29Xe3t78ufW1lbftgO5jWltAIAgET9hN9OG6nFuyI5o470FYE9cJ6XOOussV8s9+OCDXRrIZZddppdeeklPP/10p98lEomUnx3H6fTYV+1pmcWLF6u2trZL48xlJFyAcPE3aBf7FzYQP8ELky/vpl/yTZ7PFEfsCe8DAHviOilVWFhobRCXX365Hn74YT355JMpd3wpKSmRtOtqXmlpafLxpqam5NW/kpISdXR0qLm5OeVqX1NTU8ZbL8+bN0+zZs1K/tza2qry8nJft8mWML808eVs79hHsIn3l13sX9hA/AQv4vrlnYosAEBXuU5KrV692veVO46jyy+/XA899JDWr1+vioqKlN9XVFSopKRE9fX1GjVqlCSpo6NDGzZs0JIlSyRJo0ePVo8ePVRfX68pU6ZIkrZu3apXXnlFS5cuTbve/Px85efn+749QXD7pYkr/gAAhI/4CUhFAgoA8M9C7Sl16aWX6p577tFvfvMbFRQUJHsYFBYWat9991UikVB1dbUWLVqkyspKVVZWatGiRerVq5emTZuWXPbiiy/W7NmzVVRUpH79+qmmpkYjRozQxIkTw9y8UNlIQJHoArJLur9pib9rIOqInwAAQLZIOI7jhLbyDD0L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ysvL63RVr6mpqVOmFcG5/PLL9fDDD+uJJ57QgAEDko+XlJRIEscrJA0NDWpqatLo0aPVvXt3de/eXRs2bNB//dd/qXv37sljwPEJT2lpqQ4//PCUxw477DC98847kvgbCtsPfvADXXnllfr3f/93jRgxQuedd56+//3va/HixZI4PogP4qdoIn6KJuKn6CN+ijbip+xFUkpSz549NXr0aNXX16c8Xl9fr/Hjx4c0qtzlOI4uu+wyPfjgg3r88cdVUVGR8vuKigqVlJSkHK+Ojg5t2LCB4xWAqqoqvfzyy3rhhReS/8aMGaNzzz1XL7zwggYPHszxCdmxxx7b6Tbgf/vb3zRo0CBJ/A2F7fPPP1e3bqmn37y8vOQtjTk+iAvip2ghfoo24qfoI36KNuKnLBZGd/Uo2n1L49tvv935y1/+4lRXVzu9e/d23n777bCHlnO++93vOoWFhc769eudrVu3Jv99/vnnyWVuuOEGp7Cw0HnwwQedl19+2TnnnHO43WeI/vnuMY7D8QnbM88843Tv3t25/vrrnddff935xS9+4fTq1cu5++67k8twjMIzffp056CDDkre0vjBBx90DjjgAGfOnDnJZTg+iAvip+ggfoof4qdoIX6KNuKn7EVS6p/cfPPNzqBBg5yePXs6X//615O30EWwJKX9t3r16uQyO3fudK677jqnpKTEyc/Pd775zW86L7/8cniDznFfDao4PuFbu3atM3z4cCc/P9859NBDnVWrVqX8nmMUntbWVueKK65wBg4c6Oyzzz7O4MGDnR/+8IdOe3t7chmOD+KE+CkaiJ/ih/gpeoifoov4KXslHMdxwqnRAgAAAAAAQK6ipxQAAAAAAAACR1IKAAAAAAAAgSMpBQAAAAAAgMCRlAIAAAAAAEDgSEoBAAAAAAAgcCSlAAAAAAAAEDiSUgAAAAAAAAgcSSkAsTZ//nwdeeSRYQ8jowsuuEBnnHFG2MMAAABIQQwFIAoSjuM4YQ8CANJJJBJ7/P306dN10003qb29XUVFRQGNape3335bFRUVyZ979OihgQMH6oILLtAPf/jD5NhbWlrkOI7233//QMcHAAByFzEUgLjoHvYAACCTrVu3Jv9/33336dprr9WmTZuSj+27777ab7/9tN9++4UxPEnSo48+qmHDhqm9vV1PP/20/uM//kOlpaW6+OKLJUmFhYWhjQ0AAOQmYigAccH0PQCRVVJSkvxXWFioRCLR6bGvlp7vLvVetGiRiouLtf/++6u2tlZffvmlfvCDH6hfv34aMGCA7rjjjpR1vf/++5o6dar69u2roqIinX766Xr77bf3OsaioiKVlJRo0KBBOvfcczV+/Hj9+c9/7jSe3Y4//nh973vf05w5c9SvXz+VlJRo/vz5hnsKAADg/xBDAYgLklIAss7jjz+uDz74QE8++aSWLVum+fPna/Lkyerbt6/+9Kc/6ZJLLtEll1yid999V5L0+eef64QTTtB+++2nJ598Uk8//bT2228/fetb31JHR4fr9T733HP685//rLFjx+5xuTvvvFO9e/fWn/70Jy1dulQLFixQfX290TYDAACYIoYCEDSSUgCyTr9+/fRf//Vf+trXvqaLLrpIX/va1/T555/rqquuUmVlpebNm6eePXvq97//vSRpzZo16tatm372s59pxIgROuyww7R69Wq98847Wr9+/R7XNX78eO23337q2bOnjjrqKE2ZMkXnn3/+Hp8zcuRIXXfddaqsrNT555+vMWPG6LHHHvNr8wEAALqEGApA0OgpBSDrDBs2TN26/V/Ovbi4WMOHD0/+nJeXp6KiIjU1NUmSGhoa9MYbb6igoCDldb744gu9+eabe1zXfffdp8MOO0zbt2/Xyy+/rO9973vq27evbrjhhozPGTlyZMrPpaWlybEAAACEhRgKQNBISgHIOj169Ej5OZFIpH1s586dkqSdO3dq9OjR+sUvftHptfr377/HdZWXl+uQQw6RJB122GF66623dM0112j+/PnaZ599XI9v91gAAADCQgwFIGgkpQDkvK9//eu67777dOCBB6pPnz5Gr5WXl6cvv/xSHR0dGQMqAACAbEAMBcAUPaUA5Lxzzz1XBxxwgE4//XQ99dRT2rx5szZs2KArrrhC77333h6f+/HHH6uxsVHvvfeefvvb3+rHP/6xTjjhBOPADAAAIOqIoQCYolIKQM7r1auXnnzySc2dO1dnnXWWtm3bpoMOOkhVVVV7DYwmTpwoadfVvdLSUp1yyim6/vrrgxg2AABAqIihAJhKOI7jhD0IAAAAAAAA5Bam7wEAAAAAACBwJKUAAAAAAAAQOJJSAAAAAAAACBxJKQAAAAAAAASOpBQAAAAAAAACR1IKAAAAAAAAgSMpBQAAAAAAgMCRlAIAAAAAAEDgSEoBAAAAAAAgcCSlAAAAAAAAEDiSUgAAAAAAAAgcSSkAAAAAAAAEjqQUAAAAAAAAAkdSCgAAAAAAAIEjKQUAAAAAAIDAkZQCAAAAAABA4EhKAQAAAAAAIHAkpQCEqq6uTolEQs8995wvr5dIJHTZZZf58lr//Jrz58/v8vOvvvpqTZ48WQcddJASiYQuuOCCtMsdfPDBSiQSaf/ts88+XV4/AADIDdkeV7377rs688wzNXjwYPXu3VuFhYUaNWqUbrrpJn355Ze+jhNAMLqHPQAAyHbLly/XyJEjddppp+mOO+7IuNxDDz2k9vb2lMfeeecdTZ06VWeeeabtYQIAAETaZ599pj59+uiaa67RwIED1dHRoXXr1unyyy/XCy+8oJ/97GdhDxGARySlAMCybdu2qVu3XYWpd911V8blRo0a1emx//3f/5Uk/cd//IedwQEAAMTEoYceqjvvvDPlsZNPPllNTU268847dfPNNys/Pz+k0QHoCqbvAYi8L774QrNnz9aRRx6pwsJC9evXT+PGjdNvfvObjM+57bbbNHToUOXn5+vwww/XmjVrOi3T2NioGTNmaMCAAerZs6cqKipUW1vre/n37oSUV47jaPXq1Ro8eLD+5V/+xdcxAQCA3BT3uCqd/v37q1u3bsrLy7O+LgD+olIKQOS1t7frk08+UU1NjQ466CB1dHTo0Ucf1VlnnaXVq1fr/PPPT1n+4Ycf1hNPPKEFCxaod+/eWrlypc455xx1795d3/72tyXtCpyOPvpodevWTddee62GDBmiP/zhD1q4cKHefvttrV69eo9jOvjggyVJb7/9to1NliQ9+uij2rJlixYuXKhEImFtPQAAIHdkQ1zlOI527Nihbdu26ZFHHlFdXZ1mz56t7t35egvEDX+1ACKvsLAwJZjZsWOHqqqq1NzcrBUrVnQKnj766CM9++yzKi4uliSdcsopGj58uObNm5cMnubPn6/m5ma9+uqrGjhwoCSpqqpK++67r2pqavSDH/xAhx9+eMYxBRH03H777crLy8vYGB0AAMCrbIirlixZonnz5kna1Tj9qquu0sKFCz29BoBoYPoegFh44IEHdOyxx2q//fZT9+7d1aNHD91+++167bXXOi1bVVWVDJwkKS8vT1OnTtUbb7yh9957T5L03//93zrhhBNUVlamL7/8Mvnv5JNPliRt2LBhj+N544039MYbb/i4hak++eQT/frXv9a3vvUtHXTQQdbWAwAAck/c46oLLrhAzz77rP73f/9Xc+bM0Y033qjLL7/c9fMBRAeVUgAi78EHH9SUKVN09tln6wc/+IFKSkrUvXt33XLLLWnvZldSUpLxsY8//lgDBgzQhx9+qLVr16pHjx5p1/nRRx/5uxEe3X333Wpvb6fBOQAA8FU2xFUlJSXJMUyaNEl9+/bVlVdeqYsuuijtjWMARBdJKQCRd/fdd6uiokL33XdfSm+l9vb2tMs3NjZmfKyoqEiSdMABB2jkyJG6/vrr075GWVmZ6bCN3H777SouLtbkyZNDHQcAAMgu2RhXHX300ZKkv/3tbySlgJghKQUg8hKJhHr27JkSODU2Nma8S8xjjz2mDz/8MFlqvmPHDt13330aMmSIBgwYIEmaPHmy1q1bpyFDhqhv3772N8KD5557Ti+99JLmzJlDw04AAOCrbIyrnnjiCUnSIYccEvi6AZjh2w6ASHj88cfT3nHllFNO0eTJk/Xggw9q5syZ+va3v613331XP/rRj1RaWqrXX3+903MOOOAA/cu//Iuuueaa5F1i/vrXv6bcvnjBggWqr6/X+PHj9b3vfU9f+9rX9MUXX+jtt9/WunXrdOuttyYDrXR2Bz1u+h9s2LBBf//73yXtCuS2bNmiX/7yl5KkCRMmqH///inL33777ZKkiy++eK+vDQAA8FXZGlddd911+vDDD/XNb35TBx10kP7xj3/od7/7nX7605/q7LPP1ujRo13uIQBRQVIKQCTMnTs37eObN2/WhRdeqKamJt1666264447NHjwYF155ZV67733VFtb2+k5p512moYNG6arr75a77zzjoYMGaJf/OIXmjp1anKZ0tJSPffcc/rRj36kG2+8Ue+9954KCgpUUVGhb33rW3u9yvfll1+63rbrrrsupcHn+vXrtX79ekm7ruwdf/zxyd+1tbXp3nvv1Te/+U0NHTrU9ToAAAB2y9a4asyYMfqv//ov/frXv9bHH3+sffbZR4cffriWL1+u7373u65eA0C0JBzHccIeBAAAAAAAAHJLt7AHAAAAAAAAgNxDUgoAAAAAAACBIykFAAAAAACAwJGUAgAAAAAAQOBISgEAAAAAACBwJKUAAAAAAAAQOJJSAAAAAAAA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A9TU1KSNGzfqiiuuUH5+viZPnixJys7O9q1tAAAgNRFDAQgLhu8BCKy8vLzov+zsbEUikVbLvt31/EBX73nz5ik3N1ddunRReXm59uzZoxtuuEHdunVTr1699MADD7Q41ieffKLx48era9euysnJ0Q9/+ENt3br1kG3MyclRXl6e+vTpo4suukgjRozQK6+80qo9B5x++um67rrrNH36dHXr1k15eXmaNWuW4ZkCAAD4F2IoAGFBUgpA0nn++ee1fft2bdiwQYsWLdKsWbM0duxYde3aVX/961915ZVX6sorr9RHH30kSdq1a5fOOOMMderUSRs2bNDGjRvVqVMnff/731dzc7Pt47788st65ZVXNHz48IOu9+CDD6pjx47661//qoULF2r27NmqrKw0es0AAACmiKEAeI2kFICk061bN/3iF7/Q0Ucfrcsvv1xHH320du3apZtuuknFxcWaOXOmMjIy9Kc//UmStGrVKrVr106//vWvNWjQIB177LFavny5PvzwQ61fv/6gxxoxYoQ6deqkjIwMnXTSSRo3bpwmTpx40G0GDx6s22+/XcXFxZo4caKGDRumtWvXJurlAwAAtAkxFACvUVMKQNIZMGCA2rX7V849NzdXAwcOjP6clpamnJwc1dbWSpKqq6v13nvvKSsrq8V+vv76a73//vsHPdajjz6qY489Vrt379abb76p6667Tl27dtUdd9wRd5vBgwe3+Dk/Pz/aFgAAAL8QQwHwGkkpAEknPT29xc+RSCTmsn379kmS9u3bp6FDh+rhhx9uta/u3bsf9FiFhYU66qijJEnHHnusPvjgA916662aNWuWDjvsMNvtO9AWAAAAvxBDAfAaSSkAKe/EE0/Uo48+qh49eqhz585G+0pLS9OePXvU3NwcN6ACAABIBsRQAExRUwpAyrvooot0xBFH6Ic//KFeeOEFbdmyRVVVVbr++uv18ccfH3TbL774QjU1Nfr444/1zDPP6Oc//7nOOOMM48AMAAAg6IihAJiipxSAlNehQwdt2LBBM2bM0Pnnn68vv/xSPXv2VElJySEDo1GjRkna/3QvPz9fZ599tubOnetFswEAAHxFDAXAVMSyLMvvRgAAAAAAACC1MHwPAAAAAAAAniMpBQAAAAAAAM+RlAIAAAAAAIDnSEoBAAAAAADAcySlAAAAAAAA4DmSUgAAAAAAAPAcSSkAAAAAAAB4jqQUAAAAAAAAPEdSCgAAAAAAAJ4jKQUAAAAAAADPkZQCAAAAAACA50hKAQAAAAAAwHMkpQAAAAAAAOA5klIAAAAAAADwHEkpAAAAAAAAeI6kFAAAAAAAADxHUgoAAAAAAACeIykFwFcVFRWKRCJ6+eWXE7K/SCSia665JiH7+uY+Z82a1ebtb7nlFo0dO1Y9e/ZUJBLRpZdeGnO9I488UpFIJOa/ww47rM3HBwAAqSHZ46rq6mpdffXVGjRokLKyspSbm6tRo0bp+eefT2gbAXinvd8NAIBkt3jxYg0ePFg/+MEP9MADD8Rd78knn1RTU1OLZR9++KHGjx+v8847z+1mAgAABNojjzyiF198UZdffrmOP/54ffXVV7r33ntVUlKiBx98UBMnTvS7iQAcIikFAC778ssv1a7d/o6pK1asiLvekCFDWi373//9X0nSFVdc4U7jAAAAQmL69On6//6//6/FsrPPPlsnnniiZs+eTVIKCCGG7wEIvK+//lrTpk3TCSecoOzsbHXr1k2nnHKK/vCHP8Td5r777lP//v2VmZmp4447TqtWrWq1Tk1NjaZMmaJevXopIyNDRUVFKi8v1549exLa/gMJKacsy9Ly5cvVt29f/du//VtC2wQAAFJTmOOqHj16tFqWlpamoUOH6qOPPkrYcQB4h55SAAKvqalJO3fuVFlZmXr27Knm5matWbNG559/vpYvX97qqdhTTz2ldevWafbs2erYsaOWLl2qCy+8UO3bt9ePfvQjSfsDp5NPPlnt2rXTbbfdpn79+unPf/6z5syZo61bt2r58uUHbdORRx4pSdq6dasbL1mStGbNGm3btk1z5sxRJBJx7TgAACB1JFtctWfPHr3wwgsaMGCA420B+I+kFIDAy87ObhHM7N27VyUlJaqrq9OSJUtaBU+ff/65XnrpJeXm5kra36174MCBmjlzZjR4mjVrlurq6vT222+rd+/ekqSSkhIdfvjhKisr0w033KDjjjsubpvat3f/4/P+++9XWlpa3MLoAAAATiVbXDVr1iy99957+v3vf9/mfQDwD8P3AITC448/rlNPPVWdOnVS+/btlZ6ervvvv1/vvPNOq3VLSkqigZO0v1v3+PHj9d577+njjz+WJP3xj3/UGWecoYKCAu3Zsyf676yzzpIkVVVVHbQ97733nt57770EvsKWdu7cqd///vf6/ve/r549e7p2HAAAkHqSJa769a9/rblz52ratGn64Q9/6Hh7AP4jKQUg8J544gmNGzdOPXv21EMPPaQ///nPeumll3T55Zfr66+/brV+Xl5e3GVffPGFJOnTTz/V6tWrlZ6e3uLfga7fn3/+uYuv6NAeeughNTU1UeAcAAAkVLLEVcuXL9eUKVP0k5/8RHfeeWfC9w/AGwzfAxB4Dz30kIqKivToo4+2qK3U1NQUc/2ampq4y3JyciRJRxxxhAYPHqy5c+fG3EdBQYFps43cf//9ys3N1dixY31tBwAASC7JEFctX75cV1xxhSZNmqR7772X2ptAiJGUAhB4kUhEGRkZLQKOmpqauLPErF27Vp9++mm0q/nevXv16KOPql+/furVq5ckaezYsXr66afVr18/de3a1f0X4cDLL7+sN954Q9OnT/ekdhUAAEgdYY+rKioqdMUVV+jiiy/Wr3/9axJSQMjxbQdAIDz//PMxZ1w5++yzNXbsWD3xxBO66qqr9KMf/UgfffSR/uu//kv5+fl69913W21zxBFH6N/+7d906623RmeJ+fvf/95i+uLZs2ersrJSI0aM0HXXXaejjz5aX3/9tbZu3aqnn35a9957bzTQiuWoo46SJFv1D6qqqvTZZ59J2h/Ibdu2Tb/97W8lSSNHjlT37t1brH///fdLkiZPnnzIfQMAAHxbssZVjz/+uCZPnqwTTjhBU6ZM0Ysvvtji90OGDFFmZuZB9wEgWEhKAQiEGTNmxFy+ZcsWXXbZZaqtrdW9996rBx54QH379tWNN96ojz/+WOXl5a22+cEPfqABAwbolltu0Ycffqh+/frp4Ycf1vjx46Pr5Ofn6+WXX9Z//dd/6c4779THH3+srKwsFRUV6fvf//4hn/Lt2bPH9mu7/fbbWxT4XL9+vdavXy9JWrdunU4//fTo7xobG/XII4/oe9/7nvr372/7GAAAAAcka1z1P//zP9q3b59eeeUVnXrqqTFf35FHHmlrXwCCIWJZluV3IwAAAAAAAJBamH0PAAAAAAAAniMpBQAAAAAAAM+RlAIAAAAAAIDnSEoBAAAAAADAcySlAAAAAAAA4DmSUgAAAAAAAPBce78bEAT79u3T9u3blZWVpUgk4ndzAABAgFiWpS+//FIFBQVq147neQcQPwEA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/7l69OihZ599VoWFhRowYIDt/ZSVlenf//3f1bt3b9XW1mrOnDlqaGjQpEmTFIlEVFpaqnnz5qm4uFjFxcWaN2+eOnTooAkTJkiSsrOzNXnyZE2bNk05OTnq1q2bysrKNGjQII0aNaotLw2IyWR2tniCVhjcqyAzLEwCdifbOznvJj2gYh3H9IlxKrwPgEQifsIBbkyS4UadP5Nahk72abq9G5PccI8DAG84TkpVVVXprLPO0qmnnqoNGzZo7ty56tGjh9544w39+te/1m9/+1vb+/r444914YUX6vPPP1f37t31ne98R3/5y1/Up08fSdL06dPV2Nioq666SnV1dRo+fLiee+45ZWVlRfexePFitW/fXuPGjVNjY6NKSkpUUVGhtLQ0py8NScKrwMTP2WPs7s/J9qlcZ8HktZv2ajI97149hTZJfkmp/f6yi3OU3IifUoNpT6lE/837WbfQVJjbDgCwL2JZluVkg1NOOUUXXHCBpk6dqqysLL3++uvq27evXnrpJZ177rn65JNP3GqraxoaGpSdna36+npfCp3DH066yHtVLNykdoOXvZqSbShX0Hqtmb633KgBYpeXs0ACXklEnED8lBrciA1iifX5Getz1klcYzKU3UkMYhpT+XkvDktcAwBBYDdOcNxT6s0339TKlStbLe/evbu++OILp7sDPGFSfyDe9qZBlckXcicBoVcFu1M1UHOjCL8TJu9DJ18i3EiUAamE+Ck1mCR2nLC7fbxnz3YTWH5+dnvVA5zhewDgL8dJqS5dumjHjh0qKipqsfzVV19Vz549E9YwoK1Mgions815FVC6ERTZHYplmnAJc0Bn9z1j+j4wPUdhPu9hbjvgFPFTanAjAWXa+zWWRCfPnAzddqNOZyzUQgSAcHCclJowYYJmzJihxx9/XJFIRPv27dOf/vQnlZWVaeLEiW60Ed/Al7hDMynKafpUzo0Eg931TIfvhaU7vRtMhu85GRph99hO3ocmNdTiMbmWThK7YX7PAE4RP6Uu0yH3YalHGIvJg0I37lvE0QAQPI6TUnPnztWll16qnj17yrIsHXfccdq7d68mTJigW265xY024hu4cQabnwGUl++NVHgf+jlkwcn7yI33hxs1peweJxXeW2HB9Uks4qfUEOtvJBKJtFpmOimE6YOkRM/U52VdS9OJNwAAweI4KZWenq6H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6UOq8WomtaAlUbzk1XTbYf6yAoSFSZxA/AQ+PwEAqSjhhc4rKip011136a9//avS0tJa/G7v3r0aPny4SktLdfHFF5u13AcEVamJIBFe4z0HhJNJnED8BD8/+8eNGxdzeazhctyjAACJlPCk1He/+11dffXV+vGPfxzz94899pjuuusubdiwoW0t9hFBVfAFcVhdsgVqqfAa3eD3e9NPvGeQKkziBOInxOLGvSNWAiperSY+vwEAbkt4UqpHjx568cUXdeSRR8b8/ZYtW3TyySfrs88+a1OD/URQBeDbCNgBHGASJxA/uScsDwWcJItSAfdXAEgNCS10LklfffWVGhoa4v7+yy+/1K5du5y1EgACKtkCZNMi+sl2PgCvED+5JyyfS04SUIlO2HiVuHNynLBcNwCAN2wnpYqLi7Vp0yYNHjw45u83btyo4uLihDUMcBtP6nAwfr4/3PgSwXsb8AfxE5xI9Ge1k9lcnWzf1vUAAPg220mpCRMm6JZbbtGIESNaBVavv/66brvtNk2fPj3hDQTckioBFMm3tkm2aax5HwD+IH7yXtA+74LWniAcPwyCeN0AIBnZrim1e/dujR49Whs3btSoUaN0zDHHKBKJ6J133tGaNWt06qmnqrKyUunp6W63OeH8romAtgtrN3cgbAjOkcpM4gTiJ7iBz+RDS3RvMACAMwkvdC7tD6wWL16slStX6t1335VlWerfv78mTJig0tJSZWRkJKTxXiOoQlAQZAab39fH5Ph+tz3RSCC3XbK9F7xgGicQPwEAgFTjSlIqWRFUAbCDL/NAaiJOiI3zYo/pvYN7T+JwLgHAOwmffQ9A6knl3igErgCAIODekzicSwAIHnpKiSd9CB8SJsktlZOBdnGO4CXihNg4L/4hDgAABF0oekrdc889uueee7R161ZJ0oABA3TbbbfprLPOkiRZlqXy8nItW7ZMdXV1Gj58uO6++24NGDAguo+mpiaVlZXpkUceUWNjo0pKSrR06VL16tXLj5cEeILZ2ZIb5/3QOEdIZcRPsIsEPgAg6HztKbV69WqlpaXpqKOOkiQ9+OCDuvPOO/Xqq69qwIABWrBggebOnauKigr1799fc+bM0YYNG7R582ZlZWVJkn76059q9erVqqioUE5OjqZNm6adO3equrpaaWlpttrBkz4A3+ZGko7EH1JJMr3fgxYnED+FSzL9LQAAYJdrhc5nz56tsrIydejQocXyxsZG3Xnnnbrtttva1uL/p1u3brrzzjt1+eWXq6CgQKWlpZoxY4ak/U/1cnNztWDBAk2ZMkX19fXq3r27VqxYofHjx0uStm/frsLCQj399NMaM2aMrWMSVAEAgHgSEScQP6UuklIAgFTkWlIqLS1NO3bsUI8ePVos/+KLL9SjRw/t3bu3TQ3eu3evHn/8cU2aNEmvvvqqDjvsMPXr10+vvPKKhgwZEl3vhz/8obp06aIHH3xQzz//vEpKSrRz50517do1us7xxx+vc889V+Xl5TGP1dTUpKampujPDQ0NKiwsJKiCK+g6DwDhlojkC/FT6gpzz1s/E2rETwAQbq7VlLIsS5FIpNXy119/Xd26dXO6O7355ps65ZRT9PXXX6tTp0568sknddxxx2nTpk2SpNzc3Bbr5+bmatu2bZKkmpoaZWRktAioDqxTU1MT95jz58+PG3ABiUbwhIPhCTqQGoifUpcbn+le3Sf8vB9xLwSA1GA7KdW1a1dFIhFFIhH179+/RWC1d+9e/fOf/9SVV17puAFHH320XnvtNf3f//2ffve732nSpEmqqqqK/v7bAVy8oM7JOjNnztTUqVOjPx940gcAXkuVoJvkG1JVKsRPTz75ZIthifxttx2flQCAVGM7KbVkyRJZlqXLL79c5eXlys7Ojv4uIyNDRx55pE455RTHDcjIyIgW6hw2bJheeukl/fznP4/WQaipqVF+fn50/dra2ujTv7y8PDU3N6uurq7F077a2lqNGDEi7jEzMzOVmZnpuK1OEVgEG9en7Th3iROWc2naziC+JsALqRA/nXfeeQzfO4hx48a1WvbYY4/FXJfPSgBAqrGdlJo0aZIkqaioSCNGjFB6erorDbIsS01NTSoqKlJeXp4qKyujNRGam5tVVVWlBQsWSJKGDh2q9PR0VVZWRm/4O3bs0FtvvaWFCxe60j4nwhJYhOVLcaIlW+0FLyXja/JLWM5lWNoJBA3xE2IloKiXBADAfo5rShUVFWnHjh1xf9+7d2/b+7rpppt01llnqbCwUF9++aVWrVql9evX69lnn1UkElFpaanmzZun4uJiFRcXa968eerQoYMmTJggScrOztbkyZM1bdo05eTkqFu3biorK9OgQYM0atQopy8ttOjBACl+gBsL1zxx+GIB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9cADD+hHP/qR8vPz9fDDD2vVqlXq16+fJk6cqMWLF3vYYgBOtfe7AQCQ7L788ku1a7f/GYCdJ3ZDhw7VEUcc4XazAAAAAs1uDPXAAw+oT58+euyxx6LrjxkzRq+99poqKir0s5/9zJP2AnCOnlIAAu/rr7/WtGnTdMIJJyg7O1vdunXTKaecoj/84Q9xt7nvvvvUv39/ZWZm6rjjjtOqVatarVNTU6MpU6aoV69eysjIUFFRkcrLy7Vnz56Etv9AcAQAAOClVImh0tPT1alTpxbrRyIRde7cmTIIQMDRUwpA4DU1NWnnzp0qKytTz5491dzcrDVr1uj888/X8uXLNXHixBbrP/XUU1q3bp1mz56tjh07aunSpbrwwgvVvn17/ehHP5K0P5g6+eST1a5dO912223q16+f/vznP2vOnDnaunWrli9fftA2HXnkkZKkrVu3Jvz1Dho0SLW1tTriiCM0ZswYzZkzR7179074cQAAQHJLlRjq2muv1QUXXKC5c+fqJz/5iSKRiCoqKlRdXa1HHnkkYccBkHgkpQAEXnZ2dosAZ+/evSopKVFdXZ2WLFnSKqD6/PPP9dJLLyk3N1eSdPbZZ2vgwIGaOXNmNKCaNWuW6urq9Pbbb0cTPiUlJTr88MNVVlamG264Qccdd1zcNrVvn/iPz379+mnu3LkaMmSIDjvsML344otauHChnnvuOVVXV6tnz54JPyYAAEheqRJDnX/++XriiSc0adIk3XLLLZKkww8/XA8++KAuuOCChB8PQOIwpgRAKDz++OM69dRT1alTJ7Vv317p6em6//779c4777Rat6SkJBpMSVJaWprGjx+v9957Tx9//LEk6Y9//KPOOOMMFRQUaM+ePdF/Z511liSpqqrqoO1577339N577yXwFUqXXHKJbrrpJp111lk644wzNGPGDD3zzDP67LPPtHDhwoQeCwAApIZUiKGeffZZXXzxxTr//PP1zDPPqLKyUldccYUuvfTSQ/bcAuAvekoBCLwnnnhC48aN0wUXXKAbbrhBeXl5at++ve655x498MADrdbPy8uLu+yLL75Qr1699Omnn2r16tVKT0+PeczPP/88sS+ijU4++WT1799ff/nLX/xuCgAACJlUiKEsy9Lll1+u733vey1e06hRo1RfX69rr71W48aNU8eOHT1tFwB7SEoBCLyHHnpIRUVFevTRRxWJRKLLm5qaYq5fU1MTd1lOTo4k6YgjjtDgwYM1d+7cmPsoKCgwbXbCWJZFsXQAAOBYKsRQn376qXbs2KEpU6a0+t1JJ52k3/zmN9q6dasGDBjgabsA2ENSCkDgRSIRZWRktAimampq4s4cs3btWn366afR7ud79+7Vo48+qn79+qlXr16SpLFjx+rpp59Wv3791LVrV/dfRBv95S9/0bvvvqvrrrvO76YAAICQSYUYqmvXrjrssMNi9ir/85//rHbt2ik/P9+HlgGwg6QUgEB4/vnnY87CcvbZZ2vs2LF64okndNVVV+lHP/qRPvroI/3Xf/2X8vPz9e6777ba5ogjjtC//du/6dZbb43OHPP3v/+9xZTGs2fPVmVlpUaMGKHrrrtORx99tL7++mtt3bpVTz/9tO69995o8BXLUUcdJUm2aiJUVVXps88+k7Q/uNu2bZt++9vfSpJGjhyp7t27S5KOP/54XXzxxTr22GOjhc7vvPNO5eXlafr06Yc8DgAASD2pHkNlZmbqqquu0qJFizRx4kSNHz9eaWlp+v3vf6+VK1dq8uTJ6tat2yGPBcAnFgD4aPny5ZakuP+2bNliWZZl3XHHHdaRRx5pZWZmWscee6z1q1/9yrr99tutb3+MSbKuvvpqa+nSpVa/fv2s9PR065hjjrEefvjhVsf+7LPPrOuuu84qKiqy0tPTrW7dullDhw61br75Zuuf//xni33efvvtLbbt06eP1adPH1uvceTIkXFf37p166Lr/fjHP7aOOuooq2PHjlZ6errVp08f68orr7S2b99u6zgAACB1EEOti663d+9e61e/+pU1bNgwq0uXLlbnzp2tIUOGWHfddZfV3Nxs61gA/BGxLMtyP/UFAAAAAAAA/AuVcwEAAAAAAOA5klIAAAAAAADwHEkpAAAAAAAAeI6kFAAAAAAAADxHUgoAAAAAAACeIykFAAAAAAAAz7X3uwFBsG/fPm3fvl1ZWVmKRCJ+NwcAAASIZVn68ssvVVBQoHbteJ53APETAACIx278RFJK0vbt21VYWOh3MwAAQIB99NFH6tWrl9/NCAziJwAAcCiHip9ISknKysqStP9kde7c2fPjL1++PObyyy67zOOWAACAb2toaFBhYWE0XsB+fsdPAAAguOzGTySlpGiX886dO/sSVJ122mkxl7/77ru2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",
      "text/plain": [
       "<Figure size 1200x1200 with 8 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "example_batch = next(iter(train_dataset))\n",
    "visualize_training_batch(example_batch)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "9f1d2ed1-01a3-4cd1-9ac8-9393b7b920e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initialize the ELM model\n",
    "model = ELM(\n",
    "    num_synapse=num_synapse,\n",
    "    num_output=num_output, \n",
    "    num_memory=num_memory, \n",
    "    memory_tau_min=memory_tau_min,\n",
    "    memory_tau_max=memory_tau_max,\n",
    "    learn_memory_tau=learn_memory_tau,\n",
    "    mlp_num_layers=mlp_num_layers,\n",
    "    lambda_value=lambda_value, \n",
    "    delta_t=delta_t\n",
    ")\n",
    "\n",
    "# Initialize the loss function, optimizer, and scheduler\n",
    "criterion = nn.CrossEntropyLoss()\n",
    "optimizer = optim.Adamax(model.parameters(), lr=learning_rate)\n",
    "\n",
    "# Define scheduler\n",
    "scheduler = CosineAnnealingLR(optimizer, T_max=batches_per_epoch*num_epochs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "91118916-690c-4f82-80e8-b2177fa164d8",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1 Loss: 2.082: 100%|████████████████████| 814/814 [00:39<00:00, 20.69it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████| 205/205 [00:05<00:00, 39.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 1, Training Accuracy: 0.28, Validation Accuracy: 0.49\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2 Loss: 1.161: 100%|███████████████████████████████████████████████████████████| 814/814 [00:42<00:00, 19.03it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████| 205/205 [00:05<00:00, 39.12it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 2, Training Accuracy: 0.56, Validation Accuracy: 0.72\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3 Loss: 0.685: 100%|███████████████████████████████████████████████████████████| 814/814 [00:42<00:00, 19.20it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████| 205/205 [00:05<00:00, 39.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 3, Training Accuracy: 0.76, Validation Accuracy: 0.79\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4 Loss: 0.507: 100%|███████████████████████████████████████████████████████████| 814/814 [00:43<00:00, 18.82it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████| 205/205 [00:05<00:00, 39.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 4, Training Accuracy: 0.82, Validation Accuracy: 0.84\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5 Loss: 0.367: 100%|███████████████████████████████████████████████████████████| 814/814 [00:42<00:00, 19.06it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████| 205/205 [00:04<00:00, 41.04it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 5, Training Accuracy: 0.87, Validation Accuracy: 0.83\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6 Loss: 0.253: 100%|███████████████████████████████████████████████████████████| 814/814 [00:42<00:00, 19.04it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████| 205/205 [00:04<00:00, 41.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 6, Training Accuracy: 0.91, Validation Accuracy: 0.91\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7 Loss: 0.185: 100%|███████████████████████████████████████████████████████████| 814/814 [00:42<00:00, 19.25it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████| 205/205 [00:04<00:00, 41.37it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 7, Training Accuracy: 0.93, Validation Accuracy: 0.91\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8 Loss: 0.136: 100%|███████████████████████████████████████████████████████████| 814/814 [00:42<00:00, 19.05it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████| 205/205 [00:05<00:00, 39.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 8, Training Accuracy: 0.95, Validation Accuracy: 0.93\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9 Loss: 0.106: 100%|███████████████████████████████████████████████████████████| 814/814 [00:42<00:00, 18.97it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████| 205/205 [00:05<00:00, 40.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 9, Training Accuracy: 0.96, Validation Accuracy: 0.94\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10 Loss: 0.091: 100%|██████████████████████████████████████████████████████████| 814/814 [00:42<00:00, 19.06it/s]\n",
      "100%|████████████████████████████████████████████████████████████████████████████████| 205/205 [00:04<00:00, 41.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 10, Training Accuracy: 0.97, Validation Accuracy: 0.94\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████| 283/283 [00:07<00:00, 39.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Accuracy: 0.88\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# Initialize the best validation accuracy to 0\n",
    "best_valid_accuracy = 0.0\n",
    "best_model_state_dict = model.state_dict().copy()\n",
    "\n",
    "# Training loop\n",
    "for epoch in range(num_epochs):\n",
    "    # Training\n",
    "    model.train()\n",
    "    running_loss = 0.0\n",
    "    correct_predictions = 0\n",
    "    total_predictions = 0\n",
    "    pbar = tqdm(enumerate(train_dataset, 0), total=batches_per_epoch)\n",
    "    for i, data in pbar:\n",
    "        inputs, labels = data\n",
    "        \n",
    "        # Apply dropout\n",
    "        dropout_mask = torch.rand_like(inputs) < dropout\n",
    "        inputs[dropout_mask] = 0\n",
    "        \n",
    "        # Perform a single training step\n",
    "        optimizer.zero_grad()\n",
    "        outputs = model(inputs)\n",
    "        outputs = outputs[:,-1,:] # last time step prediction\n",
    "        loss = criterion(outputs, labels)\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        scheduler.step()\n",
    "\n",
    "        # Update running loss\n",
    "        running_loss += loss.item()\n",
    "        pbar.set_description(f\"Epoch {epoch+1} Loss: {running_loss / (i+1):.3f}\")\n",
    "\n",
    "        # Calculate accuracy\n",
    "        _, predicted = torch.max(outputs.data, 1)\n",
    "        correct_predictions += (predicted == labels).sum().item()\n",
    "        total_predictions += labels.size(0)\n",
    "\n",
    "    training_accuracy = correct_predictions / total_predictions\n",
    "\n",
    "    # Validation\n",
    "    model.eval()\n",
    "    valid_loss = 0.0\n",
    "    correct_predictions = 0\n",
    "    total_predictions = 0\n",
    "    for i, data in tqdm(enumerate(valid_dataset, 0), total=valid_batches_per_epoch):\n",
    "        with torch.no_grad():\n",
    "            inputs, labels = data\n",
    "            dropout_mask = torch.rand_like(inputs) < dropout\n",
    "            inputs[dropout_mask] = 0\n",
    "        \n",
    "            outputs = model(inputs)\n",
    "            outputs = outputs[:,-1,:] # last time step prediction\n",
    "            loss = criterion(outputs, labels)\n",
    "\n",
    "        valid_loss += loss.item()\n",
    "\n",
    "        # Calculate accuracy\n",
    "        _, predicted = torch.max(outputs.data, 1)\n",
    "        correct_predictions += (predicted == labels).sum().item()\n",
    "        total_predictions += labels.size(0)\n",
    "\n",
    "    validation_accuracy = correct_predictions / total_predictions\n",
    "    \n",
    "    # Copy model state dict if validation accuracy has improved\n",
    "    if validation_accuracy > best_valid_accuracy:\n",
    "        best_valid_accuracy = validation_accuracy\n",
    "        best_model_state_dict = model.state_dict().copy()\n",
    "\n",
    "    # Print statistics\n",
    "    print(f'Epoch: {epoch+1}, Training Accuracy: {training_accuracy:.2f}, Validation Accuracy: {validation_accuracy:.2f}')\n",
    "\n",
    "# Load the best model\n",
    "model.load_state_dict(best_model_state_dict)\n",
    "    \n",
    "# Test\n",
    "model.eval()\n",
    "test_loss = 0.0\n",
    "correct_predictions = 0\n",
    "total_predictions = 0\n",
    "for i, data in tqdm(enumerate(test_dataset, 0), total=test_batches_per_epoch):\n",
    "    with torch.no_grad():\n",
    "        inputs, labels = data\n",
    "        dropout_mask = torch.rand_like(inputs) < dropout\n",
    "        inputs[dropout_mask] = 0\n",
    "        \n",
    "        outputs = model(inputs)\n",
    "        outputs = outputs[:,-1,:] # last time step prediction\n",
    "        loss = criterion(outputs, labels)\n",
    "\n",
    "    test_loss += loss.item()\n",
    "\n",
    "    # Calculate accuracy\n",
    "    _, predicted = torch.max(outputs.data, 1)\n",
    "    correct_predictions += (predicted == labels).sum().item()\n",
    "    total_predictions += labels.size(0)\n",
    "\n",
    "test_accuracy = correct_predictions / total_predictions\n",
    "\n",
    "# Print statistics\n",
    "print(f'Test Accuracy: {test_accuracy:.2f}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "de1ebff9-c1f4-4126-8ffc-39094a09f727",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.9.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
