{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "omjx22T_NO9b"
   },
   "source": [
    "## Confirm runtime settings"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "PH3dsPuUNK4v",
    "outputId": "84cf0218-dd4e-417d-f6e6-46714a4397e8"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Wed Sep 29 09:55:28 2021       \n",
      "+-----------------------------------------------------------------------------+\n",
      "| NVIDIA-SMI 470.63.01    Driver Version: 460.32.03    CUDA Version: 11.2     |\n",
      "|-------------------------------+----------------------+----------------------+\n",
      "| GPU  Name        Persistence-M| Bus-Id        Disp.A | Volatile Uncorr. ECC |\n",
      "| Fan  Temp  Perf  Pwr:Usage/Cap|         Memory-Usage | GPU-Util  Compute M. |\n",
      "|                               |                      |               MIG M. |\n",
      "|===============================+======================+======================|\n",
      "|   0  Tesla T4            Off  | 00000000:00:04.0 Off |                    0 |\n",
      "| N/A   34C    P8     9W /  70W |      0MiB / 15109MiB |      0%      Default |\n",
      "|                               |                      |                  N/A |\n",
      "+-------------------------------+----------------------+----------------------+\n",
      "                                                                               \n",
      "+-----------------------------------------------------------------------------+\n",
      "| Processes:                                                                  |\n",
      "|  GPU   GI   CI        PID   Type   Process name                  GPU Memory |\n",
      "|        ID   ID                                                   Usage      |\n",
      "|=============================================================================|\n",
      "|  No running processes found                                                 |\n",
      "+-----------------------------------------------------------------------------+\n"
     ]
    }
   ],
   "source": [
    "gpu_info = !nvidia-smi\n",
    "gpu_info = '\\n'.join(gpu_info)\n",
    "if gpu_info.find('failed') >= 0:\n",
    "  print('Select the Runtime > \"Change runtime type\" menu to enable a GPU accelerator, ')\n",
    "  print('and then re-execute this cell.')\n",
    "else:\n",
    "  print(gpu_info)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "6Ux88hXjNN_T",
    "outputId": "d30b11f6-c022-4f0b-8cb1-1cbe67655768"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Your runtime has 27.3 gigabytes of available RAM\n",
      "\n",
      "You are using a high-RAM runtime!\n"
     ]
    }
   ],
   "source": [
    "from psutil import virtual_memory\n",
    "ram_gb = virtual_memory().total / 1e9\n",
    "print('Your runtime has {:.1f} gigabytes of available RAM\\n'.format(ram_gb))\n",
    "\n",
    "if ram_gb < 20:\n",
    "  print('To enable a high-RAM runtime, select the Runtime > \"Change runtime type\"')\n",
    "  print('menu, and then select High-RAM in the Runtime shape dropdown. Then, ')\n",
    "  print('re-execute this cell.')\n",
    "else:\n",
    "  print('You are using a high-RAM runtime!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "id": "NEtk8IflNOiw"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "id": "Gbi4XpxyNOl0"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "uvSEUTGKNbiB"
   },
   "source": [
    "## Main Notebook"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "scQQPiLjaUWb",
    "outputId": "fd7bb795-d3da-4757-a6c9-2516ca7a0225"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Get:1 https://cloud.r-project.org/bin/linux/ubuntu bionic-cran40/ InRelease [3,626 B]\n",
      "Ign:2 https://developer.download.nvidia.com/compute/cuda/repos/ubuntu1804/x86_64  InRelease\n",
      "Ign:3 https://developer.download.nvidia.com/compute/machine-learning/repos/ubuntu1804/x86_64  InRelease\n",
      "Hit:4 https://developer.download.nvidia.com/compute/cuda/repos/ubuntu1804/x86_64  Release\n",
      "Hit:5 https://developer.download.nvidia.com/compute/machine-learning/repos/ubuntu1804/x86_64  Release\n",
      "Get:6 http://security.ubuntu.com/ubuntu bionic-security InRelease [88.7 kB]\n",
      "Get:7 http://ppa.launchpad.net/c2d4u.team/c2d4u4.0+/ubuntu bionic InRelease [15.9 kB]\n",
      "Get:8 https://cloud.r-project.org/bin/linux/ubuntu bionic-cran40/ Packages [68.5 kB]\n",
      "Hit:9 http://archive.ubuntu.com/ubuntu bionic InRelease\n",
      "Get:11 http://archive.ubuntu.com/ubuntu bionic-updates InRelease [88.7 kB]\n",
      "Hit:13 http://ppa.launchpad.net/cran/libgit2/ubuntu bionic InRelease\n",
      "Hit:14 http://ppa.launchpad.net/deadsnakes/ppa/ubuntu bionic InRelease\n",
      "Get:15 http://archive.ubuntu.com/ubuntu bionic-backports InRelease [74.6 kB]\n",
      "Get:16 http://security.ubuntu.com/ubuntu bionic-security/universe amd64 Packages [1,429 kB]\n",
      "Get:17 http://ppa.launchpad.net/graphics-drivers/ppa/ubuntu bionic InRelease [21.3 kB]\n",
      "Get:18 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 Packages [2,800 kB]\n",
      "Get:19 http://security.ubuntu.com/ubuntu bionic-security/restricted amd64 Packages [606 kB]\n",
      "Get:20 http://security.ubuntu.com/ubuntu bionic-security/main amd64 Packages [2,365 kB]\n",
      "Get:21 http://ppa.launchpad.net/c2d4u.team/c2d4u4.0+/ubuntu bionic/main Sources [1,802 kB]\n",
      "Get:22 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 Packages [2,208 kB]\n",
      "Get:23 http://archive.ubuntu.com/ubuntu bionic-updates/restricted amd64 Packages [638 kB]\n",
      "Get:24 http://ppa.launchpad.net/c2d4u.team/c2d4u4.0+/ubuntu bionic/main amd64 Packages [922 kB]\n",
      "Get:25 http://ppa.launchpad.net/graphics-drivers/ppa/ubuntu bionic/main amd64 Packages [42.0 kB]\n",
      "Fetched 13.2 MB in 4s (3,158 kB/s)\n",
      "Reading package lists... Done\n",
      "Reading package lists... Done\n",
      "Building dependency tree       \n",
      "Reading state information... Done\n",
      "The following additional packages will be installed:\n",
      "  cm-super-minimal fonts-droid-fallback fonts-lato fonts-lmodern\n",
      "  fonts-noto-mono fonts-texgyre ghostscript gsfonts javascript-common\n",
      "  libcupsfilters1 libcupsimage2 libgs9 libgs9-common libijs-0.35 libjbig2dec0\n",
      "  libjs-jquery libkpathsea6 libpotrace0 libptexenc1 libruby2.5 libsynctex1\n",
      "  libtexlua52 libtexluajit2 libzzip-0-13 lmodern pfb2t1c2pfb poppler-data\n",
      "  preview-latex-style rake ruby ruby-did-you-mean ruby-minitest\n",
      "  ruby-net-telnet ruby-power-assert ruby-test-unit ruby2.5\n",
      "  rubygems-integration t1utils tex-common tex-gyre texlive-base\n",
      "  texlive-binaries texlive-latex-base texlive-latex-recommended\n",
      "  texlive-pictures texlive-plain-generic tipa\n",
      "Suggested packages:\n",
      "  fonts-noto ghostscript-x apache2 | lighttpd | httpd poppler-utils\n",
      "  fonts-japanese-mincho | fonts-ipafont-mincho fonts-japanese-gothic\n",
      "  | fonts-ipafont-gothic fonts-arphic-ukai fonts-arphic-uming fonts-nanum ri\n",
      "  ruby-dev bundler debhelper perl-tk xpdf-reader | pdf-viewer\n",
      "  texlive-fonts-recommended-doc texlive-latex-base-doc python-pygments\n",
      "  icc-profiles libfile-which-perl libspreadsheet-parseexcel-perl\n",
      "  texlive-latex-extra-doc texlive-latex-recommended-doc texlive-pstricks\n",
      "  dot2tex prerex ruby-tcltk | libtcltk-ruby texlive-pictures-doc vprerex\n",
      "The following NEW packages will be installed:\n",
      "  cm-super cm-super-minimal dvipng fonts-droid-fallback fonts-lato\n",
      "  fonts-lmodern fonts-noto-mono fonts-texgyre ghostscript gsfonts\n",
      "  javascript-common libcupsfilters1 libcupsimage2 libgs9 libgs9-common\n",
      "  libijs-0.35 libjbig2dec0 libjs-jquery libkpathsea6 libpotrace0 libptexenc1\n",
      "  libruby2.5 libsynctex1 libtexlua52 libtexluajit2 libzzip-0-13 lmodern\n",
      "  pfb2t1c2pfb poppler-data preview-latex-style rake ruby ruby-did-you-mean\n",
      "  ruby-minitest ruby-net-telnet ruby-power-assert ruby-test-unit ruby2.5\n",
      "  rubygems-integration t1utils tex-common tex-gyre texlive-base\n",
      "  texlive-binaries texlive-fonts-recommended texlive-latex-base\n",
      "  texlive-latex-extra texlive-latex-recommended texlive-pictures\n",
      "  texlive-plain-generic tipa\n",
      "0 upgraded, 51 newly installed, 0 to remove and 80 not upgraded.\n",
      "Need to get 163 MB of archives.\n",
      "After this operation, 503 MB of additional disk space will be used.\n",
      "Get:1 http://archive.ubuntu.com/ubuntu bionic/main amd64 fonts-droid-fallback all 1:6.0.1r16-1.1 [1,805 kB]\n",
      "Get:2 http://archive.ubuntu.com/ubuntu bionic/main amd64 fonts-lato all 2.0-2 [2,698 kB]\n",
      "Get:3 http://archive.ubuntu.com/ubuntu bionic/main amd64 poppler-data all 0.4.8-2 [1,479 kB]\n",
      "Get:4 http://archive.ubuntu.com/ubuntu bionic/main amd64 tex-common all 6.09 [33.0 kB]\n",
      "Get:5 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libkpathsea6 amd64 2017.20170613.44572-8ubuntu0.1 [54.9 kB]\n",
      "Get:6 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libptexenc1 amd64 2017.20170613.44572-8ubuntu0.1 [34.5 kB]\n",
      "Get:7 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libsynctex1 amd64 2017.20170613.44572-8ubuntu0.1 [41.4 kB]\n",
      "Get:8 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libtexlua52 amd64 2017.20170613.44572-8ubuntu0.1 [91.2 kB]\n",
      "Get:9 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libtexluajit2 amd64 2017.20170613.44572-8ubuntu0.1 [230 kB]\n",
      "Get:10 http://archive.ubuntu.com/ubuntu bionic/main amd64 t1utils amd64 1.41-2 [56.0 kB]\n",
      "Get:11 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libcupsimage2 amd64 2.2.7-1ubuntu2.8 [18.6 kB]\n",
      "Get:12 http://archive.ubuntu.com/ubuntu bionic/main amd64 libijs-0.35 amd64 0.35-13 [15.5 kB]\n",
      "Get:13 http://archive.ubuntu.com/ubuntu bionic/main amd64 libjbig2dec0 amd64 0.13-6 [55.9 kB]\n",
      "Get:14 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libgs9-common all 9.26~dfsg+0-0ubuntu0.18.04.14 [5,092 kB]\n",
      "Get:15 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libgs9 amd64 9.26~dfsg+0-0ubuntu0.18.04.14 [2,265 kB]\n",
      "Get:16 http://archive.ubuntu.com/ubuntu bionic/main amd64 libpotrace0 amd64 1.14-2 [17.4 kB]\n",
      "Get:17 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libzzip-0-13 amd64 0.13.62-3.1ubuntu0.18.04.1 [26.0 kB]\n",
      "Get:18 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 texlive-binaries amd64 2017.20170613.44572-8ubuntu0.1 [8,179 kB]\n",
      "Get:19 http://archive.ubuntu.com/ubuntu bionic/main amd64 texlive-base all 2017.20180305-1 [18.7 MB]\n",
      "Get:20 http://archive.ubuntu.com/ubuntu bionic/main amd64 fonts-lmodern all 2.004.5-3 [4,551 kB]\n",
      "Get:21 http://archive.ubuntu.com/ubuntu bionic/main amd64 texlive-latex-base all 2017.20180305-1 [951 kB]\n",
      "Get:22 http://archive.ubuntu.com/ubuntu bionic/main amd64 texlive-latex-recommended all 2017.20180305-1 [14.9 MB]\n",
      "Get:23 http://archive.ubuntu.com/ubuntu bionic/universe amd64 cm-super-minimal all 0.3.4-11 [5,810 kB]\n",
      "Get:24 http://archive.ubuntu.com/ubuntu bionic/universe amd64 pfb2t1c2pfb amd64 0.3-11 [9,342 B]\n",
      "Get:25 http://archive.ubuntu.com/ubuntu bionic/universe amd64 cm-super all 0.3.4-11 [18.7 MB]\n",
      "Get:26 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 ghostscript amd64 9.26~dfsg+0-0ubuntu0.18.04.14 [51.3 kB]\n",
      "Get:27 http://archive.ubuntu.com/ubuntu bionic/universe amd64 dvipng amd64 1.15-1 [78.2 kB]\n",
      "Get:28 http://archive.ubuntu.com/ubuntu bionic/main amd64 fonts-noto-mono all 20171026-2 [75.5 kB]\n",
      "Get:29 http://archive.ubuntu.com/ubuntu bionic/universe amd64 fonts-texgyre all 20160520-1 [8,761 kB]\n",
      "Get:30 http://archive.ubuntu.com/ubuntu bionic/main amd64 gsfonts all 1:8.11+urwcyr1.0.7~pre44-4.4 [3,120 kB]\n",
      "Get:31 http://archive.ubuntu.com/ubuntu bionic/main amd64 javascript-common all 11 [6,066 B]\n",
      "Get:32 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libcupsfilters1 amd64 1.20.2-0ubuntu3.1 [108 kB]\n",
      "Get:33 http://archive.ubuntu.com/ubuntu bionic/main amd64 libjs-jquery all 3.2.1-1 [152 kB]\n",
      "Get:34 http://archive.ubuntu.com/ubuntu bionic/main amd64 rubygems-integration all 1.11 [4,994 B]\n",
      "Get:35 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 ruby2.5 amd64 2.5.1-1ubuntu1.10 [48.6 kB]\n",
      "Get:36 http://archive.ubuntu.com/ubuntu bionic/main amd64 ruby amd64 1:2.5.1 [5,712 B]\n",
      "Get:37 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 rake all 12.3.1-1ubuntu0.1 [44.9 kB]\n",
      "Get:38 http://archive.ubuntu.com/ubuntu bionic/main amd64 ruby-did-you-mean all 1.2.0-2 [9,700 B]\n",
      "Get:39 http://archive.ubuntu.com/ubuntu bionic/main amd64 ruby-minitest all 5.10.3-1 [38.6 kB]\n",
      "Get:40 http://archive.ubuntu.com/ubuntu bionic/main amd64 ruby-net-telnet all 0.1.1-2 [12.6 kB]\n",
      "Get:41 http://archive.ubuntu.com/ubuntu bionic/main amd64 ruby-power-assert all 0.3.0-1 [7,952 B]\n",
      "Get:42 http://archive.ubuntu.com/ubuntu bionic/main amd64 ruby-test-unit all 3.2.5-1 [61.1 kB]\n",
      "Get:43 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 libruby2.5 amd64 2.5.1-1ubuntu1.10 [3,071 kB]\n",
      "Get:44 http://archive.ubuntu.com/ubuntu bionic/main amd64 lmodern all 2.004.5-3 [9,631 kB]\n",
      "Get:45 http://archive.ubuntu.com/ubuntu bionic/main amd64 preview-latex-style all 11.91-1ubuntu1 [185 kB]\n",
      "Get:46 http://archive.ubuntu.com/ubuntu bionic/universe amd64 tex-gyre all 20160520-1 [4,998 kB]\n",
      "Get:47 http://archive.ubuntu.com/ubuntu bionic/universe amd64 texlive-fonts-recommended all 2017.20180305-1 [5,262 kB]\n",
      "Get:48 http://archive.ubuntu.com/ubuntu bionic/universe amd64 texlive-pictures all 2017.20180305-1 [4,026 kB]\n",
      "Get:49 http://archive.ubuntu.com/ubuntu bionic/universe amd64 texlive-latex-extra all 2017.20180305-2 [10.6 MB]\n",
      "Get:50 http://archive.ubuntu.com/ubuntu bionic/universe amd64 texlive-plain-generic all 2017.20180305-2 [23.6 MB]\n",
      "Get:51 http://archive.ubuntu.com/ubuntu bionic/universe amd64 tipa all 2:1.3-20 [2,978 kB]\n",
      "Fetched 163 MB in 9s (17.3 MB/s)\n",
      "debconf: unable to initialize frontend: Dialog\n",
      "debconf: (No usable dialog-like program is installed, so the dialog based frontend cannot be used. at /usr/share/perl5/Debconf/FrontEnd/Dialog.pm line 76, <> line 51.)\n",
      "debconf: falling back to frontend: Readline\n",
      "debconf: unable to initialize frontend: Readline\n",
      "debconf: (This frontend requires a controlling tty.)\n",
      "debconf: falling back to frontend: Teletype\n",
      "dpkg-preconfigure: unable to re-open stdin: \n",
      "Selecting previously unselected package fonts-droid-fallback.\n",
      "(Reading database ... 155013 files and directories currently installed.)\n",
      "Preparing to unpack .../00-fonts-droid-fallback_1%3a6.0.1r16-1.1_all.deb ...\n",
      "Unpacking fonts-droid-fallback (1:6.0.1r16-1.1) ...\n",
      "Selecting previously unselected package fonts-lato.\n",
      "Preparing to unpack .../01-fonts-lato_2.0-2_all.deb ...\n",
      "Unpacking fonts-lato (2.0-2) ...\n",
      "Selecting previously unselected package poppler-data.\n",
      "Preparing to unpack .../02-poppler-data_0.4.8-2_all.deb ...\n",
      "Unpacking poppler-data (0.4.8-2) ...\n",
      "Selecting previously unselected package tex-common.\n",
      "Preparing to unpack .../03-tex-common_6.09_all.deb ...\n",
      "Unpacking tex-common (6.09) ...\n",
      "Selecting previously unselected package libkpathsea6:amd64.\n",
      "Preparing to unpack .../04-libkpathsea6_2017.20170613.44572-8ubuntu0.1_amd64.deb ...\n",
      "Unpacking libkpathsea6:amd64 (2017.20170613.44572-8ubuntu0.1) ...\n",
      "Selecting previously unselected package libptexenc1:amd64.\n",
      "Preparing to unpack .../05-libptexenc1_2017.20170613.44572-8ubuntu0.1_amd64.deb ...\n",
      "Unpacking libptexenc1:amd64 (2017.20170613.44572-8ubuntu0.1) ...\n",
      "Selecting previously unselected package libsynctex1:amd64.\n",
      "Preparing to unpack .../06-libsynctex1_2017.20170613.44572-8ubuntu0.1_amd64.deb ...\n",
      "Unpacking libsynctex1:amd64 (2017.20170613.44572-8ubuntu0.1) ...\n",
      "Selecting previously unselected package libtexlua52:amd64.\n",
      "Preparing to unpack .../07-libtexlua52_2017.20170613.44572-8ubuntu0.1_amd64.deb ...\n",
      "Unpacking libtexlua52:amd64 (2017.20170613.44572-8ubuntu0.1) ...\n",
      "Selecting previously unselected package libtexluajit2:amd64.\n",
      "Preparing to unpack .../08-libtexluajit2_2017.20170613.44572-8ubuntu0.1_amd64.deb ...\n",
      "Unpacking libtexluajit2:amd64 (2017.20170613.44572-8ubuntu0.1) ...\n",
      "Selecting previously unselected package t1utils.\n",
      "Preparing to unpack .../09-t1utils_1.41-2_amd64.deb ...\n",
      "Unpacking t1utils (1.41-2) ...\n",
      "Selecting previously unselected package libcupsimage2:amd64.\n",
      "Preparing to unpack .../10-libcupsimage2_2.2.7-1ubuntu2.8_amd64.deb ...\n",
      "Unpacking libcupsimage2:amd64 (2.2.7-1ubuntu2.8) ...\n",
      "Selecting previously unselected package libijs-0.35:amd64.\n",
      "Preparing to unpack .../11-libijs-0.35_0.35-13_amd64.deb ...\n",
      "Unpacking libijs-0.35:amd64 (0.35-13) ...\n",
      "Selecting previously unselected package libjbig2dec0:amd64.\n",
      "Preparing to unpack .../12-libjbig2dec0_0.13-6_amd64.deb ...\n",
      "Unpacking libjbig2dec0:amd64 (0.13-6) ...\n",
      "Selecting previously unselected package libgs9-common.\n",
      "Preparing to unpack .../13-libgs9-common_9.26~dfsg+0-0ubuntu0.18.04.14_all.deb ...\n",
      "Unpacking libgs9-common (9.26~dfsg+0-0ubuntu0.18.04.14) ...\n",
      "Selecting previously unselected package libgs9:amd64.\n",
      "Preparing to unpack .../14-libgs9_9.26~dfsg+0-0ubuntu0.18.04.14_amd64.deb ...\n",
      "Unpacking libgs9:amd64 (9.26~dfsg+0-0ubuntu0.18.04.14) ...\n",
      "Selecting previously unselected package libpotrace0.\n",
      "Preparing to unpack .../15-libpotrace0_1.14-2_amd64.deb ...\n",
      "Unpacking libpotrace0 (1.14-2) ...\n",
      "Selecting previously unselected package libzzip-0-13:amd64.\n",
      "Preparing to unpack .../16-libzzip-0-13_0.13.62-3.1ubuntu0.18.04.1_amd64.deb ...\n",
      "Unpacking libzzip-0-13:amd64 (0.13.62-3.1ubuntu0.18.04.1) ...\n",
      "Selecting previously unselected package texlive-binaries.\n",
      "Preparing to unpack .../17-texlive-binaries_2017.20170613.44572-8ubuntu0.1_amd64.deb ...\n",
      "Unpacking texlive-binaries (2017.20170613.44572-8ubuntu0.1) ...\n",
      "Selecting previously unselected package texlive-base.\n",
      "Preparing to unpack .../18-texlive-base_2017.20180305-1_all.deb ...\n",
      "Unpacking texlive-base (2017.20180305-1) ...\n",
      "Selecting previously unselected package fonts-lmodern.\n",
      "Preparing to unpack .../19-fonts-lmodern_2.004.5-3_all.deb ...\n",
      "Unpacking fonts-lmodern (2.004.5-3) ...\n",
      "Selecting previously unselected package texlive-latex-base.\n",
      "Preparing to unpack .../20-texlive-latex-base_2017.20180305-1_all.deb ...\n",
      "Unpacking texlive-latex-base (2017.20180305-1) ...\n",
      "Selecting previously unselected package texlive-latex-recommended.\n",
      "Preparing to unpack .../21-texlive-latex-recommended_2017.20180305-1_all.deb ...\n",
      "Unpacking texlive-latex-recommended (2017.20180305-1) ...\n",
      "Selecting previously unselected package cm-super-minimal.\n",
      "Preparing to unpack .../22-cm-super-minimal_0.3.4-11_all.deb ...\n",
      "Unpacking cm-super-minimal (0.3.4-11) ...\n",
      "Selecting previously unselected package pfb2t1c2pfb.\n",
      "Preparing to unpack .../23-pfb2t1c2pfb_0.3-11_amd64.deb ...\n",
      "Unpacking pfb2t1c2pfb (0.3-11) ...\n",
      "Selecting previously unselected package cm-super.\n",
      "Preparing to unpack .../24-cm-super_0.3.4-11_all.deb ...\n",
      "Unpacking cm-super (0.3.4-11) ...\n",
      "Selecting previously unselected package ghostscript.\n",
      "Preparing to unpack .../25-ghostscript_9.26~dfsg+0-0ubuntu0.18.04.14_amd64.deb ...\n",
      "Unpacking ghostscript (9.26~dfsg+0-0ubuntu0.18.04.14) ...\n",
      "Selecting previously unselected package dvipng.\n",
      "Preparing to unpack .../26-dvipng_1.15-1_amd64.deb ...\n",
      "Unpacking dvipng (1.15-1) ...\n",
      "Selecting previously unselected package fonts-noto-mono.\n",
      "Preparing to unpack .../27-fonts-noto-mono_20171026-2_all.deb ...\n",
      "Unpacking fonts-noto-mono (20171026-2) ...\n",
      "Selecting previously unselected package fonts-texgyre.\n",
      "Preparing to unpack .../28-fonts-texgyre_20160520-1_all.deb ...\n",
      "Unpacking fonts-texgyre (20160520-1) ...\n",
      "Selecting previously unselected package gsfonts.\n",
      "Preparing to unpack .../29-gsfonts_1%3a8.11+urwcyr1.0.7~pre44-4.4_all.deb ...\n",
      "Unpacking gsfonts (1:8.11+urwcyr1.0.7~pre44-4.4) ...\n",
      "Selecting previously unselected package javascript-common.\n",
      "Preparing to unpack .../30-javascript-common_11_all.deb ...\n",
      "Unpacking javascript-common (11) ...\n",
      "Selecting previously unselected package libcupsfilters1:amd64.\n",
      "Preparing to unpack .../31-libcupsfilters1_1.20.2-0ubuntu3.1_amd64.deb ...\n",
      "Unpacking libcupsfilters1:amd64 (1.20.2-0ubuntu3.1) ...\n",
      "Selecting previously unselected package libjs-jquery.\n",
      "Preparing to unpack .../32-libjs-jquery_3.2.1-1_all.deb ...\n",
      "Unpacking libjs-jquery (3.2.1-1) ...\n",
      "Selecting previously unselected package rubygems-integration.\n",
      "Preparing to unpack .../33-rubygems-integration_1.11_all.deb ...\n",
      "Unpacking rubygems-integration (1.11) ...\n",
      "Selecting previously unselected package ruby2.5.\n",
      "Preparing to unpack .../34-ruby2.5_2.5.1-1ubuntu1.10_amd64.deb ...\n",
      "Unpacking ruby2.5 (2.5.1-1ubuntu1.10) ...\n",
      "Selecting previously unselected package ruby.\n",
      "Preparing to unpack .../35-ruby_1%3a2.5.1_amd64.deb ...\n",
      "Unpacking ruby (1:2.5.1) ...\n",
      "Selecting previously unselected package rake.\n",
      "Preparing to unpack .../36-rake_12.3.1-1ubuntu0.1_all.deb ...\n",
      "Unpacking rake (12.3.1-1ubuntu0.1) ...\n",
      "Selecting previously unselected package ruby-did-you-mean.\n",
      "Preparing to unpack .../37-ruby-did-you-mean_1.2.0-2_all.deb ...\n",
      "Unpacking ruby-did-you-mean (1.2.0-2) ...\n",
      "Selecting previously unselected package ruby-minitest.\n",
      "Preparing to unpack .../38-ruby-minitest_5.10.3-1_all.deb ...\n",
      "Unpacking ruby-minitest (5.10.3-1) ...\n",
      "Selecting previously unselected package ruby-net-telnet.\n",
      "Preparing to unpack .../39-ruby-net-telnet_0.1.1-2_all.deb ...\n",
      "Unpacking ruby-net-telnet (0.1.1-2) ...\n",
      "Selecting previously unselected package ruby-power-assert.\n",
      "Preparing to unpack .../40-ruby-power-assert_0.3.0-1_all.deb ...\n",
      "Unpacking ruby-power-assert (0.3.0-1) ...\n",
      "Selecting previously unselected package ruby-test-unit.\n",
      "Preparing to unpack .../41-ruby-test-unit_3.2.5-1_all.deb ...\n",
      "Unpacking ruby-test-unit (3.2.5-1) ...\n",
      "Selecting previously unselected package libruby2.5:amd64.\n",
      "Preparing to unpack .../42-libruby2.5_2.5.1-1ubuntu1.10_amd64.deb ...\n",
      "Unpacking libruby2.5:amd64 (2.5.1-1ubuntu1.10) ...\n",
      "Selecting previously unselected package lmodern.\n",
      "Preparing to unpack .../43-lmodern_2.004.5-3_all.deb ...\n",
      "Unpacking lmodern (2.004.5-3) ...\n",
      "Selecting previously unselected package preview-latex-style.\n",
      "Preparing to unpack .../44-preview-latex-style_11.91-1ubuntu1_all.deb ...\n",
      "Unpacking preview-latex-style (11.91-1ubuntu1) ...\n",
      "Selecting previously unselected package tex-gyre.\n",
      "Preparing to unpack .../45-tex-gyre_20160520-1_all.deb ...\n",
      "Unpacking tex-gyre (20160520-1) ...\n",
      "Selecting previously unselected package texlive-fonts-recommended.\n",
      "Preparing to unpack .../46-texlive-fonts-recommended_2017.20180305-1_all.deb ...\n",
      "Unpacking texlive-fonts-recommended (2017.20180305-1) ...\n",
      "Selecting previously unselected package texlive-pictures.\n",
      "Preparing to unpack .../47-texlive-pictures_2017.20180305-1_all.deb ...\n",
      "Unpacking texlive-pictures (2017.20180305-1) ...\n",
      "Selecting previously unselected package texlive-latex-extra.\n",
      "Preparing to unpack .../48-texlive-latex-extra_2017.20180305-2_all.deb ...\n",
      "Unpacking texlive-latex-extra (2017.20180305-2) ...\n",
      "Selecting previously unselected package texlive-plain-generic.\n",
      "Preparing to unpack .../49-texlive-plain-generic_2017.20180305-2_all.deb ...\n",
      "Unpacking texlive-plain-generic (2017.20180305-2) ...\n",
      "Selecting previously unselected package tipa.\n",
      "Preparing to unpack .../50-tipa_2%3a1.3-20_all.deb ...\n",
      "Unpacking tipa (2:1.3-20) ...\n",
      "Setting up libgs9-common (9.26~dfsg+0-0ubuntu0.18.04.14) ...\n",
      "Setting up libkpathsea6:amd64 (2017.20170613.44572-8ubuntu0.1) ...\n",
      "Setting up libjs-jquery (3.2.1-1) ...\n",
      "Setting up libtexlua52:amd64 (2017.20170613.44572-8ubuntu0.1) ...\n",
      "Setting up fonts-droid-fallback (1:6.0.1r16-1.1) ...\n",
      "Setting up libsynctex1:amd64 (2017.20170613.44572-8ubuntu0.1) ...\n",
      "Setting up libptexenc1:amd64 (2017.20170613.44572-8ubuntu0.1) ...\n",
      "Setting up tex-common (6.09) ...\n",
      "debconf: unable to initialize frontend: Dialog\n",
      "debconf: (No usable dialog-like program is installed, so the dialog based frontend cannot be used. at /usr/share/perl5/Debconf/FrontEnd/Dialog.pm line 76.)\n",
      "debconf: falling back to frontend: Readline\n",
      "update-language: texlive-base not installed and configured, doing nothing!\n",
      "Setting up gsfonts (1:8.11+urwcyr1.0.7~pre44-4.4) ...\n",
      "Setting up poppler-data (0.4.8-2) ...\n",
      "Setting up tex-gyre (20160520-1) ...\n",
      "Setting up preview-latex-style (11.91-1ubuntu1) ...\n",
      "Setting up fonts-texgyre (20160520-1) ...\n",
      "Setting up pfb2t1c2pfb (0.3-11) ...\n",
      "Setting up fonts-noto-mono (20171026-2) ...\n",
      "Setting up fonts-lato (2.0-2) ...\n",
      "Setting up libcupsfilters1:amd64 (1.20.2-0ubuntu3.1) ...\n",
      "Setting up libcupsimage2:amd64 (2.2.7-1ubuntu2.8) ...\n",
      "Setting up libjbig2dec0:amd64 (0.13-6) ...\n",
      "Setting up ruby-did-you-mean (1.2.0-2) ...\n",
      "Setting up t1utils (1.41-2) ...\n",
      "Setting up ruby-net-telnet (0.1.1-2) ...\n",
      "Setting up libijs-0.35:amd64 (0.35-13) ...\n",
      "Setting up rubygems-integration (1.11) ...\n",
      "Setting up libpotrace0 (1.14-2) ...\n",
      "Setting up javascript-common (11) ...\n",
      "Setting up ruby-minitest (5.10.3-1) ...\n",
      "Setting up libzzip-0-13:amd64 (0.13.62-3.1ubuntu0.18.04.1) ...\n",
      "Setting up libgs9:amd64 (9.26~dfsg+0-0ubuntu0.18.04.14) ...\n",
      "Setting up libtexluajit2:amd64 (2017.20170613.44572-8ubuntu0.1) ...\n",
      "Setting up fonts-lmodern (2.004.5-3) ...\n",
      "Setting up ruby-power-assert (0.3.0-1) ...\n",
      "Setting up ghostscript (9.26~dfsg+0-0ubuntu0.18.04.14) ...\n",
      "Setting up texlive-binaries (2017.20170613.44572-8ubuntu0.1) ...\n",
      "update-alternatives: using /usr/bin/xdvi-xaw to provide /usr/bin/xdvi.bin (xdvi.bin) in auto mode\n",
      "update-alternatives: using /usr/bin/bibtex.original to provide /usr/bin/bibtex (bibtex) in auto mode\n",
      "Setting up texlive-base (2017.20180305-1) ...\n",
      "mktexlsr: Updating /var/lib/texmf/ls-R-TEXLIVEDIST... \n",
      "mktexlsr: Updating /var/lib/texmf/ls-R-TEXMFMAIN... \n",
      "mktexlsr: Updating /var/lib/texmf/ls-R... \n",
      "mktexlsr: Done.\n",
      "tl-paper: setting paper size for dvips to a4: /var/lib/texmf/dvips/config/config-paper.ps\n",
      "tl-paper: setting paper size for dvipdfmx to a4: /var/lib/texmf/dvipdfmx/dvipdfmx-paper.cfg\n",
      "tl-paper: setting paper size for xdvi to a4: /var/lib/texmf/xdvi/XDvi-paper\n",
      "tl-paper: setting paper size for pdftex to a4: /var/lib/texmf/tex/generic/config/pdftexconfig.tex\n",
      "debconf: unable to initialize frontend: Dialog\n",
      "debconf: (No usable dialog-like program is installed, so the dialog based frontend cannot be used. at /usr/share/perl5/Debconf/FrontEnd/Dialog.pm line 76.)\n",
      "debconf: falling back to frontend: Readline\n",
      "Setting up texlive-fonts-recommended (2017.20180305-1) ...\n",
      "Setting up texlive-plain-generic (2017.20180305-2) ...\n",
      "Setting up texlive-latex-base (2017.20180305-1) ...\n",
      "Setting up lmodern (2.004.5-3) ...\n",
      "Setting up texlive-latex-recommended (2017.20180305-1) ...\n",
      "Setting up texlive-pictures (2017.20180305-1) ...\n",
      "Setting up dvipng (1.15-1) ...\n",
      "Setting up tipa (2:1.3-20) ...\n",
      "Regenerating '/var/lib/texmf/fmtutil.cnf-DEBIAN'... done.\n",
      "Regenerating '/var/lib/texmf/fmtutil.cnf-TEXLIVEDIST'... done.\n",
      "update-fmtutil has updated the following file(s):\n",
      "\t/var/lib/texmf/fmtutil.cnf-DEBIAN\n",
      "\t/var/lib/texmf/fmtutil.cnf-TEXLIVEDIST\n",
      "If you want to activate the changes in the above file(s),\n",
      "you should run fmtutil-sys or fmtutil.\n",
      "Setting up cm-super-minimal (0.3.4-11) ...\n",
      "Setting up texlive-latex-extra (2017.20180305-2) ...\n",
      "Setting up cm-super (0.3.4-11) ...\n",
      "Creating fonts. This may take some time... done.\n",
      "Setting up rake (12.3.1-1ubuntu0.1) ...\n",
      "Setting up ruby2.5 (2.5.1-1ubuntu1.10) ...\n",
      "Setting up ruby (1:2.5.1) ...\n",
      "Setting up ruby-test-unit (3.2.5-1) ...\n",
      "Setting up libruby2.5:amd64 (2.5.1-1ubuntu1.10) ...\n",
      "Processing triggers for mime-support (3.60ubuntu1) ...\n",
      "Processing triggers for libc-bin (2.27-3ubuntu1.3) ...\n",
      "/sbin/ldconfig.real: /usr/local/lib/python3.7/dist-packages/ideep4py/lib/libmkldnn.so.0 is not a symbolic link\n",
      "\n",
      "Processing triggers for man-db (2.8.3-2ubuntu0.1) ...\n",
      "Processing triggers for fontconfig (2.12.6-0ubuntu2) ...\n",
      "Processing triggers for tex-common (6.09) ...\n",
      "debconf: unable to initialize frontend: Dialog\n",
      "debconf: (No usable dialog-like program is installed, so the dialog based frontend cannot be used. at /usr/share/perl5/Debconf/FrontEnd/Dialog.pm line 76.)\n",
      "debconf: falling back to frontend: Readline\n",
      "Running updmap-sys. This may take some time... done.\n",
      "Running mktexlsr /var/lib/texmf ... done.\n",
      "Building format(s) --all.\n",
      "\tThis may take some time... done.\n",
      "Collecting SciencePlots\n",
      "  Downloading SciencePlots-1.0.9.tar.gz (10 kB)\n",
      "  Installing build dependencies ... \u001b[?25l\u001b[?25hdone\n",
      "\u001b[33m  WARNING: Missing build requirements in pyproject.toml for SciencePlots from https://files.pythonhosted.org/packages/c2/44/7b5c0ecd6f2862671a076425546f86ac540bc48c1a618a82d6faa3b26f58/SciencePlots-1.0.9.tar.gz#sha256=2b002f263734a718acdf1e5be57f0de5ee887e70517dfbe1118a27d0ee3dfb0f.\u001b[0m\n",
      "\u001b[33m  WARNING: The project does not specify a build backend, and pip cannot fall back to setuptools without 'wheel'.\u001b[0m\n",
      "  Getting requirements to build wheel ... \u001b[?25l\u001b[?25hdone\n",
      "  Installing backend dependencies ... \u001b[?25l\u001b[?25hdone\n",
      "    Preparing wheel metadata ... \u001b[?25l\u001b[?25hdone\n",
      "Requirement already satisfied: matplotlib in /usr/local/lib/python3.7/dist-packages (from SciencePlots) (3.2.2)\n",
      "Requirement already satisfied: python-dateutil>=2.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib->SciencePlots) (2.8.2)\n",
      "Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.7/dist-packages (from matplotlib->SciencePlots) (0.10.0)\n",
      "Requirement already satisfied: kiwisolver>=1.0.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib->SciencePlots) (1.3.2)\n",
      "Requirement already satisfied: pyparsing!=2.0.4,!=2.1.2,!=2.1.6,>=2.0.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib->SciencePlots) (2.4.7)\n",
      "Requirement already satisfied: numpy>=1.11 in /usr/local/lib/python3.7/dist-packages (from matplotlib->SciencePlots) (1.19.5)\n",
      "Requirement already satisfied: six in /usr/local/lib/python3.7/dist-packages (from cycler>=0.10->matplotlib->SciencePlots) (1.15.0)\n",
      "Building wheels for collected packages: SciencePlots\n",
      "  Building wheel for SciencePlots (PEP 517) ... \u001b[?25l\u001b[?25hdone\n",
      "  Created wheel for SciencePlots: filename=SciencePlots-1.0.9-py3-none-any.whl size=6483 sha256=8ddc7f8eef80214425082a1dd86637aea696f4b2e1bbecc3c7a67bd0a971afd8\n",
      "  Stored in directory: /root/.cache/pip/wheels/37/f8/e9/b2f53a40b336388dfc57b108150daff7d6ffbbfc618dba3924\n",
      "Successfully built SciencePlots\n",
      "Installing collected packages: SciencePlots\n",
      "Successfully installed SciencePlots-1.0.9\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.lines import Line2D\n",
    "import matplotlib.patches as patches\n",
    "\n",
    "import torch.nn.functional as F\n",
    "from torch import nn\n",
    "from tqdm.notebook import tqdm\n",
    "from tqdm import tqdm\n",
    "import time\n",
    "\n",
    "# science plots requirements\n",
    "!apt-get update\n",
    "!sudo apt-get install dvipng texlive-latex-extra texlive-fonts-recommended cm-super\n",
    "!pip install SciencePlots\n",
    "import matplotlib.pyplot as plt\n",
    "plt.style.reload_library()\n",
    "plt.style.use('science')\n",
    "\n",
    "device = 'cuda' if torch.cuda.is_available() else 'cpu'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Yx8UXJk-Z9cy",
    "outputId": "4287b2e6-d70b-4a91-ef8c-3a2900c511fc"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.5519\n"
     ]
    }
   ],
   "source": [
    "# data generation\n",
    "def generate_seq(seq_len=20, window_len=4):\n",
    "    seq = np.random.randint(0, 2, seq_len)\n",
    "    zeros = np.zeros(window_len)\n",
    "    ones = np.ones(window_len)\n",
    "    for i in range(window_len, seq_len+1):\n",
    "        sub_seq = seq[i-window_len:i]\n",
    "        if np.array_equal(sub_seq, zeros) or np.array_equal(sub_seq, ones):\n",
    "            return seq, 1, i-1\n",
    "    return seq, 0, 0\n",
    "\n",
    "labs = []\n",
    "for i in range(10000):\n",
    "    _, l, _ = generate_seq(seq_len=25, window_len=5)\n",
    "    labs.append(l)\n",
    "print(sum(labs)/len(labs))  # ratio of pos labels to neg\n",
    "\n",
    "\n",
    "def generate_batch(size=64):\n",
    "    seqs, labels, idxs = [], [], []\n",
    "    for _ in range(size):\n",
    "        seq, lab, idx = generate_seq(seq_len=25, window_len=5)\n",
    "        seqs.append(seq)\n",
    "        labels.append(lab)\n",
    "        idxs.append(idx)\n",
    "    X = torch.tensor(seqs, dtype=torch.float32)\n",
    "    y = torch.tensor(labels, dtype=torch.float32)\n",
    "    idxs = torch.tensor(idxs)\n",
    "    return X, y, idxs\n",
    "\n",
    "X, y, idxs = generate_batch()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 295
    },
    "id": "AffL4LmsaCfH",
    "outputId": "1812ad65-3c7c-495f-e515-daada27126b8"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA1cAAAEWCAYAAACKWW0QAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAZNklEQVR4nO3dv4uc93Y/8POMflyBjXVJokK2i+EW6QxBGNdT+JYmTSD6AyxuDO4E16WfLX1BncEBJb0gaYLLqJhaGBFQ9y3MFLFV+JtgGxuMjeeTQju6c6XV7mr2s3t25rxesOCZkfb9nM/5PIajeeaZobUWAAAAnMwk+wAAAAB2geEKAACgg4ub/sX333+/vfnmmwe+tlgsYjqdbvqrTyQzW77eV82vXHv1/Mq1Z+dXrj07v3Lt1fMr156df15r39vb+9fW2vtPn2itbfTz8ccftxc57LXTlpktX++r5leuvXp+5dqz8yvXnp1fufbq+ZVrz84/r7VHxNjWZqSduyxwNpvJL5yfKbv2zPzKtZ8Hel83P1N27fZ9XXpfNz/TcWsf2oZ3CxzHsY3jeOBr8/m89OKTw74jy7buvb/757/PPgRO4If/9//j1b/9m+zDOLH/+qf/yD4EXtK2/j+P7XZe990wDHuttXH1+FTeuTqPhbP77Duy2Htk2IXBiu3k/3lk2JZ9t3OXBQIAAGTY+G6B/NlyuYyff/n1uecvX7oQk8npz6/Z+ZVVXvvKtUfsXv0vc2lWdu2V83el9k0vSa289tSVvfecdy/HcHVCDx4t4ubtu/H4m++ee+36tatx786teOet6c7mV1Z57SvXHlG7/uzaK+dXrj07P7t26sree867l/fCkW8Yhk+GYXj3LA9m2zx4tIj3Pvj0SdOHIYbJ5OlPDEM8/ua7eO+DT+PBo8VO5ldWee0r1x5Ru/7s2ivnV649Oz+7durK3nvOu808d7fA/YHqRkT8ISL+0Fq7f9BfPOxugRWsmv79jz/Fq6+/EddvvP2k4fvachmPH34RP3z9Vbz2ypX4/LMPu07X2fmVVV77yrVH7F7965dmHXVZYHbtlfN3sfZt2XvZa09d2XvPeXd8R94tsLV2v7X2p4j48iwPbJsc1fSIiGEyies33o5XX38jvv/xp67TdXZ+ZZXXvnLtEbXrz669cn7l2rPzs2unruy957w7mfP5SbBzbLlcxs3bdw9t+sqzzb95+24sl8utzq+s8tpXrj2idv3ZtVfOr1x7dn527dSVvfecdydnuHpJP//y69PrPw9r+sqq+avrQw+648k25VdWee0r1x5Ru/7s2ivnV649Oz+7durK3nvOu5MzXG1o2P9w3bH+7GQSwzDsVH5llde+cu0RtevPrr1yfuXas/Oza6eu7L3nvNvcxrdiXywWsbqhxWw2i9mWfGsyAADApubzeczn89XD6fprGw9X0+k0Kt8tEAAAqGf9jaW9vb3F+msuC9xQay3aMT8415bLePaW99ueX1nlta9ce0Tt+rNrr5xfufbs/OzaqSt77znvNme4ekmXL12I69euRrQWjx9+cWTzV/fij9bi+rWrcfnSha3Or6zy2leuPaJ2/dm1V86vXHt2fnbt1JW995x3J/fccDUMw41hGD6JiHcj4qNhGP549od1fk0mk7h351a89sqV+OHrrw5t/rNfcnbvzq2YHPMDeuc1v7LKa1+59oja9WfXXjm/cu3Z+dm1U1f23nPendxBXyL8sLX2UWttaK39fv8LhVnzzlvT+PyzDw9t/ml+e3R2fmWV175y7RG168+uvXJ+5dqz87Nrp67svee8O5lh0+sUx3Fs1W9osf4t0jEMf3EryNZaRGun2vTs/Moqr33l2iN2q/6/++e/f/rf//VP/3Hkn8+uvXL+rtW+TXsve+2pK3vvOe+OZxiGvdbauHp8Pt4/21Kr6Xp1fWhbLp/+rK7/PM2mZ+dXVnntK9ceUbv+7Nor51euPTs/u3bqyt57zrvNeOeqg+VyeeC3Ql++dOFMrv/Mzq+s8tpXrj1iN+pff/cAshznnauVzPNuF855tlP23nPeHe7Zd642/p4r/mwymcSV3+Q1ODu/ssprX7n2CPVDhszzzjlPluy957x7Odt1tAAAAOeUd64AinqZy7EAgKN55woAAKADwxUAAEAHhisAAIAODFcAAAAdGK4AAAA6MFwBAAB0YLgCAADoYOPharFYxDiOMZ/POx4OAADA+bc/B03Xn9v4S4Sn02mM43iiAwIAANhGs9ksImKx/pzLAgEAADowXAEAAHRguAIAAOjAcAUAANCB4QoAAKADwxUAAEAHhisAAIAODFcAAAAdGK4AAAA6MFwBAAB0YLgCAADowHAFAADQgeEKAACgA8MVAABA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\n",
      "text/plain": [
       "<Figure size 1080x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "np.random.seed(2)\n",
    "torch.manual_seed(2)\n",
    "\n",
    "# parameters\n",
    "face_col = plt.cm.Blues(0.2*(0.6/0.4) + 0.4)\n",
    "edge_col = plt.cm.Blues(0.4*(0.6/0.4) + 0.4)\n",
    "box_col = plt.cm.Greens(0.2*(6/4) + 0.4)\n",
    "\n",
    "\n",
    "# make plot\n",
    "fig, (ax1, ax2) = plt.subplots(2, 1, figsize=(15,5))\n",
    "ax1.set_yticks([0,1])\n",
    "ax1.tick_params(axis='y', labelsize=15)\n",
    "ax1.set_xticklabels([])\n",
    "\n",
    "seq, l, idx = generate_seq(seq_len=25, window_len=5)\n",
    "# plt.step(np.arange(0, 25), seq, zorder=1)\n",
    "ax1.scatter(np.arange(1, 26), seq, marker='8', s=200, facecolor=face_col, edgecolors=edge_col, linewidth=2)\n",
    "\n",
    "rect = patches.Rectangle((idx-3-0.5, 1-0.1), 5, 0.2, linewidth=3, edgecolor=box_col, facecolor='none')\n",
    "ax1.add_patch(rect)\n",
    "ax1.set_ylim([-0.15, 1.15])\n",
    "\n",
    "np.random.seed(3)\n",
    "torch.manual_seed(3)\n",
    "ax2.set_yticks([0,1])\n",
    "ax2.tick_params(axis='y', labelsize=15)\n",
    "ax2.set_xticklabels([])\n",
    "\n",
    "seq, l, idx = generate_seq(seq_len=25, window_len=5)\n",
    "# plt.step(np.arange(0, 25), seq, zorder=1)\n",
    "ax2.scatter(np.arange(1, 26), seq, marker='8', s=200, facecolor=face_col, edgecolors=edge_col, linewidth=2)\n",
    "\n",
    "ax2.set_ylim([-0.15, 1.15])\n",
    "\n",
    "plt.savefig('seqof5_data.pdf', dpi = 1200)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "id": "m81X9rnif962"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "id": "VSyLE-TRaCkO"
   },
   "outputs": [],
   "source": [
    "torch.manual_seed(3)\n",
    "\n",
    "class LSTM(nn.Module):\n",
    "    def __init__(self, input_size, output_size, nhid, f_bias=True):\n",
    "        super(LSTM, self).__init__()\n",
    "        self.nhid = nhid\n",
    "        self.lstm = nn.LSTM(input_size, nhid, batch_first=True)\n",
    "        self.linear = nn.Linear(nhid, output_size)\n",
    "\n",
    "    def forward(self, inputs):\n",
    "        \"\"\"Inputs have to have dimension (N, C_in, L_in)\"\"\"\n",
    "        h0 = torch.zeros(1, inputs.size(0), self.nhid).to(device) \n",
    "        c0 = torch.zeros(1, inputs.size(0), self.nhid).to(device)\n",
    "        y1, _ = self.lstm(inputs, (h0, c0))  # input should have dimension (B, S, I)\n",
    "        o = self.linear(y1)\n",
    "        return o"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "id": "T-G6uDzB1dp2"
   },
   "outputs": [],
   "source": [
    "# CUSTOM LOSS EVALUATION \n",
    "\n",
    "# if obs has true label 1:\n",
    "#     if pred label = 0:\n",
    "#         loss = 1  [loss1]\n",
    "#     if pred label = 1:\n",
    "#         if model output spiked:\n",
    "#             if model spike >= optimal spike:\n",
    "#                 loss = (model spike - optimal spike)/(seq len)  [loss2]\n",
    "#             if model spike < optimal spike:\n",
    "#                 loss = 1 (this was a lucky guess)  [loss3]\n",
    "#         if model output didnt spike:\n",
    "#             loss = (seq len - optimal spike)/(seq len)  [loss4]\n",
    "# if obs has true label 0:\n",
    "#     if pred label = 0:\n",
    "#         loss = 0  [loss5]\n",
    "#     if pred label = 1:\n",
    "#         loss = 1  [loss6]\n",
    "\n",
    "def custom_loss(preds, spikes, y, opt_idx, seq_len=25, window_size=5):\n",
    "    \"\"\"\n",
    "    Custom loss for evaluating performance.\n",
    "\n",
    "    Args:\n",
    "      preds (torch tensor): Raw predictions.\n",
    "      spikes (torch tensor): Tensor of binary spikes.\n",
    "      y (torch tensor): True labels.\n",
    "      opt_idx (torch tensor): Ground truth optimal spike indexes. \n",
    "      seq_len (int): Length of the sequence.\n",
    "      window_size (int): Size of window of consecutive values.\n",
    "    \"\"\"\n",
    "    preds = torch.round(preds)\n",
    "    first_spike_idx = torch.argmax(spikes, dim=1).squeeze(-1)\n",
    "    normaliser = seq_len - window_size\n",
    "\n",
    "    loss1 = (y == 1) * (preds == 0)\n",
    "    loss2 = (y == 1) * (preds == 1) * (first_spike_idx != 0) * (first_spike_idx >= opt_idx)\n",
    "    loss2 = loss2 * (first_spike_idx - opt_idx)/normaliser\n",
    "    loss3 = (y == 1) * (preds == 1) * (first_spike_idx != 0) * (first_spike_idx < opt_idx)\n",
    "    loss4 = (y == 1) * (preds == 1) * (first_spike_idx == 0) * (seq_len - opt_idx)/normaliser\n",
    "    loss5 = torch.tensor([0])\n",
    "    loss6 = (y == 0) * (preds == 1)\n",
    "    loss_ls = [loss1, loss2, loss3, loss4, loss5, loss6]\n",
    "    total_loss = np.sum([torch.sum(loss).item() for loss in loss_ls])/y.size(0)\n",
    "    return total_loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "id": "MZ64fAZXQdMX"
   },
   "outputs": [],
   "source": [
    "# helper functions \n",
    "\n",
    "def gather_spiking_preds(spikes, out, last_idx=24):\n",
    "      \"\"\"\n",
    "      Gather predictions based on first spike or final output if no spike\n",
    "      occurs. \n",
    "\n",
    "      Args:\n",
    "          spikes (torch tensor): Tensor of binary spikes.\n",
    "          out (torch tensor): Tensor of all model predictions.\n",
    "          y (torch tensor)\n",
    "          last_idx (int): Index of the final element in the sequence.\n",
    "\n",
    "      Returns:\n",
    "          Torch tensor: Outputs at these spiking values.\n",
    "          Int: Number of observations in which no spike occured.\n",
    "      \"\"\"\n",
    "      first_spike_idx = torch.argmax(spikes, dim=1, keepdim=True)\n",
    "      no_spike_count = torch.sum(first_spike_idx == 0).item()\n",
    "      # replace no spike with last idx for prediction\n",
    "      first_spike_idx[first_spike_idx == 0] = last_idx\n",
    "      preds = torch.gather(out, 1, first_spike_idx)  \n",
    "      preds = preds.squeeze(-1).squeeze(-1)\n",
    "      return preds, no_spike_count\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "id": "ZLtBT1hRZE_W"
   },
   "outputs": [],
   "source": [
    "# calculate mean spike time for both classes\n",
    "def calc_mean_spike_times(spikes, y):\n",
    "    first_spike_idx = torch.argmax(spikes, dim=1).squeeze(-1)\n",
    "    class_0_spikes = first_spike_idx[(first_spike_idx > 0) * (y == 0)]\n",
    "    class_1_spikes = first_spike_idx[(first_spike_idx > 0) * (y == 1)]\n",
    "    class_0_mean = class_0_spikes.sum()/class_0_spikes.size(0)\n",
    "    class_1_mean = class_1_spikes.sum()/class_1_spikes.size(0)\n",
    "    return class_0_mean.item(), class_1_mean.item()\n",
    "\n",
    "# calculate average lag between optimal spike and observed spike\n",
    "def calc_mean_lag(spikes, preds, y, opt_idx):\n",
    "    first_spike_idx = torch.argmax(spikes, dim=1).squeeze(-1)\n",
    "    preds = torch.round(preds)\n",
    "    spiking_obs = (y == 1) * (preds == 1) * (first_spike_idx != 0) \n",
    "    lags = first_spike_idx[spiking_obs] - opt_idx[spiking_obs]\n",
    "    early_spikes = torch.sum(lags < 0).item()\n",
    "    lags = lags[lags >= 0]  # remove early spikes\n",
    "    mean_lag = (lags.sum()/lags.size(0)).item()\n",
    "    return mean_lag, early_spikes\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "LazqXlR8dFdq",
    "outputId": "95b465a7-f2cd-4096-9258-058248829282"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([128])"
      ]
     },
     "execution_count": 86,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.repeat_interleave(torch.tensor([24]), BATCH_SIZE).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Efmq_1o2aCnP",
    "outputId": "9ce9e060-e2ae-467b-ee31-a0a6c6d75dff"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "################## TRAINING ##################\n",
      "Training 1000000 examples in batches of size 128\n",
      "resulting in 7813 batches\n",
      "##############################################\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 7813/7813 [04:22<00:00, 29.82it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Final loss: 0.400375\n"
     ]
    }
   ],
   "source": [
    "model = LSTM(1, 1, 125)\n",
    "model.to(device)\n",
    "optimiser = torch.optim.Adam(model.parameters(), lr=0.0003)\n",
    "criterion = torch.nn.BCELoss()\n",
    "s = nn.Sigmoid()\n",
    "\n",
    "NUM_TRAIN_EXAMPLES = 1000000\n",
    "BATCH_SIZE = 128\n",
    "VALIDATION_SIZE = 2000\n",
    "VALIDATION_FREQ = 50\n",
    "PATH = '/model_weights'\n",
    "\n",
    "best_loss = 99999\n",
    "loss_ls = []\n",
    "spiking_acc_ls = []\n",
    "custom_loss_ls = []\n",
    "class_0_spike_times_ls = []\n",
    "class_1_spike_times_ls = []\n",
    "mean_lag_ls = []\n",
    "early_spike_count_ls = []\n",
    "num_batches = int(np.ceil(NUM_TRAIN_EXAMPLES/BATCH_SIZE))\n",
    "seq_lens = torch.repeat_interleave(torch.tensor([24]), BATCH_SIZE).unsqueeze(-1).unsqueeze(-1).to(device)\n",
    "print('################## TRAINING ##################')\n",
    "print('Training {} examples in batches of size {}'.format(NUM_TRAIN_EXAMPLES, BATCH_SIZE))\n",
    "print(f'resulting in {num_batches} batches')\n",
    "print('##############################################\\n')\n",
    "\n",
    "time.sleep(0.2)\n",
    "for i in tqdm(range(num_batches)):\n",
    "    ######################## TRAIN A BATCH ########################\n",
    "    # generate some training data \n",
    "    X, y, idxs = generate_batch(BATCH_SIZE)\n",
    "    X, y = X.to(device), y.to(device)\n",
    "    X.unsqueeze_(-1)\n",
    "    \n",
    "    # learn through network\n",
    "    model.train()\n",
    "    optimiser.zero_grad()\n",
    "    out = model(X)\n",
    "    out = s(out)\n",
    "    \n",
    "    # grab indixes of first spikes\n",
    "    # with torch.no_grad():\n",
    "    #     spikes = ((out < 0.05) * 1) + ((out > 0.95) * 1)\n",
    "    #     first_spike_idx = torch.argmax(spikes, dim=1, keepdim=True)\n",
    "    #     first_spike_idx[first_spike_idx == 0] = 24  # replace no spike with last idx\n",
    "\n",
    "        \n",
    "    # preds = torch.gather(out, 1, first_spike_idx) \n",
    "    preds = torch.gather(out, 1, seq_lens)  \n",
    "    preds = preds.squeeze(-1).squeeze(-1)\n",
    "    \n",
    "    loss = criterion(preds, y)\n",
    "    loss_ls.append(loss.item())\n",
    "    loss.backward()\n",
    "    optimiser.step()\n",
    "    \n",
    "    ######################## VALIDATION SET ########################\n",
    "    if i % VALIDATION_FREQ == 0:\n",
    "      model.eval()\n",
    "      with torch.no_grad():\n",
    "          X, y, opt_idx = generate_batch(VALIDATION_SIZE)\n",
    "          X, y, opt_idx = X.to(device), y.to(device), opt_idx.to(device)\n",
    "          X.unsqueeze_(-1)\n",
    "          out = model(X)\n",
    "          out = s(out)\n",
    "          \n",
    "          # generate tensor of spikes\n",
    "          spikes = ((out < 0.05) * 1) + ((out > 0.95) * 1)\n",
    "          preds, _ = gather_spiking_preds(spikes, out)\n",
    "\n",
    "          # spiking accuracy\n",
    "          spiking_acc_val = (torch.sum(y == torch.round(preds))/y.size(0)).item()\n",
    "          spiking_acc_ls.append(spiking_acc_val)\n",
    "\n",
    "          # custom loss score\n",
    "          custom_loss_val = custom_loss(preds, spikes, y, opt_idx)\n",
    "          custom_loss_ls.append(custom_loss_val)\n",
    "\n",
    "          # store mean spike times\n",
    "          mean_spike_times = calc_mean_spike_times(spikes, y)\n",
    "          class_0_spike_times_ls.append(mean_spike_times[0])\n",
    "          class_1_spike_times_ls.append(mean_spike_times[1])\n",
    "\n",
    "          # evaluate mean lag between optimal and predicted spikes\n",
    "          mean_lag, early_spike_count = calc_mean_lag(spikes, preds, y, opt_idx)\n",
    "          mean_lag_ls.append(mean_lag)\n",
    "          early_spike_count_ls.append(early_spike_count)\n",
    "\n",
    "          # save model if better than current best\n",
    "          if (custom_loss_val < best_loss) and (i > num_batches * 0.9):\n",
    "              # save the model \n",
    "              best_loss = custom_loss_val\n",
    "              torch.save(model.state_dict(), PATH)\n",
    "\n",
    "time.sleep(0.2)    \n",
    "    \n",
    "    \n",
    "print('\\nFinal loss:', best_loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "yKxedFfE9tHr",
    "outputId": "83a0766f-803e-4c19-9703-99f63322f1ac"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([128, 1, 1])"
      ]
     },
     "execution_count": 90,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 226
    },
    "id": "kdLBVy2caCpi",
    "outputId": "8ba0f4c4-cb43-4db1-fa57-02475c0b9c42"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1008x216 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(14,3))\n",
    "plt.subplot(1, 3, 1)\n",
    "plt.plot(loss_ls)\n",
    "plt.xlabel('Training Batch')\n",
    "plt.title('Training Loss')\n",
    "\n",
    "plt.subplot(1, 3, 2)\n",
    "xvals = np.arange(len(spiking_acc_ls)) * VALIDATION_FREQ\n",
    "plt.plot(xvals, spiking_acc_ls)\n",
    "plt.xlabel('Training Batch')\n",
    "plt.title('Validation Accuracy')\n",
    "\n",
    "plt.subplot(1, 3, 3)\n",
    "plt.plot(xvals, custom_loss_ls)\n",
    "plt.xlabel('Training Batch')\n",
    "plt.title('Custom Loss')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 335
    },
    "id": "mzyPHlh0bzQl",
    "outputId": "b2e2c3c1-1c08-40be-a58e-b0eb3e335768"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot the average first spike times by class during training (of observations that do spike)\n",
    "plt.figure(figsize=(12,5))\n",
    "xvals = np.arange(len(class_0_spike_times_ls)) * VALIDATION_FREQ\n",
    "\n",
    "class_0_spike_times_arr = np.array(class_0_spike_times_ls)\n",
    "mask_0 = class_0_spike_times_arr > 0\n",
    "plt.xlim(0, len(xvals))\n",
    "plt.plot(xvals[mask_0], class_0_spike_times_arr[mask_0], linestyle='-',\n",
    "         marker='o', label='Class 0')\n",
    "\n",
    "class_1_spike_times_arr = np.array(class_1_spike_times_ls)\n",
    "mask_1 = class_1_spike_times_arr > 0\n",
    "plt.xlim(0, xvals[-1])\n",
    "plt.plot(xvals[mask_1], class_1_spike_times_arr[mask_1], linestyle='-',\n",
    "         marker='o', label='Class 1')\n",
    "\n",
    "plt.title('Mean First Spike Times by Class')\n",
    "plt.ylabel('Mean Spike Time')\n",
    "plt.xlabel('Batch')\n",
    "plt.ylim(10,25)\n",
    "plt.grid()\n",
    "plt.legend(loc='best')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 336
    },
    "id": "Si64TXPN7Gbq",
    "outputId": "c647dd50-0b82-4b2a-c1b0-946db84aef98"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1584x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot lag between optimal first spike and observed first spike on observations\n",
    "# in class 1 that did spike and did not spike early\n",
    "plt.figure(figsize=(22,5))\n",
    "plt.subplot(1, 2, 1)\n",
    "xvals = np.arange(len(mean_lag_ls)) * VALIDATION_FREQ\n",
    "mean_lag_arr = np.array(mean_lag_ls)\n",
    "mask = mean_lag_arr > 0\n",
    "plt.plot(xvals[mask], mean_lag_arr[mask], linestyle='-',\n",
    "         marker='o', label='Label')\n",
    "plt.ylim(-0.3,18)\n",
    "plt.ylabel('Mean time lag')\n",
    "plt.xlabel('Batch')\n",
    "plt.title('Mean lag between optimal first spike and observed first spike')\n",
    "# plt.show()\n",
    "\n",
    "plt.subplot(1, 2, 2)\n",
    "plt.plot(xvals, early_spike_count_ls, linestyle='-',\n",
    "         marker='o', label='Label')\n",
    "plt.ylabel('Count')\n",
    "plt.xlabel('Batch')\n",
    "plt.title(f'Number of early spikes per batch (size = {BATCH_SIZE})')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 131,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "HRweEphNaTci",
    "outputId": "0a704cdf-de99-4256-f4db-134bd9498023"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Final output accuracy: 1.0\n",
      "Accuracy if evaluated on first spike: 0.5819000005722046\n",
      "(including 0 observations with no spikes)\n",
      "Custom loss: 0.426375\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(1)\n",
    "torch.manual_seed(1)\n",
    "\n",
    "# load best model and evaluate on test set\n",
    "model = LSTM(1, 1, 125)\n",
    "model.load_state_dict(torch.load(PATH))\n",
    "model.to(device)\n",
    "\n",
    "######################## TEST SET ########################\n",
    "TEST_SIZE = 10000\n",
    "model.eval()\n",
    "with torch.no_grad():\n",
    "    X, y, opt_idx = generate_batch(TEST_SIZE)\n",
    "    X, y, opt_idx = X.to(device), y.to(device), opt_idx.to(device)\n",
    "    X.unsqueeze_(-1)\n",
    "    out = model(X)\n",
    "    out = s(out)\n",
    "\n",
    "    # generate tensors of spikes and preds\n",
    "    spikes = ((out < 0.05) * 1) + ((out > 0.95) * 1)\n",
    "    preds, no_spike_count = gather_spiking_preds(spikes, out)\n",
    "\n",
    "    # spiking accuracy\n",
    "    spike_acc = torch.sum(y == torch.round(preds))/y.size(0)\n",
    "    # final output accuracy\n",
    "    reg_acc = torch.sum(torch.round(out[:,-1].squeeze(-1)) == y)/y.size(0)\n",
    "    # custom loss value\n",
    "    custom_loss_val = custom_loss(preds, spikes, y, opt_idx)\n",
    "    \n",
    "print('Final output accuracy:', reg_acc.item())\n",
    "print('Accuracy if evaluated on first spike:', spike_acc.item())\n",
    "print(f'(including {no_spike_count} observations with no spikes)')\n",
    "print('Custom loss:', custom_loss_val)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 601
    },
    "id": "wemxqIUbl1Fa",
    "outputId": "5bb18a9a-5a1d-4b57-9855-6f4dc6045a3e"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1080x720 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# POSTERIOR PLOT\n",
    "\n",
    "# parameters\n",
    "text_size = 15\n",
    "tick_label_size = 13\n",
    "show_full = True\n",
    "model = 'EOS'  # 'RC' or 'EOS'\n",
    "\n",
    "num_obs = 50\n",
    "# gather data\n",
    "post = out[:num_obs].cpu().numpy().squeeze(-1).T\n",
    "labels = y[:num_obs].unsqueeze(0).cpu().numpy()\n",
    "opt_spike = opt_idx[:num_obs].cpu().numpy()\n",
    "spikes_out = ((out < 0.05) * -1) + ((out > 0.95) * 1)\n",
    "spikes_out = spikes_out[:num_obs].cpu().numpy().squeeze(-1).T\n",
    "first_spike_idx = torch.argmax(spikes, dim=1, keepdim=True)\n",
    "first_spike_idx[first_spike_idx == 0] = 25  # to do maybe\n",
    "first_spike_idx = first_spike_idx.squeeze().squeeze()\n",
    "first_spikes = first_spike_idx[:num_obs].cpu().numpy()\n",
    "preds = []\n",
    "# gather predictions\n",
    "for idx in range(num_obs):\n",
    "  # no spike\n",
    "  if first_spike_idx[idx] == 25:\n",
    "    preds.append(0.5)\n",
    "  else:\n",
    "    if model == 'RC':\n",
    "      pred = int(np.round(post[first_spikes[idx],idx]))\n",
    "      preds.append(pred)\n",
    "    else:\n",
    "      if labels[0,idx] == 0:\n",
    "        preds.append(0.5)\n",
    "      else:\n",
    "        pred = (np.max(post[:,idx]) > 0.95)*1\n",
    "        preds.append(pred)\n",
    "\n",
    "\n",
    "# only show up to first spike\n",
    "if not show_full:\n",
    "  for idx in range(num_obs):\n",
    "    spikes_out[first_spikes[idx]+1:,idx] = 0\n",
    "    post[first_spikes[idx]+1:,idx] = 0.5\n",
    "  \n",
    "\n",
    "# make plot\n",
    "fig, (ax0, ax1, ax2, ax3) = plt.subplots(4, 1, figsize=(15,10), gridspec_kw={'height_ratios': [1,1,10,10]})\n",
    "# true labels\n",
    "ax0.imshow(labels*-1, cmap='coolwarm')\n",
    "ax0.set_yticks([0])\n",
    "ax0.set_xticks([])\n",
    "ax0.tick_params(axis='y', labelsize=text_size)\n",
    "ax0.set_yticklabels(['True labels'])\n",
    "ax0.set_xticks(np.arange(-.5, num_obs, 1), minor=True)\n",
    "ax0.set_axisbelow(True)\n",
    "ax0.grid(which='minor')\n",
    "\n",
    "# model predictions\n",
    "ax1.imshow(np.array(preds)[None,:]*-1, cmap='coolwarm', vmin=-1, vmax=0)\n",
    "ax1.set_yticks([0])\n",
    "ax1.set_xticks([])\n",
    "ax1.tick_params(axis='y', labelsize=text_size)\n",
    "ax1.set_yticklabels([f'{model} labels'])\n",
    "ax1.set_xticks(np.arange(-.5, num_obs, 1), minor=True)\n",
    "ax1.set_axisbelow(True)\n",
    "ax1.grid(which='minor')\n",
    "\n",
    "# spikes\n",
    "ax2.imshow(spikes_out*-1, origin='lower', aspect='auto', cmap='coolwarm')\n",
    "for idx in range(num_obs):\n",
    "  if labels[0,idx] == 1:      \n",
    "    rect = patches.Rectangle((idx-0.5, opt_spike[idx]-4-0.5), 1, 5, linewidth=3, edgecolor='black', facecolor='none')\n",
    "    ax2.add_patch(rect)\n",
    "ax2.set_ylabel(f'{model} spikes\\nIndex in sequence', size=text_size+4)\n",
    "# ax2.set_xlabel('Test set sequences', size=text_size+4)\n",
    "ax2.set_xticks([0,9,19,29,39,49])\n",
    "ax2.tick_params(axis='x', labelsize=tick_label_size)\n",
    "ax2.set_xticklabels([1,10,20,30,40,50])\n",
    "ax2.tick_params(axis='y', labelsize=tick_label_size)\n",
    "ax2.set_xticks(np.arange(-.5, num_obs, 1), minor=True)\n",
    "ax2.set_yticks(np.arange(-.5, 25, 1), minor=True)\n",
    "ax2.set_axisbelow(True)\n",
    "ax2.grid(which='minor')\n",
    "\n",
    "# posteriors\n",
    "ax3.imshow(post*-1, origin='lower', aspect='auto', cmap='coolwarm')\n",
    "for idx in range(num_obs):\n",
    "  if labels[0,idx] == 1:      \n",
    "    rect = patches.Rectangle((idx-0.5, opt_spike[idx]-4-0.5), 1, 5, linewidth=3, edgecolor='black', facecolor='none')\n",
    "    ax3.add_patch(rect)\n",
    "ax3.set_ylabel(f'{model} posteriors\\nIndex in sequence', size=text_size+4)\n",
    "ax3.set_xlabel('Test set sequences', size=text_size+4)\n",
    "ax3.set_xticks([0,9,19,29,39,49])\n",
    "ax3.tick_params(axis='x', labelsize=tick_label_size)\n",
    "ax3.set_xticklabels([1,10,20,30,40,50])\n",
    "ax3.tick_params(axis='y', labelsize=tick_label_size)\n",
    "ax3.set_xticks(np.arange(-.5, num_obs, 1), minor=True)\n",
    "ax3.set_yticks(np.arange(-.5, 25, 1), minor=True)\n",
    "ax3.set_axisbelow(True)\n",
    "ax3.grid(which='minor')\n",
    "\n",
    "plt.savefig('spike_plot.pdf', dpi = 1200)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {
    "id": "CZMrvEAMKQ6U"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 227
    },
    "id": "mzjeUGKFbFuT",
    "outputId": "8d5cb0df-6f39-4993-f656-d40794735b73"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1008x216 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot when all spikes occur and first spike occurs across the sequence\n",
    "# Note: first spike at index 1 refers to observations that did not spike\n",
    "plt.figure(figsize=(14,3))\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.bar(x=list(range(1,26)), height=spikes.cpu().sum(axis=0))\n",
    "plt.title('All spikes')\n",
    "plt.xticks(list(range(1,26)))\n",
    "\n",
    "plt.subplot(1, 2, 2)\n",
    "first_spike_idx = torch.argmax(spikes, dim=1).squeeze(-1)\n",
    "values, counts = first_spike_idx.unique(return_counts=True)\n",
    "heights = torch.zeros(25)\n",
    "for i, v in enumerate(values):\n",
    "    heights[v] = counts[i]\n",
    "plt.bar(x=list(range(1,26)), height=heights)\n",
    "plt.title('First spike')\n",
    "plt.xticks(list(range(1,26)))\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 281
    },
    "id": "QW8z7-pAbPyu",
    "outputId": "f7a0e2a9-e12b-4cff-f2e6-bdab9c9a35f0"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# of the observations that should spike, what is the delay\n",
    "first_spike_idx = torch.argmax(spikes, dim=1).squeeze(-1)\n",
    "preds = torch.round(preds)\n",
    "spiking_obs = (y == 1) * (preds == 1) * (first_spike_idx != 0) \n",
    "lags = first_spike_idx[spiking_obs] - opt_idx[spiking_obs]\n",
    "values, counts = lags.unique(return_counts=True)\n",
    "plt.bar(x=values.cpu(), height=counts.cpu())\n",
    "plt.title('Lag between optimal spike and observed spike')\n",
    "plt.xticks(values.cpu())\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 350
    },
    "id": "7LW80lHe52fi",
    "outputId": "4f4d6fbc-60f0-4728-a0be-5977f415bd8f"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAwsAAAFNCAYAAABPOPPiAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO3debxVdbn48c/jUKQiTugV0SA1k0xQwVkyzSkLzKGbWolDZqk/G/SG1wbKBrtW3rKbZjlVWg6VWlpqGlGZAygSSiYaKjjhhBhpgs/vj/U9tMV1ztno2fswfN6v136dNe31PGufw2I9+/v9rhWZiSRJkiQtaoXeTkCSJEnSksliQZIkSVItiwVJkiRJtSwWJEmSJNWyWJAkSZJUy2JBkiRJUi2LBUnqRERsFBHPRcSKLdj3uIj4cQ/vc5eIuKdhfkZEvLMnY7RbRGREbNLbeSyOVnzuEXF2RHy2TO8aETN7cv+S1BmLBUnLjIgYExF/iYh5EfFoRJwVEWssxvtfdpGXmQ9m5mqZuaA1GfeszPxDZm7W23mo52XmMZl5am/nIWn5Y7EgaZkQEZ8CvgacBPQDtgfeCFwfEa/rzdy0ZGtFy5EkLSssFiQt9SJideALwPGZ+ZvMfDEzZwDvAwYBHyjbjYuIyyPikoiYGxG3R8TQsu5HwEbAL0vXo/+KiEGlG8xKZZvxEfGliLipbPPLiFg7Ii6KiGcj4raIGNSQ17ci4qGyblJE7NLk8awTEb+KiGci4qmI+ENErFDWzYiIkyPi7oh4OiLOj4g+ZV2n3VMiYvOI+HtEHFzm3x0Rk0uMmyJiy4ZtPx0Rs8pndE9E7F6zv+1K682KDcveGxFTyvS2ETGxHPtjEfHNLo73wxExvRzrVRExYJFN3hUR90fEExFxesNnsUlE/D4i5pR1lzTs8y0RcX3Z5z0R8b6GdReUVqdrIuIfwIndHMsKETE2Iu6LiCcj4tKIWKth2w9GxANl3SmdHWfZ9l3ldze3fMYnluW7RsTMiPjvciwzIuLQRXL+Uif7/H9lnwMj4vUR8fWIeLB87mdHxBvKdp3+XUlSZzxJSFoW7Aj0AX7euDAznwOuAfZoWDwauAxYC7gYuCIiVs7MDwIPAu8pXY/+p5NY7wc+CGwAbAz8GTi/7G8a8PmGbW8DhjXEuqzjwr4bnwJmAv2B9YD/BrJh/aHAXiX+m4HPdLWziNgauJaqmPpJRGwFnAd8BFgb+B5wVbnQ3Aw4DhiRmX1LnBmL7jMzbwH+AezWsPiQcpwA3wK+lZmrlzwv7SS33YCvUhV26wMPAD9dZLP3AsOBral+f0eU5acC1wFrAgOBM8s+VwWuL7msS/U7+25EDFkk1y8DfUuuXR3L8cB+wNuBAcDTwP+VWEOAs6j+JgZQfZ4D6461OBf4SPlstwBubFj3H8A6VH9bhwHnlN9HpyLic8AY4O2ZORM4jepvYhiwSdnX58rm3f1dSdIrWCxIWhasAzyRmfNr1j1S1neYlJmXZ+aLwDepioztFyPW+Zl5X2bOAX4N3JeZvy2xLwO26tgwM3+cmU9m5vzM/AbweqCZMQUvUl04v7G0kvwhMxsv6r6TmQ9l5lNUF7wHd7GvXYCrgA9l5q/KsqOB72XmLZm5IDMvBF6g+hwWlDyHlCJqRmbe18m+f9IROyL6Au8qyzqOYZOIWCczn8vMmzvZx6HAeZl5e2a+AJwM7NDYQgN8LTOfyswHgf9tON4XqbqaDcjM5zPzj2X5u4EZmXl++ezvAH4GHNSwzysz80+Z+VJmPt/NsRwDnJKZM0uO44ADo2pxOhD4VWZOKOs+C7zUybF25DwkIlbPzKcz8/ZF1n82M1/IzN8DV1MVUXWitNbsCbwjM2dHRFD9bj9RPq+5wFeoiqWO2F39XUnSK1gsSFoWPAGsUy7eFrV+Wd/hoY6JzHyJ6pvWRbu9dOWxhul/1syv1jETESdGxLTSTeYZqrEUjYVLZ04HpgPXle43YxdZ/1DD9APd5H8McFNmjm9Y9kbgU6U7yjMltw2pLrqnAx+nuiB+PCJ+WtMtqMPFwP4R8Xpgf+D2zHygrDuS6hvuv0bVPevdnexjQDkGYGFr0JNU34h3d7z/BQRwa0TcFREdLQ5vBLZb5PgOpfrmvm6f3R3LG4FfNOxrGlVRtV7JpfFv6h8l/84cQFWIPFC6UO3QsO7p8v66Y13UGlSFwVdL4QpVi8EqwKSGXH9TlkP3f1eS9AoWC5KWBX+m+mZ8/8aFEbEasA9wQ8PiDRvWr0DVZeThsqjHvmWNanzCf1F9M7xmZq4BzKG6uO1SZs7NzE9l5puAUcAn4+XjBjZsmN6If+df5xhgo4g4o2HZQ8CXM3ONhtcqmfmTEv/izNyZ6iI5qQaO1+V5N9UF7T68vNsOmXlvZh5M1Q3oa8DlpXvQoh4ucYCFXYjWBmZ1d7yZ+WhmfjgzB1B1qfpuVLdZfQj4/SLHt1pmfrQx/WaPpexvn0X21yczZ1G1XDX+Ta1S8q+Vmbdl5ujyuVzBy7tnrbnIZ9TV7/ZpqhaU8yNip7LsCaqC9a0NefbLzNVK7O7+riTpFSwWJC31yjerXwDOjIi9I2Ll0o3lUqqWgx81bL5NROxfWiE+TlVkdHSReQx4Uw+l1ReYD8wGVip9y1dv5o1RDT7epHQrmUP1LXZj15Zjy2DWtYBTgEvq9lPMBfYGRkbEaWXZ94FjohqkHBGxakTsGxF9I2KziNitfMP+PNXFZ1fdai4GTgBGUnXD6jiGD0RE/9J680xZXLefnwCHR8SwEvMrwC1lgHqHkyJizYjYsMS6pMQ4KCI6xgc8TVUAvAT8CnhzVAOPVy6vERGxeRfH0emxAGcDX46IN5a4/SNidFl3OfDuiNg5qrtufZFO/m+NiNdFxKER0a90g3u25jP5QtluF6pi4LJX7KgorUWHAj+PiG3LZ/194IyIWLfE3CAi9irT3f1dSdIrWCxIWiaUAcn/DXyd6iLsFqpvhHcvfck7XAn8J9XF5QeB/cuFG1QDbT9TunCc+BpTupaqC8jfqL6xfp5Xdn3pzKbAb4HnqFpNvpuZv2tYfzHVwN77gfuA2rvkdMjMZ6gGee8TEadm5kTgw8B3qD6H6VSDZKEar3Aa1bfUj1J9A35yF7v/CdXA3xszs7G7197AXRHxHNUA4vdn5j9rcvstVT//n1F9S78x/+5j3+FKYBIwmaof/7ll+QjglhLjKuCEzLy/9NXfs+zn4XIcXyvH1pXOjuVbZf/XRcRcquJyu5L/XcCxVL+TR6g+z64emPZBYEZEPEvV6nNow7pHy/sfBi4CjsnMv3aVcGZeTzXg+5dlIPunqX6fN5cYv+Xf42S6+7uSpFcIxzZJWl5ExDhgk8z8QG/n8mpFxAzgqHKRrWVEROwK/Dgzu7qTkiS1nS0LkiRJkmpZLEiSJEmqZTckSZIkSbVsWZAkSZJUy2JBkiRJUq26p50uNdZZZ50cNGhQb6chSZIkLbUmTZr0RGb2r1u3VBcLgwYNYuLEib2dhiRJkrTUiogHOltnNyRJkiRJtSwWJEmSJNWyWJAkSZJUa6kesyBJkqT2evHFF5k5cybPP/98b6eixdSnTx8GDhzIyiuv3PR7LBYkSZLUtJkzZ9K3b18GDRpERPR2OmpSZvLkk08yc+ZMBg8e3PT77IYkSZKkpj3//POsvfbaFgpLmYhg7bXXXuwWIYsFSZIkLRYLhaXTq/m9WSxIkiRpqTJz5kxGjx7NpptuysYbb8wJJ5zAv/71ry7f88wzz/Dd73534fzDDz/MgQce2CP5jBs3jq9//euveT877rgjAOPHj+fd7373a95fT3DMgiRJkl61QWOv7tH9zTht3y7XZyb7778/H/3oR7nyyitZsGABRx99NKeccgqnn356p+/rKBY+9rGPATBgwAAuv/zyHs39tbrpppt6O4VXsGVBkiRJS40bb7yRPn36cPjhhwOw4oorcsYZZ3Deeecxb948LrjgAkaPHs2uu+7Kpptuyhe+8AUAxo4dy3333cewYcM46aSTmDFjBltssQUAF1xwAfvttx977LEHgwYN4jvf+Q7f/OY32Wqrrdh+++156qmnAPj+97/PiBEjGDp0KAcccADz5s3rMtfLLruMLbbYgqFDhzJy5MiFseryA1httdVesY/bbruNrbbaivvuu49Jkybx9re/nW222Ya99tqLRx555LV/oN2wWJAkSdJS46677mKbbbZ52bLVV1+djTbaiOnTpwNw66238rOf/YwpU6Zw2WWXMXHiRE477TQ23nhjJk+eXNsCMXXqVH7+859z2223ccopp7DKKqtwxx13sMMOO/DDH/4QgP3335/bbruNO++8k80335xzzz23y1y/+MUvcu2113LnnXdy1VVXLVxel1+dm266iWOOOYYrr7ySjTbaiOOPP57LL7+cSZMmccQRR3DKKacs1mf3atgN6TVqpultRp9Dut/RuDk9kI0kSZL22GMP1l57baC6wP/jH//Ifvvt1+V73vGOd9C3b1/69u1Lv379eM973gPA2972NqZMmQJUBcVnPvMZnnnmGZ577jn22muvLve50047MWbMGN73vvex//77d5nf8OHDX/beadOmcfTRR3PdddcxYMAApk6dytSpU9ljjz0AWLBgAeuvv/5ifCqvjsWCJEmSlhpDhgx5xViDZ599lgcffJBNNtmE22+//RV3/WnmLkCvf/3rF06vsMIKC+dXWGEF5s+fD8CYMWO44oorGDp0KBdccAHjx4/vcp9nn302t9xyC1dffTXbbLMNkyZNqs2nLr/111+f559/njvuuIMBAwaQmbz1rW/lz3/+c7fH0pPshiRJkqSlxu677868efMWdg1asGABn/rUpxgzZgyrrLIKANdffz1PPfUU//znP7niiivYaaed6Nu3L3Pnzn1NsefOncv666/Piy++yEUXXdTt9vfddx/bbbcdX/ziF+nfvz8PPfRQp/ktao011uDqq6/m5JNPZvz48Wy22WbMnj17YbHw4osvctddd72m42mGxYIkSZKWGhHBL37xCy677DI23XRT3vzmN9OnTx++8pWvLNxm22235YADDmDLLbfkgAMOYPjw4ay99trstNNObLHFFpx00kmvKvapp57Kdtttx0477cRb3vKWbrc/6aSTeNvb3sYWW2zBjjvuyNChQzvNr856663Hr371K4499ljuuOMOLr/8cj796U8zdOhQhg0b1pa7J0VmtjxIqwwfPjw7GxDSLo5ZkCRJy5Np06ax+eab93YanbrggguYOHEi3/nOd3o7lVq9nV/d7y8iJmVmbcViy4IkSZKkWi0tFiJijYi4PCL+GhHTImKHiFgrIq6PiHvLzzXLthER346I6RExJSK2bmVukiRJWvaMGTNmiW1VgCU/v0W1umXhW8BvMvMtwFBgGjAWuCEzNwVuKPMA+wCbltfRwFktzk2SJElSF1pWLEREP2AkcC5AZv4rM58BRgMXls0uBDpuejsa+GFWbgbWiIjW3zxWkiRJUq1WtiwMBmYD50fEHRHxg4hYFVgvMzueTf0osF6Z3gB4qOH9M8sySZIkSb2glcXCSsDWwFmZuRXwD/7d5QiArG7FtFi3Y4qIoyNiYkRMnD17do8lK0mSJOnlWlkszARmZuYtZf5yquLhsY7uReXn42X9LGDDhvcPLMteJjPPyczhmTm8f//+LUtekiRJS6YVV1yRYcOGscUWW3DQQQcxb968V72vMWPGLHwi9FFHHcXdd9/d6bbjx49/Vc82GDRoEE888cSrzhHgqquu4rTTTgNennOrrdSqHWfmoxHxUERslpn3ALsDd5fXYcBp5eeV5S1XAcdFxE+B7YA5Dd2VJEmStCQa16+H99f9s6fe8IY3MHnyZAAOPfRQzj77bD75yU8uXD9//nxWWmnxL3N/8IMfdLl+/PjxrLbaauy4446Lve/XatSoUYwaNartcVt9N6TjgYsiYgowDPgKVZGwR0TcC7yzzANcA9wPTAe+D3ysxblJkiRpKbfLLrswffp0xo8fzy677MKoUaMYMmQICxYs4KSTTmLEiBFsueWWfO973wMgMznuuOPYbLPNeOc738njjz++cF+77rorHQ/8/c1vfsPWW2/N0KFD2X333ZkxYwZnn302Z5xxBsOGDeMPf/gDs2fP5oADDmDEiBGMGDGCP/3pTwA8+eST7Lnnnrz1rW/lqKOOou4hyAsWLGDMmDFsscUWvO1tb+OMM85YmMMJJ5ywsOXk1ltvBaqHuR133HGv2M9nP/tZxowZw4IFCzj99NMXHu/nP//5Hvl8W9ayAJCZk4G6p8HtXrNtAse2Mh9JkiQtO+bPn8+vf/1r9t57bwBuv/12pk6dyuDBgznnnHPo168ft912Gy+88AI77bQTe+65J3fccQf33HMPd999N4899hhDhgzhiCOOeNl+Z8+ezYc//GEmTJjA4MGDeeqpp1hrrbU45phjWG211TjxxBMBOOSQQ/jEJz7BzjvvzIMPPshee+3FtGnT+MIXvsDOO+/M5z73Oa6++mrOPffcV+Q+efJkZs2axdSpUwF45plnFq6bN28ekydPZsKECRxxxBELt1nUSSedxNy5czn//PO5/vrruffee7n11lvJTEaNGsWECRMYOXLka/qMW1osSJIkST3tn//8J8OGDQOqloUjjzySm266iW233ZbBgwcDcN111zFlypSFffvnzJnDvffey4QJEzj44INZccUVGTBgALvtttsr9n/zzTczcuTIhftaa621avP47W9/+7IxDs8++yzPPfccEyZM4Oc//zkA++67L2uuueYr3vumN72J+++/n+OPP559992XPffcc+G6gw8+GICRI0fy7LPPvqyQ6HDqqaey3Xbbcc455yw83uuuu46tttoKgOeee457773XYkGSJEnLl8YxC41WXXXVhdOZyZlnnslee+31sm2uueaaHsvjpZde4uabb6ZPnz6L/d4111yTO++8k2uvvZazzz6bSy+9lPPOOw+AiHjZtovOA4wYMYJJkyYtbPXITE4++WQ+8pGPvLqD6USrxyxIkiRJbbfXXntx1lln8eKLLwLwt7/9jX/84x+MHDmSSy65hAULFvDII4/wu9/97hXv3X777ZkwYQJ///vfAXjqqacA6Nu3L3Pnzl243Z577smZZ565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\n",
      "text/plain": [
       "<Figure size 936x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# optimal spike time vs observed spike time\n",
    "\n",
    "N = 22\n",
    "\n",
    "# Data on X-axis\n",
    "\n",
    "# Specify the values of blue bars (height)\n",
    "values_opt, counts_opt = opt_idx[y == 1].unique(return_counts=True)\n",
    "blue_bar = np.zeros(25 - 4)\n",
    "cnt_to_append = 0\n",
    "for val, cnt in zip(values_opt, counts_opt):\n",
    "  if val > 0:\n",
    "    blue_bar[val - 4] = cnt.item()\n",
    "  else:\n",
    "    cnt_to_append = cnt.item()\n",
    "blue_bar = np.append(blue_bar, cnt_to_append)\n",
    "\n",
    "# Specify the values of orange bars (height)\n",
    "values_pred, counts_pred = first_spike_idx[y == 1].unique(return_counts=True)\n",
    "orange_bar = np.zeros(25 - 4)\n",
    "cnt_to_append = 0\n",
    "for val, cnt in zip(values_pred, counts_pred):\n",
    "  if val > 0:\n",
    "    orange_bar[val - 4] = cnt.item()\n",
    "  else:\n",
    "    cnt_to_append = cnt.item()\n",
    "orange_bar = np.append(orange_bar, cnt_to_append)\n",
    "\n",
    "# Position of bars on x-axis\n",
    "ind = np.arange(N)\n",
    "\n",
    "plt.figure(figsize=(13,5))\n",
    "\n",
    "# Width of a bar \n",
    "width = 0.3       \n",
    "\n",
    "# Plotting\n",
    "plt.bar(ind, blue_bar , width, label='Optimal spike')\n",
    "plt.bar(ind + width, orange_bar, width, label='Predicted spike')\n",
    "\n",
    "plt.xlabel('Spike index')\n",
    "plt.ylabel('Test set counts')\n",
    "plt.title('Optimal spikes vs observed spikes')\n",
    "\n",
    "# First argument - A list of positions at which ticks should be placed\n",
    "# Second argument -  A list of labels to place at the given locations\n",
    "x_labs = list(range(5,26))\n",
    "x_labs.append('No Spike')\n",
    "plt.xticks(ind + width / 2, x_labs)\n",
    "\n",
    "# Finding the best position for legends and putting it\n",
    "plt.legend(loc='best')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "rz0yKZSfpZrT"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "JvAK1plzpZvZ"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "6FckaoQ8pZym"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "jYSSW8Y6b35q"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "authorship_tag": "ABX9TyOUsHO8F3TuiVI8uFn/OOeW",
   "collapsed_sections": [],
   "include_colab_link": true,
   "machine_shape": "hm",
   "name": "seq_data_rank_coding2.ipynb",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
