{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "font = {'weight' : 'bold',\n",
    "        'size'   : 15}\n",
    "matplotlib.rc('font', **font)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def KL_divergence(P,Q):\n",
    "    return np.sum(P*np.log(P/Q))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Observations.csv  \u001b[34mh0.08\u001b[m\u001b[m/            \u001b[34mh0.7\u001b[m\u001b[m/             \u001b[34mh1.5\u001b[m\u001b[m/\r\n",
      "\u001b[34mh0.01\u001b[m\u001b[m/            \u001b[34mh0.09\u001b[m\u001b[m/            \u001b[34mh0.8\u001b[m\u001b[m/             \u001b[34mh1.6\u001b[m\u001b[m/\r\n",
      "\u001b[34mh0.02\u001b[m\u001b[m/            \u001b[34mh0.1\u001b[m\u001b[m/             \u001b[34mh0.9\u001b[m\u001b[m/             \u001b[34mh1.7\u001b[m\u001b[m/\r\n",
      "\u001b[34mh0.03\u001b[m\u001b[m/            \u001b[34mh0.2\u001b[m\u001b[m/             \u001b[34mh1\u001b[m\u001b[m/               \u001b[34mh1.8\u001b[m\u001b[m/\r\n",
      "\u001b[34mh0.04\u001b[m\u001b[m/            \u001b[34mh0.3\u001b[m\u001b[m/             \u001b[34mh1.1\u001b[m\u001b[m/             \u001b[34mh1.9\u001b[m\u001b[m/\r\n",
      "\u001b[34mh0.05\u001b[m\u001b[m/            \u001b[34mh0.4\u001b[m\u001b[m/             \u001b[34mh1.2\u001b[m\u001b[m/             \u001b[34mh2\u001b[m\u001b[m/\r\n",
      "\u001b[34mh0.06\u001b[m\u001b[m/            \u001b[34mh0.5\u001b[m\u001b[m/             \u001b[34mh1.3\u001b[m\u001b[m/\r\n",
      "\u001b[34mh0.07\u001b[m\u001b[m/            \u001b[34mh0.6\u001b[m\u001b[m/             \u001b[34mh1.4\u001b[m\u001b[m/\r\n"
     ]
    }
   ],
   "source": [
    "ls './store_data/two_dimension_dense/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "two_dimension_ground_truth_path = './store_data/two_dimension/ground_truth/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "dimension_list = ['two_dimension', 'higher_dimension']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "setting_list = ['dense', 'sparse']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "h_list = ['h0.01', 'h0.02', 'h0.03', 'h0.04', 'h0.05', 'h0.06', 'h0.07', 'h0.08', 'h0.09', 'h0.1', 'h0.2', 'h0.3', 'h0.4', 'h0.5', 'h0.6', 'h0.7', 'h0.8', 'h0.9', 'h1', 'h1.1', 'h1.2', 'h1.3', 'h1.4', 'h1.5', 'h1.6', 'h1.7', 'h1.8', 'h1.9', 'h2']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "h_vec = np.array([0.01, 0.02, 0.03, 0.04, 0.05, 0.06, 0.07, 0.08, 0.09, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 1.7, 1.8, 1.9, 2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "two_dimension_process_list = ['p1', 'p2', 'p12']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "higher_dimension_process_list = ['p1', 'p2', 'p3', 'p4', 'p12', 'p13', 'p14', 'p23', 'p24', 'p34', 'p123', 'p124', 'p134', 'p234', 'p1234']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "results_path = './results/'\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "dt = 0.1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Two-Dimension"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Create plots of the intensity function for dense case"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dense h0.01 p1\n"
     ]
    },
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: './store_data/two_dimension_dense/p1.csv'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "Input \u001b[0;32mIn [16]\u001b[0m, in \u001b[0;36m<cell line: 12>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     16\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m i, two_dimension_process \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28menumerate\u001b[39m(two_dimension_process_list):\n\u001b[1;32m     17\u001b[0m     \u001b[38;5;28mprint\u001b[39m(setting, h, two_dimension_process)\n\u001b[0;32m---> 18\u001b[0m     df \u001b[38;5;241m=\u001b[39m \u001b[43mpd\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mread_csv\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;132;43;01m{}\u001b[39;49;00m\u001b[38;5;132;43;01m{}\u001b[39;49;00m\u001b[38;5;124;43m.csv\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mformat\u001b[49m\u001b[43m(\u001b[49m\u001b[43mstore_path\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtwo_dimension_process\u001b[49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     19\u001b[0m     gt_bin_location \u001b[38;5;241m=\u001b[39m df[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mBin Location\u001b[39m\u001b[38;5;124m'\u001b[39m]\u001b[38;5;241m.\u001b[39mvalues\n\u001b[1;32m     20\u001b[0m     gt_pdf \u001b[38;5;241m=\u001b[39m df[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mpdf\u001b[39m\u001b[38;5;124m'\u001b[39m]\u001b[38;5;241m.\u001b[39mvalues\n",
      "File \u001b[0;32m~/opt/anaconda3/lib/python3.9/site-packages/pandas/util/_decorators.py:311\u001b[0m, in \u001b[0;36mdeprecate_nonkeyword_arguments.<locals>.decorate.<locals>.wrapper\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    305\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mlen\u001b[39m(args) \u001b[38;5;241m>\u001b[39m num_allow_args:\n\u001b[1;32m    306\u001b[0m     warnings\u001b[38;5;241m.\u001b[39mwarn(\n\u001b[1;32m    307\u001b[0m         msg\u001b[38;5;241m.\u001b[39mformat(arguments\u001b[38;5;241m=\u001b[39marguments),\n\u001b[1;32m    308\u001b[0m         \u001b[38;5;167;01mFutureWarning\u001b[39;00m,\n\u001b[1;32m    309\u001b[0m         stacklevel\u001b[38;5;241m=\u001b[39mstacklevel,\n\u001b[1;32m    310\u001b[0m     )\n\u001b[0;32m--> 311\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mfunc\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/opt/anaconda3/lib/python3.9/site-packages/pandas/io/parsers/readers.py:680\u001b[0m, in \u001b[0;36mread_csv\u001b[0;34m(filepath_or_buffer, sep, delimiter, header, names, index_col, usecols, squeeze, prefix, mangle_dupe_cols, dtype, engine, converters, true_values, false_values, skipinitialspace, skiprows, skipfooter, nrows, na_values, keep_default_na, na_filter, verbose, skip_blank_lines, parse_dates, infer_datetime_format, keep_date_col, date_parser, dayfirst, cache_dates, iterator, chunksize, compression, thousands, decimal, lineterminator, quotechar, quoting, doublequote, escapechar, comment, encoding, encoding_errors, dialect, error_bad_lines, warn_bad_lines, on_bad_lines, delim_whitespace, low_memory, memory_map, float_precision, storage_options)\u001b[0m\n\u001b[1;32m    665\u001b[0m kwds_defaults \u001b[38;5;241m=\u001b[39m _refine_defaults_read(\n\u001b[1;32m    666\u001b[0m     dialect,\n\u001b[1;32m    667\u001b[0m     delimiter,\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    676\u001b[0m     defaults\u001b[38;5;241m=\u001b[39m{\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mdelimiter\u001b[39m\u001b[38;5;124m\"\u001b[39m: \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m,\u001b[39m\u001b[38;5;124m\"\u001b[39m},\n\u001b[1;32m    677\u001b[0m )\n\u001b[1;32m    678\u001b[0m kwds\u001b[38;5;241m.\u001b[39mupdate(kwds_defaults)\n\u001b[0;32m--> 680\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_read\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfilepath_or_buffer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mkwds\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/opt/anaconda3/lib/python3.9/site-packages/pandas/io/parsers/readers.py:575\u001b[0m, in \u001b[0;36m_read\u001b[0;34m(filepath_or_buffer, kwds)\u001b[0m\n\u001b[1;32m    572\u001b[0m _validate_names(kwds\u001b[38;5;241m.\u001b[39mget(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mnames\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;28;01mNone\u001b[39;00m))\n\u001b[1;32m    574\u001b[0m \u001b[38;5;66;03m# Create the parser.\u001b[39;00m\n\u001b[0;32m--> 575\u001b[0m parser \u001b[38;5;241m=\u001b[39m \u001b[43mTextFileReader\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfilepath_or_buffer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwds\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    577\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m chunksize \u001b[38;5;129;01mor\u001b[39;00m iterator:\n\u001b[1;32m    578\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m parser\n",
      "File \u001b[0;32m~/opt/anaconda3/lib/python3.9/site-packages/pandas/io/parsers/readers.py:934\u001b[0m, in \u001b[0;36mTextFileReader.__init__\u001b[0;34m(self, f, engine, **kwds)\u001b[0m\n\u001b[1;32m    931\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39moptions[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mhas_index_names\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m=\u001b[39m kwds[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mhas_index_names\u001b[39m\u001b[38;5;124m\"\u001b[39m]\n\u001b[1;32m    933\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mhandles: IOHandles \u001b[38;5;241m|\u001b[39m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mNone\u001b[39;00m\n\u001b[0;32m--> 934\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_engine \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_make_engine\u001b[49m\u001b[43m(\u001b[49m\u001b[43mf\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mengine\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/opt/anaconda3/lib/python3.9/site-packages/pandas/io/parsers/readers.py:1218\u001b[0m, in \u001b[0;36mTextFileReader._make_engine\u001b[0;34m(self, f, engine)\u001b[0m\n\u001b[1;32m   1214\u001b[0m     mode \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mrb\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m   1215\u001b[0m \u001b[38;5;66;03m# error: No overload variant of \"get_handle\" matches argument types\u001b[39;00m\n\u001b[1;32m   1216\u001b[0m \u001b[38;5;66;03m# \"Union[str, PathLike[str], ReadCsvBuffer[bytes], ReadCsvBuffer[str]]\"\u001b[39;00m\n\u001b[1;32m   1217\u001b[0m \u001b[38;5;66;03m# , \"str\", \"bool\", \"Any\", \"Any\", \"Any\", \"Any\", \"Any\"\u001b[39;00m\n\u001b[0;32m-> 1218\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mhandles \u001b[38;5;241m=\u001b[39m \u001b[43mget_handle\u001b[49m\u001b[43m(\u001b[49m\u001b[43m  \u001b[49m\u001b[38;5;66;43;03m# type: ignore[call-overload]\u001b[39;49;00m\n\u001b[1;32m   1219\u001b[0m \u001b[43m    \u001b[49m\u001b[43mf\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m   1220\u001b[0m \u001b[43m    \u001b[49m\u001b[43mmode\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m   1221\u001b[0m \u001b[43m    \u001b[49m\u001b[43mencoding\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43moptions\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mencoding\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m   1222\u001b[0m \u001b[43m    \u001b[49m\u001b[43mcompression\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43moptions\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mcompression\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m   1223\u001b[0m \u001b[43m    \u001b[49m\u001b[43mmemory_map\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43moptions\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mmemory_map\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mFalse\u001b[39;49;00m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m   1224\u001b[0m \u001b[43m    \u001b[49m\u001b[43mis_text\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mis_text\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m   1225\u001b[0m \u001b[43m    \u001b[49m\u001b[43merrors\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43moptions\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mencoding_errors\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mstrict\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m   1226\u001b[0m \u001b[43m    \u001b[49m\u001b[43mstorage_options\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43moptions\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mstorage_options\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m   1227\u001b[0m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1228\u001b[0m \u001b[38;5;28;01massert\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mhandles \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m\n\u001b[1;32m   1229\u001b[0m f \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mhandles\u001b[38;5;241m.\u001b[39mhandle\n",
      "File \u001b[0;32m~/opt/anaconda3/lib/python3.9/site-packages/pandas/io/common.py:786\u001b[0m, in \u001b[0;36mget_handle\u001b[0;34m(path_or_buf, mode, encoding, compression, memory_map, is_text, errors, storage_options)\u001b[0m\n\u001b[1;32m    781\u001b[0m \u001b[38;5;28;01melif\u001b[39;00m \u001b[38;5;28misinstance\u001b[39m(handle, \u001b[38;5;28mstr\u001b[39m):\n\u001b[1;32m    782\u001b[0m     \u001b[38;5;66;03m# Check whether the filename is to be opened in binary mode.\u001b[39;00m\n\u001b[1;32m    783\u001b[0m     \u001b[38;5;66;03m# Binary mode does not support 'encoding' and 'newline'.\u001b[39;00m\n\u001b[1;32m    784\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m ioargs\u001b[38;5;241m.\u001b[39mencoding \u001b[38;5;129;01mand\u001b[39;00m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mb\u001b[39m\u001b[38;5;124m\"\u001b[39m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;129;01min\u001b[39;00m ioargs\u001b[38;5;241m.\u001b[39mmode:\n\u001b[1;32m    785\u001b[0m         \u001b[38;5;66;03m# Encoding\u001b[39;00m\n\u001b[0;32m--> 786\u001b[0m         handle \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mopen\u001b[39;49m\u001b[43m(\u001b[49m\n\u001b[1;32m    787\u001b[0m \u001b[43m            \u001b[49m\u001b[43mhandle\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    788\u001b[0m \u001b[43m            \u001b[49m\u001b[43mioargs\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mmode\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    789\u001b[0m \u001b[43m            \u001b[49m\u001b[43mencoding\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mioargs\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mencoding\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    790\u001b[0m \u001b[43m            \u001b[49m\u001b[43merrors\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43merrors\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    791\u001b[0m \u001b[43m            \u001b[49m\u001b[43mnewline\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m    792\u001b[0m \u001b[43m        \u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    793\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    794\u001b[0m         \u001b[38;5;66;03m# Binary mode\u001b[39;00m\n\u001b[1;32m    795\u001b[0m         handle \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mopen\u001b[39m(handle, ioargs\u001b[38;5;241m.\u001b[39mmode)\n",
      "\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: './store_data/two_dimension_dense/p1.csv'"
     ]
    }
   ],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[0]\n",
    "setting = setting_list[0]\n",
    "\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    process_path = '{}{}/'.format(results_path, h)\n",
    "    if not os.path.exists(process_path):\n",
    "        os.mkdir(process_path)\n",
    "    for i, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "        print(setting, h, two_dimension_process)\n",
    "        df = pd.read_csv('{}{}.csv'.format(store_path, two_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        plt.clf()\n",
    "        \n",
    "        plt.plot(gt_bin_location, gt_pdf * np.sum(order1) / dt, 'k', linewidth=3)\n",
    "        plt.plot(time, order1, linewidth=3)\n",
    "        plt.plot(time, order2, '--', linewidth=3)\n",
    "\n",
    "        \n",
    "        plt.plot(event_time, np.zeros(len(event_time)), '.k')\n",
    "\n",
    "        plt.xlabel('Time', fontsize=18, fontweight='bold')\n",
    "        plt.ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "        plt.legend(['Ground Truth', 'Order: 1', 'Order: 2'], ncol=2)\n",
    "        plt.grid()\n",
    "        plt.tight_layout()\n",
    "        plt.savefig('{}{}_{}_{}_{}.eps'.format(process_path, dimension, setting, two_dimension_process, h.replace('.','')), format='eps')\n",
    "        plt.savefig('{}{}_{}_{}_{}.png'.format(process_path, dimension, setting, two_dimension_process, h.replace('.','')), format='png', dpi=600)\n",
    "        plt.show()\n",
    "        print('order 2:', np.round(np.sum(order2)))\n",
    "        print('ground truth:', len(event_time))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Create plots of the intensity function for sparse case"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[0]\n",
    "setting = setting_list[1]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    process_path = '{}{}/'.format(results_path, h)\n",
    "    if not os.path.exists(process_path):\n",
    "        os.mkdir(process_path)\n",
    "    for i, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "        print(setting, h, two_dimension_process)\n",
    "        df = pd.read_csv('{}{}.csv'.format(two_dimension_ground_truth_path, two_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        plt.clf()\n",
    "\n",
    "        plt.plot(gt_bin_location, gt_pdf * np.sum(order1) / dt, 'k', linewidth=3)\n",
    "        plt.plot(time, order1, linewidth=3)\n",
    "        plt.plot(time, order2, '--', linewidth=3)\n",
    "\n",
    "        plt.plot(event_time, np.zeros(len(event_time)), '.k')\n",
    "\n",
    "        plt.xlabel('Time', fontsize=18, fontweight='bold')\n",
    "        plt.ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "        plt.legend(['Ground Truth', 'Order: 1', 'Order: 2'], ncol=2)\n",
    "        plt.grid()\n",
    "        plt.tight_layout()\n",
    "        plt.savefig('{}{}_{}_{}_{}.eps'.format(process_path, dimension, setting, two_dimension_process, h.replace('.','')), format='eps')\n",
    "        plt.savefig('{}{}_{}_{}_{}.png'.format(process_path, dimension, setting, two_dimension_process, h.replace('.','')), format='png', dpi=600)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Make subplot for dense setting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dimension = dimension_list[0]\n",
    "setting = setting_list[0]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    process_path = '{}{}/'.format(results_path, h)\n",
    "    if not os.path.exists(process_path):\n",
    "        os.mkdir(process_path)\n",
    "    plt.clf()\n",
    "    fig, ax = plt.subplots(1,3, figsize=(32, 5))\n",
    "    for i, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "        print(setting, h, two_dimension_process)\n",
    "        df = pd.read_csv('{}{}.csv'.format(two_dimension_ground_truth_path, two_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "        \n",
    "        \n",
    "#         cax = ax[np.unravel_index(i, (1,4))]\n",
    "        cax = ax[i]\n",
    "        cax.plot(gt_bin_location, gt_pdf * np.sum(order1) / dt, 'k', linewidth=3)    \n",
    "        cax.plot(time, order1, linewidth=3.5)\n",
    "        cax.plot(time, order2, '--', linewidth=3)\n",
    "\n",
    "        cax.plot(event_time, np.zeros(len(event_time)), '.k')\n",
    "        cax.grid()\n",
    "\n",
    "        cax.set_xlabel('Time', fontsize=18, fontweight='bold')\n",
    "        cax.set_ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "        cax.set_title('Process: {}'.format([int(_) for _ in two_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "    cax = ax[1]\n",
    "#     cax.axis('off')\n",
    "    color_list = [c['color'] for c in matplotlib.rcParams['axes.prop_cycle']]\n",
    "    line_list = list()\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color='k', linewidth=3))\n",
    "    cax.legend(line_list, ['Ground Truth', 'Order: 1', 'Order: 2'], ncol=3, loc='upper center', bbox_to_anchor=(0.5, -0.2))\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}.eps'.format(process_path, dimension, setting, h.replace('.','')), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}.png'.format(process_path, dimension, setting, h.replace('.','')), format='png', dpi=600)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Make subplot for sparse setting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[0]\n",
    "setting = setting_list[1]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    process_path = '{}{}/'.format(results_path, h)\n",
    "    if not os.path.exists(process_path):\n",
    "        os.mkdir(process_path)\n",
    "    plt.clf()\n",
    "    fig, ax = plt.subplots(1,3, figsize=(32, 5))\n",
    "    for i, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "        print(setting, h, two_dimension_process)\n",
    "        df = pd.read_csv('{}{}.csv'.format(two_dimension_ground_truth_path, two_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "        \n",
    "        \n",
    "#         cax = ax[np.unravel_index(i, (1,4))]\n",
    "        cax = ax[i]\n",
    "        cax.plot(gt_bin_location, gt_pdf * np.sum(order1) / dt, 'k', linewidth=3) \n",
    "        cax.plot(time, order1, linewidth=3.5)\n",
    "        cax.plot(time, order2, '--', linewidth=3)\n",
    "           \n",
    "        cax.plot(event_time, np.zeros(len(event_time)), '.k')\n",
    "        cax.grid()\n",
    "\n",
    "        cax.set_xlabel('Time', fontsize=18, fontweight='bold')\n",
    "        cax.set_ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "        cax.set_title('Process: {}'.format([int(_) for _ in two_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "    cax = ax[1]\n",
    "#     cax.axis('off')\n",
    "    color_list = [c['color'] for c in matplotlib.rcParams['axes.prop_cycle']]\n",
    "    line_list = list()\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color='k', linewidth=3))\n",
    "    cax.legend(line_list, ['Ground Truth', 'Order: 1', 'Order: 2'], ncol=3, loc='upper center', bbox_to_anchor=(0.5, -0.2))\n",
    "    plt.tight_layout()\n",
    "    print('{}{}_{}_{}.eps'.format(process_path, dimension, setting, h))\n",
    "    plt.savefig('{}{}_{}_{}.eps'.format(process_path, dimension, setting, h.replace('.','')), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}.png'.format(process_path, dimension, setting, h.replace('.','')), format='png', dpi=600)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Calculate and plot KL divergence for dense setting for the intensity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[0]\n",
    "setting = setting_list[0]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "order1_KL_list = list()\n",
    "order2_KL_list = list()\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    for i, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "        df = pd.read_csv('{}{}.csv'.format(two_dimension_ground_truth_path, two_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        order1_KL = KL_divergence(order1, gt_pdf * np.sum(order1) / dt)\n",
    "        order2_KL = KL_divergence(order2, gt_pdf * np.sum(order1) / dt)\n",
    "        \n",
    "        order1_KL_list.append(order1_KL)\n",
    "        order2_KL_list.append(order2_KL)\n",
    "\n",
    "order1_KL_list = np.array(order1_KL_list).reshape(len(h_list), len(two_dimension_process))\n",
    "order2_KL_list = np.array(order2_KL_list).reshape(len(h_list), len(two_dimension_process))\n",
    "for p, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "    plt.clf()\n",
    "    plt.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    plt.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    plt.yscale('log')\n",
    "    plt.grid(which='minor')\n",
    "    plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    plt.legend(['Order: 1', 'Order: 2'])\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.eps'.format(results_path, dimension, setting, p), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.png'.format(results_path, dimension, setting, p), format='png', dpi=600)\n",
    "    plt.show()\n",
    "\n",
    "plt.clf()\n",
    "plt.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "plt.yscale('log')\n",
    "plt.grid(which='minor')\n",
    "plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.legend(['Order: 1', 'Order: 2'])\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_total_KL_divergence.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_total_KL_divergence.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "plt.clf()\n",
    "fig, ax = plt.subplots(1,4, figsize=(32, 5))\n",
    "for p, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "    cax = ax[p]\n",
    "    cax.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.set_yscale('log')\n",
    "    cax.grid(which='minor')\n",
    "    cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    cax.set_title('Process: {}'.format([int(_) for _ in two_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "\n",
    "cax = ax[3]\n",
    "cax.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.set_yscale('log')\n",
    "cax.grid(which='minor')\n",
    "cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax.set_title('Total KL Divergence', fontsize=18, fontweight='bold')\n",
    "\n",
    "cax = ax[1]\n",
    "color_list = [c['color'] for c in matplotlib.rcParams['axes.prop_cycle']]\n",
    "line_list = list()\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "cax.legend(line_list, ['Order: 1', 'Order: 2'], ncol=2, loc='upper center', bbox_to_anchor=(0.5, -0.2))\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence_intensity_subplotted.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence_intensity_subplotted.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Calculate and plot KL divergence for dense setting for the density"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[0]\n",
    "setting = setting_list[0]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "order1_KL_list = list()\n",
    "order2_KL_list = list()\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    for i, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "        df = pd.read_csv('{}{}.csv'.format(two_dimension_ground_truth_path, two_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        order1_KL = KL_divergence(order1 / np.sum(order1) * dt, gt_pdf)\n",
    "        order2_KL = KL_divergence(order2 / np.sum(order1) * dt, gt_pdf)\n",
    "        order1_KL_list.append(order1_KL)\n",
    "        order2_KL_list.append(order2_KL)\n",
    "\n",
    "order1_KL_list = np.array(order1_KL_list).reshape(len(h_list), len(two_dimension_process))\n",
    "order2_KL_list = np.array(order2_KL_list).reshape(len(h_list), len(two_dimension_process))\n",
    "for p, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "    plt.clf()\n",
    "    plt.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    plt.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    plt.yscale('log')\n",
    "    plt.grid(which='minor')\n",
    "    plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    plt.legend(['Order: 1', 'Order: 2'])\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.eps'.format(results_path, dimension, setting, p), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.png'.format(results_path, dimension, setting, p), format='png', dpi=600)\n",
    "    plt.show()\n",
    "\n",
    "plt.clf()\n",
    "plt.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "plt.yscale('log')\n",
    "plt.grid(which='minor')\n",
    "plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.legend(['Order: 1', 'Order: 2'])\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_total_KL_divergence.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_total_KL_divergence.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "plt.clf()\n",
    "fig, ax = plt.subplots(1,4, figsize=(32, 5))\n",
    "for p, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "    cax = ax[p]\n",
    "    cax.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.set_yscale('log')\n",
    "    cax.grid(which='minor')\n",
    "    cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    cax.set_title('Process: {}'.format([int(_) for _ in two_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "\n",
    "cax = ax[3]\n",
    "cax.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.set_yscale('log')\n",
    "cax.grid(which='minor')\n",
    "cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax.set_title('Total KL Divergence', fontsize=18, fontweight='bold')\n",
    "\n",
    "cax = ax[1]\n",
    "color_list = [c['color'] for c in matplotlib.rcParams['axes.prop_cycle']]\n",
    "line_list = list()\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "cax.legend(line_list, ['Order: 1', 'Order: 2'], ncol=2, loc='upper center', bbox_to_anchor=(0.5, -0.2))\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Calculate and plot KL divergence for sparse setting for the intensity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[0]\n",
    "setting = setting_list[1]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "order1_KL_list = list()\n",
    "order2_KL_list = list()\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    for i, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "        df = pd.read_csv('{}{}.csv'.format(two_dimension_ground_truth_path, two_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        order1_KL = KL_divergence(order1, gt_pdf * np.sum(order1) / dt)\n",
    "        order2_KL = KL_divergence(order2, gt_pdf * np.sum(order1) / dt)\n",
    "        \n",
    "        order1_KL_list.append(order1_KL)\n",
    "        order2_KL_list.append(order2_KL)\n",
    "\n",
    "order1_KL_list = np.array(order1_KL_list).reshape(len(h_list), len(two_dimension_process))\n",
    "order2_KL_list = np.array(order2_KL_list).reshape(len(h_list), len(two_dimension_process))\n",
    "for p, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "    plt.clf()\n",
    "    plt.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    plt.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    plt.yscale('log')\n",
    "    plt.grid(which='minor')\n",
    "    plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    plt.legend(['Order: 1', 'Order: 2'])\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.eps'.format(results_path, dimension, setting, p), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.png'.format(results_path, dimension, setting, p), format='png', dpi=600)\n",
    "    plt.show()\n",
    "\n",
    "plt.clf()\n",
    "plt.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "plt.yscale('log')\n",
    "plt.grid(which='minor')\n",
    "plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.legend(['Order: 1', 'Order: 2'])\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "plt.clf()\n",
    "fig, ax = plt.subplots(1,4, figsize=(32, 5))\n",
    "for p, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "    cax = ax[p]\n",
    "    cax.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.set_yscale('log')\n",
    "    cax.grid(which='minor')\n",
    "    cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    cax.set_title('Process: {}'.format([int(_) for _ in two_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "\n",
    "cax = ax[3]\n",
    "cax.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.set_yscale('log')\n",
    "cax.grid(which='minor')\n",
    "cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax.set_title('Total KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax = ax[1]\n",
    "cax.legend(line_list, ['Order: 1', 'Order: 2'], ncol=2, loc='upper center', bbox_to_anchor=(0.5, -0.2))\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence_intensity_subplotted.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence_intensity_subplotted.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Calculate and plot KL divergence for sparse setting for the density"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[0]\n",
    "setting = setting_list[1]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "order1_KL_list = list()\n",
    "order2_KL_list = list()\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    for i, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "        df = pd.read_csv('{}{}.csv'.format(two_dimension_ground_truth_path, two_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, two_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        order1_KL = KL_divergence(order1 / np.sum(order1) * dt, gt_pdf)\n",
    "        order2_KL = KL_divergence(order2 / np.sum(order1) * dt, gt_pdf)\n",
    "        \n",
    "        order1_KL_list.append(order1_KL)\n",
    "        order2_KL_list.append(order2_KL)\n",
    "\n",
    "order1_KL_list = np.array(order1_KL_list).reshape(len(h_list), len(two_dimension_process))\n",
    "order2_KL_list = np.array(order2_KL_list).reshape(len(h_list), len(two_dimension_process))\n",
    "for p, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "    plt.clf()\n",
    "    plt.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    plt.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    plt.yscale('log')\n",
    "    plt.grid(which='minor')\n",
    "    plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    plt.legend(['Order: 1', 'Order: 2'])\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.eps'.format(results_path, dimension, setting, p), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.png'.format(results_path, dimension, setting, p), format='png', dpi=600)\n",
    "    plt.show()\n",
    "\n",
    "plt.clf()\n",
    "plt.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "plt.yscale('log')\n",
    "plt.grid(which='minor')\n",
    "plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.legend(['Order: 1', 'Order: 2'])\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "plt.clf()\n",
    "fig, ax = plt.subplots(1,4, figsize=(32, 5))\n",
    "for p, two_dimension_process in enumerate(two_dimension_process_list):\n",
    "    cax = ax[p]\n",
    "    cax.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.set_yscale('log')\n",
    "    cax.grid(which='minor')\n",
    "    cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    cax.set_title('Process: {}'.format([int(_) for _ in two_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "\n",
    "cax = ax[3]\n",
    "cax.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.set_yscale('log')\n",
    "cax.grid(which='minor')\n",
    "cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax.set_title('Total KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax = ax[1]\n",
    "cax.legend(line_list, ['Order: 1', 'Order: 2'], ncol=2, loc='upper center', bbox_to_anchor=(0.5, -0.2))\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Higher-Order Experiment"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Create plots of the intensity function for dense case"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "higher_dimension_ground_truth_path = './store_data/higher_dimension/ground_truth/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[1]\n",
    "setting = setting_list[0]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    process_path = '{}{}/'.format(results_path, h)\n",
    "    if not os.path.exists(process_path):\n",
    "        os.mkdir(process_path)\n",
    "    plt.clf()\n",
    "    if not os.path.exists(process_path):\n",
    "        os.mkdir(process_path)\n",
    "    for i, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "        print(setting, h, higher_dimension_process)\n",
    "        df = pd.read_csv('{}{}.csv'.format(higher_dimension_ground_truth_path, higher_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "        order3 = df['Order3'].values\n",
    "        order4 = df['Order4'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        plt.clf()\n",
    "        plt.plot(gt_bin_location, gt_pdf * np.sum(order1) / dt, 'k', linewidth=3)\n",
    "        plt.plot(time, order1, linewidth=3)\n",
    "        plt.plot(time, order2, '-.', linewidth=3)\n",
    "        plt.plot(time, order3, '--', linewidth=3)\n",
    "        plt.plot(time, order4, ':', linewidth=3)\n",
    "\n",
    "        \n",
    "        plt.plot(event_time, np.zeros(len(event_time)), '.k')\n",
    "\n",
    "        plt.xlabel('Time', fontsize=18, fontweight='bold')\n",
    "        plt.ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "        plt.legend(['Ground Truth', 'Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'], ncol=2)\n",
    "        plt.grid()\n",
    "        plt.tight_layout()\n",
    "        plt.savefig('{}{}_{}_{}_{}.eps'.format(process_path, dimension, setting, higher_dimension_process, h.replace('.','')), format='eps')\n",
    "        plt.savefig('{}{}_{}_{}_{}.png'.format(process_path, dimension, setting, higher_dimension_process, h.replace('.','')), format='png', dpi=600)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Create plots of the intensity function for sparse case"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[1]\n",
    "setting = setting_list[1]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    process_path = '{}{}/'.format(results_path, h)\n",
    "    if not os.path.exists(process_path):\n",
    "        os.mkdir(process_path)\n",
    "    plt.clf()\n",
    "    if not os.path.exists(process_path):\n",
    "        os.mkdir(process_path)\n",
    "    for i, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "        print(setting, h, higher_dimension_process)\n",
    "        df = pd.read_csv('{}{}.csv'.format(higher_dimension_ground_truth_path, higher_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "        order3 = df['Order3'].values\n",
    "        order4 = df['Order4'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        plt.clf()\n",
    "        plt.plot(gt_bin_location, gt_pdf * np.sum(order1) / dt, 'k', linewidth=4)\n",
    "        plt.plot(time, order1, linewidth=3.5)\n",
    "        plt.plot(time, order2, '-.', linewidth=3)\n",
    "        plt.plot(time, order3, '--', linewidth=3)\n",
    "        plt.plot(time, order4, ':', linewidth=3)\n",
    "\n",
    "        plt.plot(event_time, np.zeros(len(event_time)), '.k')\n",
    "\n",
    "        plt.xlabel('Time', fontsize=18, fontweight='bold')\n",
    "        plt.ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "        plt.legend(['Ground Truth', 'Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'], ncol=2)\n",
    "        plt.grid()\n",
    "        plt.tight_layout()\n",
    "        plt.savefig('{}{}_{}_{}_{}.eps'.format(process_path, dimension, setting, higher_dimension_process, h.replace('.','')), format='eps')\n",
    "        plt.savefig('{}{}_{}_{}_{}.png'.format(process_path, dimension, setting, higher_dimension_process, h.replace('.','')), format='png', dpi=600)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Make subplot for dense setting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[1]\n",
    "setting = setting_list[0]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    process_path = '{}{}/'.format(results_path, h)\n",
    "    if not os.path.exists(process_path):\n",
    "        os.mkdir(process_path)\n",
    "    plt.clf()\n",
    "    fig, ax = plt.subplots(4,4, figsize=(32, 15))\n",
    "    for i, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "        print(setting, h, higher_dimension_process)\n",
    "        df = pd.read_csv('{}{}.csv'.format(higher_dimension_ground_truth_path, higher_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "        order3 = df['Order3'].values\n",
    "        order4 = df['Order4'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "        \n",
    "        \n",
    "        \n",
    "        cax = ax[np.unravel_index(i, (4,4))]\n",
    "        cax.plot(gt_bin_location, gt_pdf * np.sum(order1) / dt, 'k', linewidth=4)   \n",
    "        cax.plot(time, order1, linewidth=3.5)\n",
    "        cax.plot(time, order2, '-.', linewidth=3)\n",
    "        cax.plot(time, order3, '--', linewidth=3)\n",
    "        cax.plot(time, order4, ':', linewidth=3)\n",
    "\n",
    "\n",
    "         \n",
    "        cax.plot(event_time, np.zeros(len(event_time)), '.k')\n",
    "        cax.grid()\n",
    "\n",
    "        cax.set_xlabel('Time', fontsize=18, fontweight='bold')\n",
    "        cax.set_ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "        cax.set_title('Process: {}'.format([int(_) for _ in higher_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "    cax = ax[3,3]\n",
    "    cax.axis('off')\n",
    "    color_list = [c['color'] for c in matplotlib.rcParams['axes.prop_cycle']]\n",
    "    line_list = list()\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[2], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[3], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color='black', linewidth=3))\n",
    "    cax.legend(line_list, ['Ground Truth', 'Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'], ncol=2, loc='lower right')\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}.eps'.format(process_path, dimension, setting, h.replace('.','')), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}.png'.format(process_path, dimension, setting, h.replace('.','')), format='png', dpi=600)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Make subplot for sparse setting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[1]\n",
    "setting = setting_list[1]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    process_path = '{}{}/'.format(results_path, h)\n",
    "    if not os.path.exists(process_path):\n",
    "        os.mkdir(process_path)\n",
    "    plt.clf()\n",
    "    fig, ax = plt.subplots(4,4, figsize=(32, 15))\n",
    "    for i, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "        print(setting, h, higher_dimension_process)\n",
    "        df = pd.read_csv('{}{}.csv'.format(higher_dimension_ground_truth_path, higher_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "        order3 = df['Order3'].values\n",
    "        order4 = df['Order4'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "        \n",
    "        \n",
    "        \n",
    "        cax = ax[np.unravel_index(i, (4,4))]\n",
    "        cax.plot(gt_bin_location, gt_pdf * np.sum(order1) / dt, 'k', linewidth=4) \n",
    "        cax.plot(time, order1, linewidth=3.5)\n",
    "        cax.plot(time, order2, '-.', linewidth=3)\n",
    "        cax.plot(time, order3, '--', linewidth=3)\n",
    "        cax.plot(time, order4, ':', linewidth=3)\n",
    "\n",
    "\n",
    "           \n",
    "        cax.plot(event_time, np.zeros(len(event_time)), '.k')\n",
    "        cax.grid()\n",
    "\n",
    "        cax.set_xlabel('Time', fontsize=18, fontweight='bold')\n",
    "        cax.set_ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "        cax.set_title('Process: {}'.format([int(_) for _ in higher_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "    cax = ax[3,3]\n",
    "    cax.axis('off')\n",
    "    color_list = [c['color'] for c in matplotlib.rcParams['axes.prop_cycle']]\n",
    "    line_list = list()\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[2], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[3], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color='black', linewidth=3))\n",
    "    cax.legend(line_list, ['Ground Truth', 'Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'], ncol=2, loc='lower right')\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}.eps'.format(process_path, dimension, setting, h.replace('.','')), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}.png'.format(process_path, dimension, setting, h.replace('.','')), format='png', dpi=600)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": [
    "Representitive Diagram"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "representitive_higher_dimension_process_list = ['p1', 'p12', 'p123', 'p1234']\n",
    "# Set settings\n",
    "dimension = dimension_list[1]\n",
    "setting = setting_list[0]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    process_path = '{}{}/'.format(results_path, h)\n",
    "    if not os.path.exists(process_path):\n",
    "        os.mkdir(process_path)\n",
    "    plt.clf()\n",
    "    fig, ax = plt.subplots(1,4, figsize=(32, 5))\n",
    "    ax = np.atleast_2d(ax)\n",
    "    for i, higher_dimension_process in enumerate(representitive_higher_dimension_process_list):\n",
    "        print(setting, h, higher_dimension_process)\n",
    "        df = pd.read_csv('{}{}.csv'.format(higher_dimension_ground_truth_path, higher_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "        order3 = df['Order3'].values\n",
    "        order4 = df['Order4'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "        \n",
    "        \n",
    "        print(np.unravel_index(i, (1,4)))\n",
    "        cax = ax[np.unravel_index(i, (1,4))]\n",
    "        cax.plot(gt_bin_location, gt_pdf * np.sum(order1) / dt, 'k', linewidth=4)   \n",
    "        cax.plot(time, order1, linewidth=3.5)\n",
    "        cax.plot(time, order2, '-.', linewidth=3)\n",
    "        cax.plot(time, order3, '--', linewidth=3)\n",
    "        cax.plot(time, order4, ':', linewidth=3)\n",
    "\n",
    "\n",
    "         \n",
    "        cax.plot(event_time, np.zeros(len(event_time)), '.k')\n",
    "        cax.grid()\n",
    "\n",
    "        cax.set_xlabel('Time', fontsize=18, fontweight='bold')\n",
    "        cax.set_ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "        cax.set_title('Process: {}'.format([int(_) for _ in higher_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "    cax = ax[0,2]\n",
    "# #     cax.axis('off')\n",
    "    color_list = [c['color'] for c in matplotlib.rcParams['axes.prop_cycle']]\n",
    "    line_list = list()\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[2], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[3], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color='black', linewidth=3))\n",
    "    cax.legend(line_list, ['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4', 'Ground Truth'], ncol=3, loc='upper center', bbox_to_anchor=(0.5, -0.2))\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}_Representitive.eps'.format(process_path, dimension, setting, h.replace('.','')), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}_Representitive.png'.format(process_path, dimension, setting, h.replace('.','')), format='png', dpi=600)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "representitive_higher_dimension_process_list = ['p1', 'p12', 'p123', 'p1234']\n",
    "\n",
    "# Set settings\n",
    "dimension = dimension_list[1]\n",
    "setting = setting_list[1]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    process_path = '{}{}/'.format(results_path, h)\n",
    "    if not os.path.exists(process_path):\n",
    "        os.mkdir(process_path)\n",
    "    plt.clf()\n",
    "    fig, ax = plt.subplots(1,4, figsize=(32, 5))\n",
    "    ax = np.atleast_2d(ax)\n",
    "    for i, higher_dimension_process in enumerate(representitive_higher_dimension_process_list):\n",
    "        print(setting, h, higher_dimension_process)\n",
    "        df = pd.read_csv('{}{}.csv'.format(higher_dimension_ground_truth_path, higher_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "        order3 = df['Order3'].values\n",
    "        order4 = df['Order4'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "        \n",
    "        \n",
    "        \n",
    "        cax = ax[np.unravel_index(i, (4,4))]\n",
    "        cax.plot(gt_bin_location, gt_pdf * np.sum(order1) / dt, 'k', linewidth=4) \n",
    "        cax.plot(time, order1, linewidth=3.5)\n",
    "        cax.plot(time, order2, '-.', linewidth=3)\n",
    "        cax.plot(time, order3, '--', linewidth=3)\n",
    "        cax.plot(time, order4, ':', linewidth=3)\n",
    "\n",
    "\n",
    "           \n",
    "        cax.plot(event_time, np.zeros(len(event_time)), '.k')\n",
    "        cax.grid()\n",
    "\n",
    "        cax.set_xlabel('Time', fontsize=18, fontweight='bold')\n",
    "        cax.set_ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "        cax.set_title('Process: {}'.format([int(_) for _ in higher_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "    cax = ax[0,2]\n",
    "# #     cax.axis('off')\n",
    "    color_list = [c['color'] for c in matplotlib.rcParams['axes.prop_cycle']]\n",
    "    line_list = list()\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[2], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[3], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color='black', linewidth=3))\n",
    "    cax.legend(line_list, ['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4', 'Ground Truth'], ncol=3, loc='upper center', bbox_to_anchor=(0.5, -0.2))\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}_representitive.eps'.format(process_path, dimension, setting, h.replace('.','')), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}_representitive.png'.format(process_path, dimension, setting, h.replace('.','')), format='png', dpi=600)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Calculate and plot KL divergence for dense setting for intensity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[1]\n",
    "setting = setting_list[0]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "order1_KL_list = list()\n",
    "order2_KL_list = list()\n",
    "order3_KL_list = list()\n",
    "order4_KL_list = list()\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    for i, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "        df = pd.read_csv('{}{}.csv'.format(higher_dimension_ground_truth_path, higher_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "        order3 = df['Order3'].values\n",
    "        order4 = df['Order4'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        order1_KL = KL_divergence(order1, gt_pdf * np.sum(order1) / dt)\n",
    "        order2_KL = KL_divergence(order2, gt_pdf * np.sum(order1) / dt)\n",
    "        order3_KL = KL_divergence(order3, gt_pdf * np.sum(order1) / dt)\n",
    "        order4_KL = KL_divergence(order4, gt_pdf * np.sum(order1) / dt)\n",
    "        \n",
    "        order1_KL_list.append(order1_KL)\n",
    "        order2_KL_list.append(order2_KL)\n",
    "        order3_KL_list.append(order3_KL)\n",
    "        order4_KL_list.append(order4_KL)\n",
    "\n",
    "order1_KL_list = np.array(order1_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "order2_KL_list = np.array(order2_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "order3_KL_list = np.array(order3_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "order4_KL_list = np.array(order4_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "for p, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "    plt.clf()\n",
    "    plt.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    plt.plot(h_vec, order2_KL_list[:,p], '-.o', linewidth=3)\n",
    "    plt.plot(h_vec, order3_KL_list[:,p], '--o', linewidth=3)\n",
    "    plt.plot(h_vec, order4_KL_list[:,p], ':o', linewidth=3)\n",
    "    plt.yscale('log')\n",
    "    plt.grid(which='minor')\n",
    "    plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    plt.legend(['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'])\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.eps'.format(results_path, dimension, setting, p), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.png'.format(results_path, dimension, setting, p), format='png', dpi=600)\n",
    "    plt.show()\n",
    "\n",
    "plt.clf()\n",
    "plt.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order2_KL_list, axis=1), '-.o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order3_KL_list, axis=1), '--o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order4_KL_list, axis=1), ':o', linewidth=3)\n",
    "plt.yscale('log')\n",
    "plt.grid(which='minor')\n",
    "plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.legend(['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'])\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "plt.clf()\n",
    "fig, ax = plt.subplots(4,4, figsize=(32, 10))\n",
    "for p, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "    cax = ax[np.unravel_index(p, (4,4))]\n",
    "    cax.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.plot(h_vec, order3_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order4_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.set_yscale('log')\n",
    "    cax.grid(which='minor')\n",
    "    cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    cax.set_title('Process: {}'.format([int(_) for _ in higher_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "\n",
    "cax = ax[np.unravel_index(15, (4,4))]\n",
    "cax.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order3_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order4_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.set_yscale('log')\n",
    "cax.grid(which='minor')\n",
    "cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax.set_title('Total KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax = ax[np.unravel_index(13, (4,4))]\n",
    "line_list = list()\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[2], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[3], linewidth=3))\n",
    "cax.legend(line_list, ['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'], ncol=4, loc='upper center', bbox_to_anchor=(0.5, -0.5))\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Calculate and plot KL divergence for dense setting for density"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[1]\n",
    "setting = setting_list[0]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "order1_KL_list = list()\n",
    "order2_KL_list = list()\n",
    "order3_KL_list = list()\n",
    "order4_KL_list = list()\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    for i, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "        df = pd.read_csv('{}{}.csv'.format(higher_dimension_ground_truth_path, higher_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "        order3 = df['Order3'].values\n",
    "        order4 = df['Order4'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        order1_KL = KL_divergence(order1 / np.sum(order1) * dt, gt_pdf)\n",
    "        order2_KL = KL_divergence(order2 / np.sum(order1) * dt, gt_pdf)\n",
    "        order3_KL = KL_divergence(order3 / np.sum(order1) * dt, gt_pdf)\n",
    "        order4_KL = KL_divergence(order4 / np.sum(order1) * dt, gt_pdf)\n",
    "        \n",
    "        order1_KL_list.append(order1_KL)\n",
    "        order2_KL_list.append(order2_KL)\n",
    "        order3_KL_list.append(order3_KL)\n",
    "        order4_KL_list.append(order4_KL)\n",
    "\n",
    "order1_KL_list = np.array(order1_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "order2_KL_list = np.array(order2_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "order3_KL_list = np.array(order3_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "order4_KL_list = np.array(order4_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "for p, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "    plt.clf()\n",
    "    plt.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    plt.plot(h_vec, order2_KL_list[:,p], '-.o', linewidth=3)\n",
    "    plt.plot(h_vec, order3_KL_list[:,p], '--o', linewidth=3)\n",
    "    plt.plot(h_vec, order4_KL_list[:,p], ':o', linewidth=3)\n",
    "    plt.yscale('log')\n",
    "    plt.grid(which='minor')\n",
    "    plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    plt.legend(['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'])\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.eps'.format(results_path, dimension, setting, p), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.png'.format(results_path, dimension, setting, p), format='png', dpi=600)\n",
    "    plt.show()\n",
    "\n",
    "plt.clf()\n",
    "plt.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order2_KL_list, axis=1), '-.o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order3_KL_list, axis=1), '--o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order4_KL_list, axis=1), ':o', linewidth=3)\n",
    "plt.yscale('log')\n",
    "plt.grid(which='minor')\n",
    "plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.legend(['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'])\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "plt.clf()\n",
    "fig, ax = plt.subplots(4,4, figsize=(32, 15))\n",
    "for p, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "    cax = ax[np.unravel_index(p, (4,4))]\n",
    "    cax.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.plot(h_vec, order3_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order4_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.set_yscale('log')\n",
    "    cax.grid(which='minor')\n",
    "    cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    cax.set_title('Process: {}'.format([int(_) for _ in higher_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "\n",
    "cax = ax[np.unravel_index(15, (4,4))]\n",
    "cax.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order3_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order4_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.set_yscale('log')\n",
    "cax.grid(which='minor')\n",
    "cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax.set_title('Total KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax = ax[np.unravel_index(13, (4,4))]\n",
    "line_list = list()\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[2], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[3], linewidth=3))\n",
    "cax.legend(line_list, ['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'], ncol=4, loc='upper center', bbox_to_anchor=(0.5, -0.5))\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Representitive Example"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "representitive_higher_dimension_process_list = ['p1', 'p12', 'p123', 'p1234']\n",
    "# Set settings\n",
    "dimension = dimension_list[1]\n",
    "setting = setting_list[0]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "order1_KL_list = list()\n",
    "order2_KL_list = list()\n",
    "order3_KL_list = list()\n",
    "order4_KL_list = list()\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    for i, higher_dimension_process in enumerate(representitive_higher_dimension_process_list):\n",
    "        df = pd.read_csv('{}{}.csv'.format(higher_dimension_ground_truth_path, higher_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "        order3 = df['Order3'].values\n",
    "        order4 = df['Order4'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        order1_KL = KL_divergence(order1, gt_pdf * np.sum(order1) / dt)\n",
    "        order2_KL = KL_divergence(order2, gt_pdf * np.sum(order1) / dt)\n",
    "        order3_KL = KL_divergence(order3, gt_pdf * np.sum(order1) / dt)\n",
    "        order4_KL = KL_divergence(order4, gt_pdf * np.sum(order1) / dt)\n",
    "        \n",
    "        order1_KL_list.append(order1_KL)\n",
    "        order2_KL_list.append(order2_KL)\n",
    "        order3_KL_list.append(order3_KL)\n",
    "        order4_KL_list.append(order4_KL)\n",
    "\n",
    "order1_KL_list = np.array(order1_KL_list).reshape(len(h_list), len(representitive_higher_dimension_process_list))\n",
    "order2_KL_list = np.array(order2_KL_list).reshape(len(h_list), len(representitive_higher_dimension_process_list))\n",
    "order3_KL_list = np.array(order3_KL_list).reshape(len(h_list), len(representitive_higher_dimension_process_list))\n",
    "order4_KL_list = np.array(order4_KL_list).reshape(len(h_list), len(representitive_higher_dimension_process_list))\n",
    "for p, higher_dimension_process in enumerate(representitive_higher_dimension_process_list):\n",
    "    plt.clf()\n",
    "    plt.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    plt.plot(h_vec, order2_KL_list[:,p], '-.o', linewidth=3)\n",
    "    plt.plot(h_vec, order3_KL_list[:,p], '--o', linewidth=3)\n",
    "    plt.plot(h_vec, order4_KL_list[:,p], ':o', linewidth=3)\n",
    "    plt.yscale('log')\n",
    "    plt.grid(which='minor')\n",
    "    plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    plt.legend(['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'])\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.eps'.format(results_path, dimension, setting, p), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.png'.format(results_path, dimension, setting, p), format='png', dpi=600)\n",
    "    plt.show()\n",
    "\n",
    "plt.clf()\n",
    "plt.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order2_KL_list, axis=1), '-.o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order3_KL_list, axis=1), '--o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order4_KL_list, axis=1), ':o', linewidth=3)\n",
    "plt.yscale('log')\n",
    "plt.grid(which='minor')\n",
    "plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.legend(['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'])\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "plt.clf()\n",
    "fig, ax = plt.subplots(2,3, figsize=(32, 10))\n",
    "for p, higher_dimension_process in enumerate(representitive_higher_dimension_process_list):\n",
    "    cax = ax[np.unravel_index(p, (2,3))]\n",
    "    cax.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.plot(h_vec, order3_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order4_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.set_yscale('log')\n",
    "    cax.grid(which='minor')\n",
    "    cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    cax.set_title('Process: {}'.format([int(_) for _ in higher_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "\n",
    "cax = ax[np.unravel_index(4, (2,3))]\n",
    "cax.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order3_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order4_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.set_yscale('log')\n",
    "cax.grid(which='minor')\n",
    "cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax.set_title('Total KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax = ax[np.unravel_index(5, (2,3))]\n",
    "cax.axis('off')\n",
    "line_list = list()\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[2], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[3], linewidth=3))\n",
    "cax.legend(line_list, ['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'], ncol=4, loc='upper center') #, bbox_to_anchor=(0.5, -0.5))\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted_representitive.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted_representitive.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "representitive_higher_dimension_process_list = ['p1', 'p12', 'p123', 'p1234']\n",
    "# Set settings\n",
    "dimension = dimension_list[1]\n",
    "setting = setting_list[1]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "order1_KL_list = list()\n",
    "order2_KL_list = list()\n",
    "order3_KL_list = list()\n",
    "order4_KL_list = list()\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    for i, higher_dimension_process in enumerate(representitive_higher_dimension_process_list):\n",
    "        df = pd.read_csv('{}{}.csv'.format(higher_dimension_ground_truth_path, higher_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "        order3 = df['Order3'].values\n",
    "        order4 = df['Order4'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        order1_KL = KL_divergence(order1, gt_pdf * np.sum(order1) / dt)\n",
    "        order2_KL = KL_divergence(order2, gt_pdf * np.sum(order1) / dt)\n",
    "        order3_KL = KL_divergence(order3, gt_pdf * np.sum(order1) / dt)\n",
    "        order4_KL = KL_divergence(order4, gt_pdf * np.sum(order1) / dt)\n",
    "        \n",
    "        order1_KL_list.append(order1_KL)\n",
    "        order2_KL_list.append(order2_KL)\n",
    "        order3_KL_list.append(order3_KL)\n",
    "        order4_KL_list.append(order4_KL)\n",
    "\n",
    "order1_KL_list = np.array(order1_KL_list).reshape(len(h_list), len(representitive_higher_dimension_process_list))\n",
    "order2_KL_list = np.array(order2_KL_list).reshape(len(h_list), len(representitive_higher_dimension_process_list))\n",
    "order3_KL_list = np.array(order3_KL_list).reshape(len(h_list), len(representitive_higher_dimension_process_list))\n",
    "order4_KL_list = np.array(order4_KL_list).reshape(len(h_list), len(representitive_higher_dimension_process_list))\n",
    "for p, higher_dimension_process in enumerate(representitive_higher_dimension_process_list):\n",
    "    plt.clf()\n",
    "    plt.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    plt.plot(h_vec, order2_KL_list[:,p], '-.o', linewidth=3)\n",
    "    plt.plot(h_vec, order3_KL_list[:,p], '--o', linewidth=3)\n",
    "    plt.plot(h_vec, order4_KL_list[:,p], ':o', linewidth=3)\n",
    "    plt.yscale('log')\n",
    "    plt.grid(which='minor')\n",
    "    plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    plt.legend(['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'])\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.eps'.format(results_path, dimension, setting, p), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.png'.format(results_path, dimension, setting, p), format='png', dpi=600)\n",
    "    plt.show()\n",
    "\n",
    "plt.clf()\n",
    "plt.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order2_KL_list, axis=1), '-.o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order3_KL_list, axis=1), '--o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order4_KL_list, axis=1), ':o', linewidth=3)\n",
    "plt.yscale('log')\n",
    "plt.grid(which='minor')\n",
    "plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.legend(['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'])\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "plt.clf()\n",
    "fig, ax = plt.subplots(2,3, figsize=(32, 10))\n",
    "for p, higher_dimension_process in enumerate(representitive_higher_dimension_process_list):\n",
    "    cax = ax[np.unravel_index(p, (2,3))]\n",
    "    cax.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.plot(h_vec, order3_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order4_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.set_yscale('log')\n",
    "    cax.grid(which='minor')\n",
    "    cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    cax.set_title('Process: {}'.format([int(_) for _ in higher_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "\n",
    "cax = ax[np.unravel_index(4, (2,3))]\n",
    "cax.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order3_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order4_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.set_yscale('log')\n",
    "cax.grid(which='minor')\n",
    "cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax.set_title('Total KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax = ax[np.unravel_index(5, (2,3))]\n",
    "cax.axis('off')\n",
    "line_list = list()\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[2], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[3], linewidth=3))\n",
    "cax.legend(line_list, ['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'], ncol=4, loc='upper center') #, bbox_to_anchor=(0.5, -0.5))\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted_representitive.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted_representitive.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Calculate and plot KL divergence for sparse setting for intensity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[1]\n",
    "setting = setting_list[1]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "order1_KL_list = list()\n",
    "order2_KL_list = list()\n",
    "order3_KL_list = list()\n",
    "order4_KL_list = list()\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    for i, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "        df = pd.read_csv('{}{}.csv'.format(higher_dimension_ground_truth_path, higher_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "        order3 = df['Order3'].values\n",
    "        order4 = df['Order4'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        order1_KL = KL_divergence(order1, gt_pdf * np.sum(order1) / dt)\n",
    "        order2_KL = KL_divergence(order2, gt_pdf * np.sum(order1) / dt)\n",
    "        order3_KL = KL_divergence(order3, gt_pdf * np.sum(order1) / dt)\n",
    "        order4_KL = KL_divergence(order4, gt_pdf * np.sum(order1) / dt)\n",
    "        \n",
    "        order1_KL_list.append(order1_KL)\n",
    "        order2_KL_list.append(order2_KL)\n",
    "        order3_KL_list.append(order3_KL)\n",
    "        order4_KL_list.append(order4_KL)\n",
    "\n",
    "order1_KL_list = np.array(order1_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "order2_KL_list = np.array(order2_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "order3_KL_list = np.array(order3_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "order4_KL_list = np.array(order4_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "for p, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "    plt.clf()\n",
    "    plt.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    plt.plot(h_vec, order2_KL_list[:,p], '-.o', linewidth=3)\n",
    "    plt.plot(h_vec, order3_KL_list[:,p], '--o', linewidth=3)\n",
    "    plt.plot(h_vec, order4_KL_list[:,p], ':o', linewidth=3)\n",
    "    plt.yscale('log')\n",
    "    plt.grid(which='minor')\n",
    "    plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    plt.legend(['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'])\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.eps'.format(results_path, dimension, setting, p), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.png'.format(results_path, dimension, setting, p), format='png', dpi=600)\n",
    "    plt.show()\n",
    "\n",
    "plt.clf()\n",
    "plt.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order2_KL_list, axis=1), '-.o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order3_KL_list, axis=1), '--o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order4_KL_list, axis=1), ':o', linewidth=3)\n",
    "plt.yscale('log')\n",
    "plt.grid(which='minor')\n",
    "plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.legend(['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'])\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "plt.clf()\n",
    "fig, ax = plt.subplots(4,4, figsize=(32, 11))\n",
    "for p, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "    cax = ax[np.unravel_index(p, (4,4))]\n",
    "    cax.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.plot(h_vec, order3_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order4_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.set_yscale('log')\n",
    "    cax.grid(which='minor')\n",
    "    cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    cax.set_title('Process: {}'.format([int(_) for _ in higher_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "\n",
    "cax = ax[np.unravel_index(15, (4,4))]\n",
    "cax.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order3_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order4_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.set_yscale('log')\n",
    "cax.grid(which='minor')\n",
    "cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax.set_title('Total KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax = ax[np.unravel_index(13, (4,4))]\n",
    "line_list = list()\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[2], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[3], linewidth=3))\n",
    "cax.legend(line_list, ['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'], ncol=4, loc='upper center', bbox_to_anchor=(0.5, -0.5))\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence_intensity_subplotted.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence_intensity_subplotted.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Calculate and plot KL divergence for sparse setting for density"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set settings\n",
    "dimension = dimension_list[1]\n",
    "setting = setting_list[1]\n",
    "\n",
    "store_path = './store_data/{}_{}/'.format(dimension, setting)\n",
    "\n",
    "results_path = './results/{}_{}/'.format(dimension, setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "\n",
    "order1_KL_list = list()\n",
    "order2_KL_list = list()\n",
    "order3_KL_list = list()\n",
    "order4_KL_list = list()\n",
    "\n",
    "# Loop through bandwidth\n",
    "for h in h_list:\n",
    "    for i, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "        df = pd.read_csv('{}{}.csv'.format(higher_dimension_ground_truth_path, higher_dimension_process))\n",
    "        gt_bin_location = df['Bin Location'].values\n",
    "        gt_pdf = df['pdf'].values\n",
    "\n",
    "        intensity_path = '{}{}/{}/intensity.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(intensity_path)\n",
    "        time = df['Time'].values\n",
    "        order1 = df['Order1'].values\n",
    "        order2 = df['Order2'].values\n",
    "        order3 = df['Order3'].values\n",
    "        order4 = df['Order4'].values\n",
    "\n",
    "        event_time_path = '{}{}/{}/event_time.csv'.format(store_path, h, higher_dimension_process)\n",
    "        df = pd.read_csv(event_time_path)\n",
    "\n",
    "        event_time = df['Event Time'].values\n",
    "\n",
    "        order1_KL = KL_divergence(order1 / np.sum(order1) * dt, gt_pdf)\n",
    "        order2_KL = KL_divergence(order2 / np.sum(order1) * dt, gt_pdf)\n",
    "        order3_KL = KL_divergence(order3 / np.sum(order1) * dt, gt_pdf )\n",
    "        order4_KL = KL_divergence(order4 / np.sum(order1) * dt, gt_pdf)\n",
    "        \n",
    "        order1_KL_list.append(order1_KL)\n",
    "        order2_KL_list.append(order2_KL)\n",
    "        order3_KL_list.append(order3_KL)\n",
    "        order4_KL_list.append(order4_KL)\n",
    "\n",
    "order1_KL_list = np.array(order1_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "order2_KL_list = np.array(order2_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "order3_KL_list = np.array(order3_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "order4_KL_list = np.array(order4_KL_list).reshape(len(h_list), len(higher_dimension_process_list))\n",
    "for p, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "    plt.clf()\n",
    "    plt.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    plt.plot(h_vec, order2_KL_list[:,p], '-.o', linewidth=3)\n",
    "    plt.plot(h_vec, order3_KL_list[:,p], '--o', linewidth=3)\n",
    "    plt.plot(h_vec, order4_KL_list[:,p], ':o', linewidth=3)\n",
    "    plt.yscale('log')\n",
    "    plt.grid(which='minor')\n",
    "    plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    plt.legend(['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'])\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.eps'.format(results_path, dimension, setting, p), format='eps')\n",
    "    plt.savefig('{}{}_{}_{}_KL_divergence.png'.format(results_path, dimension, setting, p), format='png', dpi=600)\n",
    "    plt.show()\n",
    "\n",
    "plt.clf()\n",
    "plt.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order2_KL_list, axis=1), '-.o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order3_KL_list, axis=1), '--o', linewidth=3)\n",
    "plt.plot(h_vec, np.sum(order4_KL_list, axis=1), ':o', linewidth=3)\n",
    "plt.yscale('log')\n",
    "plt.grid(which='minor')\n",
    "plt.xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.legend(['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'])\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "plt.clf()\n",
    "fig, ax = plt.subplots(4,4, figsize=(32, 15))\n",
    "for p, higher_dimension_process in enumerate(higher_dimension_process_list):\n",
    "    cax = ax[np.unravel_index(p, (4,4))]\n",
    "    cax.plot(h_vec, order1_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order2_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.plot(h_vec, order3_KL_list[:,p], '-o', linewidth=3)\n",
    "    cax.plot(h_vec, order4_KL_list[:,p], '--o', linewidth=3)\n",
    "    cax.set_yscale('log')\n",
    "    cax.grid(which='minor')\n",
    "    cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "    cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "    cax.set_title('Process: {}'.format([int(_) for _ in higher_dimension_process[1:]]), fontsize=18, fontweight='bold')\n",
    "\n",
    "cax = ax[np.unravel_index(15, (4,4))]\n",
    "cax.plot(h_vec, np.sum(order1_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order2_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order3_KL_list, axis=1), '-o', linewidth=3)\n",
    "cax.plot(h_vec, np.sum(order4_KL_list, axis=1), '--o', linewidth=3)\n",
    "cax.set_yscale('log')\n",
    "cax.grid(which='minor')\n",
    "cax.set_xlabel('Kernel Bandwidth', fontsize=18, fontweight='bold')\n",
    "cax.set_ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax.set_title('Total KL Divergence', fontsize=18, fontweight='bold')\n",
    "cax = ax[np.unravel_index(13, (4,4))]\n",
    "line_list = list()\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[1], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[2], linewidth=3))\n",
    "line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[3], linewidth=3))\n",
    "cax.legend(line_list, ['Order: 1', 'Order: 2', 'Order: 3', 'Order: 4'], ncol=4, loc='upper center', bbox_to_anchor=(0.5, -0.5))\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted.eps'.format(results_path, dimension, setting), format='eps')\n",
    "plt.savefig('{}{}_{}_KL_divergence_density_subplotted.png'.format(results_path, dimension, setting), format='png', dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# One Dimensional Experiment with Thinning Algorithm"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Dense Setting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "setting = setting_list[0]\n",
    "\n",
    "results_path = './results/thinning_algorithm_{}/'.format(setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "thinning_store_path = './store_data/thinning_algorithm_{}/'.format(setting)\n",
    "df = pd.read_csv('{}ground_truth_intensity.csv'.format(thinning_store_path))\n",
    "gt_time = df['Time'].values\n",
    "gt_intensity = df['Intensity'].values\n",
    "intensity_df = pd.read_csv('{}thinning_algorithm_{}_intensity.csv'.format(thinning_store_path, setting))\n",
    "observation_df = pd.read_csv('{}thinning_algorithm_{}_observations.csv'.format(thinning_store_path, setting))\n",
    "thinning_h_list = list(intensity_df.columns)\n",
    "for h in thinning_h_list:\n",
    "    plt.clf()\n",
    "    plt.plot(gt_time, intensity_df[h], linewidth=3)\n",
    "    plt.plot(gt_time, gt_intensity, 'k', linewidth=3)\n",
    "    plt.plot(observation_df.values, np.zeros(len(observation_df.values)), '.k')\n",
    "    plt.xlabel('Time', fontsize=18, fontweight='bold')\n",
    "    plt.ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "    plt.grid()\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}thinning_algorithm_{}_{}.eps'.format(results_path, setting, h.replace('=', '')), format='eps')\n",
    "    plt.savefig('{}thinning_algorithm_{}_{}.png'.format(results_path, setting, h.replace('=', '')), format='png', dpi=600)\n",
    "    plt.show()\n",
    "    \n",
    "fig, ax = plt.subplots(2,4, figsize=(32, 7))\n",
    "for i, h in enumerate(thinning_h_list):\n",
    "    cax = ax[np.unravel_index(i, (2,4))]\n",
    "    cax.plot(gt_time, intensity_df[h], linewidth=3)\n",
    "    cax.plot(gt_time, gt_intensity, 'k', linewidth=3)\n",
    "    cax.plot(observation_df.values, np.zeros(len(observation_df.values)), '.k')\n",
    "    line_list = list()\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color='k', linewidth=3))\n",
    "    cax.set_xlabel('Time', fontsize=18, fontweight='bold')\n",
    "    cax.set_ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "    cax.set_title(h)\n",
    "    cax.grid()\n",
    "cax = cax = ax[np.unravel_index(5, (2,4))]\n",
    "cax.legend(line_list, ['APP', 'Ground Truth'], ncol=3, loc='upper center', bbox_to_anchor=(0.5, -0.3))\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}thinning_algorithm_{}_subplotted.eps'.format(results_path, setting), format='eps')\n",
    "plt.savefig('{}thinning_algorithm_{}_subplotted.png'.format(results_path, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "KL = [KL_divergence(intensity_df[h], gt_intensity) for h in thinning_h_list]\n",
    "plt.plot([0.3, 1, 2, 4, 5, 8, 10, 12], KL, '-o', linewidth=3)\n",
    "plt.grid()\n",
    "plt.xlabel('Kernel Bandwith', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}thinning_algorithm_{}_KL_intensity.eps'.format(results_path, setting), format='eps')\n",
    "plt.savefig('{}thinning_algorithm_{}_KL_intensity.png'.format(results_path, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "KL = [KL_divergence(intensity_df[h] / np.sum(intensity_df[h]), gt_intensity/ np.sum(intensity_df[h])) for h in thinning_h_list]\n",
    "plt.plot([0.3, 1, 2, 4, 5, 8, 10, 12], KL, '-o', linewidth=3)\n",
    "plt.grid()\n",
    "plt.xlabel('Kernel Bandwith', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}thinning_algorithm_{}_KL_density.eps'.format(results_path, setting), format='eps')\n",
    "plt.savefig('{}thinning_algorithm_{}_KL_density.png'.format(results_path, setting), format='png', dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Sparse Setting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set settings\n",
    "setting = setting_list[1]\n",
    "\n",
    "results_path = './results/thinning_algorithm_{}/'.format(setting)\n",
    "if not os.path.exists(results_path):\n",
    "    os.mkdir(results_path)\n",
    "thinning_store_path = './store_data/thinning_algorithm_{}/'.format(setting)\n",
    "if not os.path.exists(thinning_store_path):\n",
    "    os.mkdir(thinning_store_path)\n",
    "df = pd.read_csv('{}ground_truth_intensity.csv'.format(thinning_store_path))\n",
    "gt_time = df['Time'].values\n",
    "gt_intensity = df['Intensity'].values\n",
    "intensity_df = pd.read_csv('{}thinning_algorithm_{}_intensity.csv'.format(thinning_store_path, setting))\n",
    "observation_df = pd.read_csv('{}thinning_algorithm_{}_observations.csv'.format(thinning_store_path, setting))\n",
    "thinning_h_list = list(intensity_df.columns)\n",
    "for h in thinning_h_list:\n",
    "    plt.clf()\n",
    "    plt.plot(gt_time, intensity_df[h], linewidth=3)\n",
    "    plt.plot(gt_time, gt_intensity, 'k', linewidth=3)\n",
    "    plt.plot(observation_df.values, np.zeros(len(observation_df.values)), '.k')\n",
    "    plt.xlabel('Time', fontsize=18, fontweight='bold')\n",
    "    plt.ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "    plt.grid()\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('{}thinning_algorithm_{}_{}.eps'.format(results_path, setting, h.replace('=', '')), format='eps')\n",
    "    plt.savefig('{}thinning_algorithm_{}_{}.png'.format(results_path, setting, h.replace('=', '')), format='png', dpi=600)\n",
    "    plt.show()\n",
    "    \n",
    "fig, ax = plt.subplots(2,4, figsize=(32, 7))\n",
    "for i, h in enumerate(thinning_h_list):\n",
    "    cax = ax[np.unravel_index(i, (2,4))]\n",
    "    cax.plot(gt_time, intensity_df[h], linewidth=3)\n",
    "    cax.plot(gt_time, gt_intensity, 'k', linewidth=3)\n",
    "    cax.plot(observation_df.values, np.zeros(len(observation_df.values)), '.k')\n",
    "    line_list = list()\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color=color_list[0], linewidth=3))\n",
    "    line_list.append(matplotlib.lines.Line2D([0], [0], color='k', linewidth=3))\n",
    "    cax.set_xlabel('Time', fontsize=18, fontweight='bold')\n",
    "    cax.set_ylabel('Intensity', fontsize=18, fontweight='bold')\n",
    "    cax.set_title(h)\n",
    "    cax.grid()\n",
    "cax = cax = ax[np.unravel_index(5, (2,4))]\n",
    "cax.legend(line_list, ['APP', 'Ground Truth'], ncol=3, loc='upper center', bbox_to_anchor=(0.5, -0.3))\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}thinning_algorithm_{}_subplotted.eps'.format(results_path, setting), format='eps')\n",
    "plt.savefig('{}thinning_algorithm_{}_subplotted.png'.format(results_path, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "KL = [KL_divergence(intensity_df[h], gt_intensity) for h in thinning_h_list]\n",
    "plt.plot([0.3, 1, 2, 4, 5, 8, 10, 12], KL, '-o', linewidth=3)\n",
    "plt.grid()\n",
    "plt.xlabel('Kernel Bandwith', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}thinning_algorithm_{}_KL_intensity.eps'.format(results_path, setting), format='eps')\n",
    "plt.savefig('{}thinning_algorithm_{}_KL_intensity.png'.format(results_path, setting), format='png', dpi=600)\n",
    "plt.show()\n",
    "\n",
    "KL = [KL_divergence(intensity_df[h] / np.sum(intensity_df[h]), gt_intensity/ np.sum(intensity_df[h])) for h in thinning_h_list]\n",
    "plt.plot([0.3, 1, 2, 4, 5, 8, 10, 12], KL, '-o', linewidth=3)\n",
    "plt.grid()\n",
    "plt.xlabel('Kernel Bandwith', fontsize=18, fontweight='bold')\n",
    "plt.ylabel('KL Divergence', fontsize=18, fontweight='bold')\n",
    "plt.tight_layout()\n",
    "plt.savefig('{}thinning_algorithm_{}_KL_density.eps'.format(results_path, setting), format='eps')\n",
    "plt.savefig('{}thinning_algorithm_{}_KL_density.png'.format(results_path, setting), format='png', dpi=600)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
