{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "37ec58fb-6974-47c1-912c-00090778ec3f",
   "metadata": {},
   "source": [
    "# Event datasets in Ide, et al.,\"Cardinality-Regularized Hawkes-Granger Model\", NeurIPS 21.\n",
    "\n",
    "This notebook presents Python code for generating `Sparse5` and `Dense10` datasets using *tick*, a well-known Hawkes process simulator. These datasets were first introduced in:\n",
    "```\n",
    "@article{Ide21NeurIPS,\n",
    "title={Cardinality-Regularized {Hawkes-Granger} Model},\n",
    "author={Tsuyoshi Id\\'{e} and Georgios Kollias and Dzung T. Phan and Naoki Abe},\n",
    "journal={Advances in Neural Information Processing Systems},\n",
    "volume = {35},\n",
    "number = {},\n",
    "pages={TBD},\n",
    "year={2021}\n",
    "}\n",
    "```\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cee4391f-5b2f-4dc3-ad31-34906d23abf9",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Generating `Sparse5` dataset\n",
    "\n",
    "The **Sparse5** benchmark dataset is designed to have a simplest but nontrivial kind of causal structure, which is supposed to be easily reproduced by any Granger-causal learning algorithms. Using a standard point process simulator *tick* (https://x-datainitiative.github.io/tick/), we generated Sparse5 by giving 0.001 to $\\mathtt{baseline}$ for all the types and\n",
    "\\begin{align}\n",
    "    \\mathtt{decays}  = \\begin{pmatrix}\n",
    "    0.5\\\\\n",
    "    0.5\\\\\n",
    "    0.1\\\\\n",
    "    0.1\\\\\n",
    "    0.1\n",
    "    \\end{pmatrix}\n",
    "    (1,1,1,1,1)\n",
    "    ,\\quad\n",
    "\\mathtt{adjacency} = \\begin{pmatrix}\n",
    "0.   &0.   &0.   &0.   &0.  \\\\\n",
    "1.5  &0.   &0.   &0.   &0.  \\\\\n",
    "0.   &0.   &0.   &0.   &0.  \\\\\n",
    "0.   &0.   &1.5  &0.   &0.  \\\\\n",
    "0.   &0.   &0.   &0.   &0.75\n",
    "\\end{pmatrix},\n",
    "\\end{align}\n",
    "where  we employed the exponential distribution as the decay function. The numbers above were manually adjusted so *tick* did not produce a \"spectral radius error\" and all the event types have roughly the same number of event instances. In *tick*, we provided $\\mathtt{seed}=1,2,3,4,5$, which resulted in five realizations of the 5-dimensional point process as shown below. Due to the stochastic nature, the total number of event instances cannot be controlled. We manually adjusted the duration of simulation so the total number of events is roughly $N \\approx 1\\, 000$. In particular, we had $N=(966, 991, 978, 960, 1030)$ for $\\mathtt{seed}=(1,2,3,4,5)$, respectively."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "0b22d0b4-a3d3-4e58-9379-58bf94ab4c2b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "A=\n",
      " [[0.   0.   0.   0.   0.  ]\n",
      " [1.5  0.   0.   0.   0.  ]\n",
      " [0.   0.   0.   0.   0.  ]\n",
      " [0.   0.   1.5  0.   0.  ]\n",
      " [0.   0.   0.   0.   0.75]]\n",
      "beta_mat=\n",
      " [[0.5 0.5 0.5 0.5 0.5]\n",
      " [0.5 0.5 0.5 0.5 0.5]\n",
      " [0.1 0.1 0.1 0.1 0.1]\n",
      " [0.1 0.1 0.1 0.1 0.1]\n",
      " [0.1 0.1 0.1 0.1 0.1]]\n",
      "mu_vec=\n",
      " [0.001 0.001 0.001 0.001 0.001]\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "D  = 5  # dimension of the Hawkes process\n",
    "A = np.zeros([D,D]) # Adjacency matrix\n",
    "A[2-1,1-1]=2\n",
    "A[4-1,3-1]=2\n",
    "A[5-1,5-1]=1\n",
    "A = A*.75\n",
    "\n",
    "b0 = 0.5\n",
    "b1 = 0.1\n",
    "beta_vec = np.array([[b0, b0, b1, b1,b1]]).T \n",
    "beta_mat = beta_vec.dot(np.ones([D,1]).T) # decay matrix\n",
    "\n",
    "mu = 0.001\n",
    "mu_vec = np.array([mu,mu,mu,mu,mu]) # baseline intensities\n",
    "\n",
    "print('A=\\n',A)\n",
    "print('beta_mat=\\n',beta_mat)\n",
    "print('mu_vec=\\n',mu_vec)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "017ca003-03e5-4259-8338-ded3811a639c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def SerializeMultEvents(EventsList):\n",
    "    import numpy as np\n",
    "    # Obtaining time stamps\n",
    "    #Xlist = hawkes.timestamps\n",
    "    ts0 = np.array([],dtype=np.float32)\n",
    "    et0 = np.array([],dtype=np.int16)\n",
    "    for ii in range(len(EventsList)):\n",
    "        tt = EventsList[ii] # This is timestamps of the i-th event type\n",
    "        ee = np.repeat(ii+1,len(tt))\n",
    "        ts0 = np.concatenate((ts0,tt))\n",
    "        et0 = np.concatenate((et0,ee))\n",
    "    idx = ts0.argsort()\n",
    "    ts = ts0[idx]\n",
    "    et = et0[idx]\n",
    "    return ts, et"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e83658fd-8c0e-4320-a84f-282d8a48d286",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "seed=1, N=966\n",
      "seed=2, N=991\n",
      "seed=3, N=978\n",
      "seed=4, N=960\n",
      "seed=5, N=1030\n",
      "done.\n",
      "Wall time: 4.16 s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "from tick.hawkes import SimuHawkesExpKernels\n",
    "from tick.plot import plot_point_process\n",
    "import bz2; import pickle\n",
    "\n",
    "start_time = 0 \n",
    "run_time = 90000\n",
    "dt = 1\n",
    "Sparse5 =[]\n",
    "Sparse5WithTick =[]\n",
    "\n",
    "saveData = False\n",
    "dataFn = 'Sparse5.pickle.bz2'\n",
    "\n",
    "for seed in [1,2,3,4,5]:\n",
    "    hawkes = SimuHawkesExpKernels(adjacency=A, decays=beta_mat,\n",
    "                                  baseline=mu_vec, verbose=False, seed=seed)\n",
    "    hawkes.end_time = run_time\n",
    "    hawkes.track_intensity(dt)\n",
    "    hawkes.simulate()\n",
    "    Xlist = hawkes.timestamps\n",
    "    \n",
    "    ts,et = SerializeMultEvents(EventsList = Xlist) \n",
    "    print('seed={}, N={}'.format(seed, len(ts) ))\n",
    "    \n",
    "    obj = {'Xlist':Xlist, 'ts':ts, 'et':et}\n",
    "    Sparse5.append(obj)\n",
    "    \n",
    "\n",
    "# Saving Sparse5 data.....\n",
    "if saveData:\n",
    "    with bz2.open(dataFn,'wb') as f:\n",
    "        pickle.dump(Sparse5,f)\n",
    "\n",
    "print('done.')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "d1549f24-dc9c-49bd-bc53-25d69d6b6433",
   "metadata": {},
   "outputs": [],
   "source": [
    "def showPoints2(EventList,alpha=0.2,marker='|',linewidths=1,markerSize=100,figsize=(10,10)):\n",
    "    import matplotlib.pyplot as plt\n",
    "    import numpy as np\n",
    "    #import seaborn as sns; sns.set()\n",
    "    fig,axes = plt.subplots(len(EventList),1,figsize=figsize,sharex=True,tight_layout=True)\n",
    "    if len(EventList) == 1:\n",
    "        axes = [axes]\n",
    "    for ii in range(len(EventList)):\n",
    "        ts_ii = EventList[ii]\n",
    "        yy = np.repeat(0,len(ts_ii))\n",
    "        axes[ii].scatter(ts_ii,yy,marker=marker,linewidths=linewidths,\n",
    "                         #edgecolors='face',\n",
    "                      alpha=alpha,color='black',s=markerSize)\n",
    "        axes[ii].axes.xaxis.set_visible(False)\n",
    "        axes[ii].axes.yaxis.set_visible(False)\n",
    "        axes[ii].axis(\"off\")\n",
    "    return fig,axes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e6c60235-1182-476b-bbfc-723bfe35680c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------seed=1-------------------\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x108 with 5 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------seed=2-------------------\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x108 with 5 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------seed=3-------------------\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA1gAAABkCAYAAACbz5HjAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8rg+JYAAAACXBIWXMAAAsTAAALEwEAmpwYAAAHs0lEQVR4nO3dQa7kNBAAUBtxEI7CzZhhxZIjcJQ/RxluwJIFCgvUUhQSp+yUO90z723m/8QuVxzH6dJHdF2WpQAAAHDdD3cnAAAA8K1QYAEAACRRYAEAACRRYAEAACRRYAEAACR5ywKr1vqp9XtGzNH42bnVWj/VWj+u5nUQ91PG3I3kcjX30b5Z1jns3fPHsaw53saJxDxqc8f8tXI5y2fv/Iw9oFdGDrPWx2iM9b97515F1v3P2rdmzM9obq37+Mw8RtvOehf3yL7myPlnvxOPxoysn+07biSP1nvzGUavPWusyLkrcffaHVzzR9Y40VxW+fxv7Fd711xR3/F/015rXZZlqUe/Z8SMnpudW611KaWUvRhXYj/iHsUeidcT52ruGTlfsc5h756X8t+8tu5f73jrOJE5OGpzx/y1cimlPT97fWfsAb0ycpi1PkZjPNbs2XzfLev+Z+1bM+ZnNLfWfXxmHqNtZ72Le2Rfc+R8KePPb+beE1k/23dcz3vpKOesvTCqtfayn+esNT3a9+renjkfR2tnxlh3e8u/YAEAALwiBRYAAEASBRYAAEASBRYAAEASBRYAAEASBRYAAEASBRYAAEASBRYAAECSt/yiYQAAgFfkL1gAAABJFFgAAABJFFgAAABJFFgAAABJFFgAAABJFFgAAABJFFgAAABJFFgAAABJFFgAAABJ3rbAqrUutdbl8fOVOGcxesbZtunJ7ajvUYzHHKznoifPbb/e/Fo5nsWNjtsaM9J+dJyefnvzv56XrHXaG6u1bqLj9We6P0ZrnZyNFbmOs/Xf+3z0jj8Se+QZPIs3cm7bZu9eHe0xR22v5tvbfnSt9+xpo7mdne/d92fH2cbo2Rsz3yk97aNxMvaGoz2sp32kXdToOtl7n0TfMUftzq6t1TZzL4yIfK6KxIg8+2djRXONftY7e05GY/Tk3dqPWp8Hovm9g7ctsAAAAF6NAgsAACCJAgsAACCJAgsAACCJAgsAACCJAgsAACCJAgsAACCJAgsAACBJXZa3/Q4vAACAl+IvWAAAAEkUWAAAAEkUWAAAAEkUWAAAAEkUWAAAAEkUWAAAAEkUWAAAAEkUWAAAAEkUWAAAAEneusCqtX7a+znSfuR8q12t9SPS5yznbbuR69qOsXc+eq1XrK/h6Lof89a63qu59szl1TGix2frfTai8WY+Q3vHR3OfFSej/7Oev0guR22urOfofpORT6tfdM99FUfvkJnz1Brjrv2yZ9yee3zyjvmIjhnJJ3p8r03PHvrs9070Ou7a4yJG1tdZ32c8P1fyjvYf2Suf/XnyndRlWe7OYVitdVmWpW5/jrQfOd9qF419lvO23ch1bccopZTt+e2xGdbXsB5vbw5a1xu9L5E8Zl3zUeyZY0bzycghOodXnqG946O5z4qT0f9Zz18kl6M2V9bz3tyX8v/rzcin1e8xZvazMEvGnGeu87v2y1Liz0b0vXrU9iyfXs+8h625mnXvotfx+PkVn7WeuYm+R57x/FzJO9p/ZK989ufJmWNke+u/YAEAALwSBRYAAEASBRYAAEASBRYAAEASBRYAAEASBRYAAEASBRYAAEASBRYAAECSt/6iYQAAgFfiL1gAAABJFFgAAABJFFgAAABJFFgAAABJFFgAAABJFFgAAABJFFgAAABJFFgAAABJFFgAAABJvokCq9a61FqX1vn1v3vnIrHWx9ftHj+3xtmL3Rp7G/vo2vbyauUQjXkWI9IvMj97bbPyGok9IrpmInFGYxytzfW5K9efFaOV5178yDPbynekb2T83jU42v8o3tW1fLQPZTwze8999vVG9sTe/bgnfrarubSek+j77EqOvUbuybpf73po9d2Om7Feo8ePxu/t0zteq+3ZWurZ+3o+X/XIeJdF2z57L7gq8vw8fu593165p5nvrHfxTRRYAAAAr0CBBQAAkESBBQAAkESBBQAAkESBBQAAkESBBQAAkESBBQAAkESBBQAAkKQuy9t9dxcAAMBL8hcsAACAJAosAACAJAosAACAJAosAACAJAosAACAJAosAACAJAosAACAJAosAACAJAosAACAJN9lgVVrXWqty5X+mfnMiN0TZ6/t9lgk3tG8ro+14oxee8aczbind15PJNbe/To6NjLu7PuyHqN3rMhaPTp+Nmbr+My942z8WfHP5uHKfRrt80wz7+srx736jvletPaZZ+0JrZx6crjyTot+hhhpf5ZbxjyPfo7J/Cw1atZ6e8a6Gen3Kr7LAgsAAGAGBRYAAEASBRYAAEASBRYAAEASBRYAAEASBRYAAEASBRYAAEASBRYAAECSH+9O4CZ/lVJ+vzuJA59viLPXdnvsayDOUkr59STWl848Iloxo/5KiJEl43oeWnP6uZTyc6B91poc0ZqLL6WUj0C7o74/dYy3Pv558280xtdSyh9niSXIXD97/t78fvRlkI/5+buU8tvmWI/I3nO3WXM+69nLyPefjrZ37iF327v2L6tzvzwxl4d1Tksp5c+Bfj3We0AkfnSczwc/z7Deh1pfgLs9t92/7ngWZo0ZjTu638x+l01Vl+WtvygZAADgZfhPBAEAAJIosAAAAJIosAAAAJIosAAAAJIosAAAAJL8C4ttpunC04A6AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 864x108 with 5 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------seed=4-------------------\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x108 with 5 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------seed=5-------------------\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x108 with 5 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "for seed in [1,2,3,4,5]:\n",
    "    print('--------------seed={}-------------------'.format(seed))\n",
    "    Xlist = Sparse5[seed-1].get('Xlist')\n",
    "    showPoints2(EventList=Xlist,alpha=1,marker='|',linewidths=1,markerSize=100,figsize=(12,1.5))\n",
    "    plt.pause(0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "03baa124-b9f2-4ff8-8623-c5a45168f035",
   "metadata": {},
   "source": [
    "# Generating `Dense10` dataset\n",
    "\n",
    "We generated the simulated data again with the standard simulator *tick* version 0.6 (https://x-datainitiative.github.io/tick/) for reproducibility. The parameters specified are `adjacency`, `decays`, and `baseline,` which are associated with $\\mathsf{A}$, $\\mathbf{\\beta}$, and $\\mathbf{\\mu}$, respectively. We gave $\\beta_d=0.1, \\mu_d=1$ for all $d$'s. For the adjacency matrix, which is called the impact matrix in our work, we followed the following steps:\n",
    "- Starting with the $D=10$-dimensional identify matrix, pick $D/2$ entries from the first row to set 1. \n",
    "- From the remaining $D-1$ event indexes for the rows, randomly pick $D/2$ indexes (the index set $\\mathcal{S}_2$)\n",
    "- From the column indexes $\\{2, \\ldots, D\\}$, randomly pick $D/2$ indexes (the index set $\\mathcal{S}_3$).\n",
    "- Set 1 to the element corresponding to the direct product between $\\mathcal{S}_2$ and $\\mathcal{S}_3$ using Python's `numpy.ix_(S2,S3)`. \n",
    "\n",
    "In this way, we can create a moderately filled adjacency matrix with at least one dense node. After creating the adjacency matrix, we added gamma-distributed noise with:\n",
    "```python\n",
    "    adjacency = adjacency + np.random.gamma(1,1,size=[D,D])\n",
    "    adjacency = adjacency/(D*D)\n",
    "```\n",
    "We have attached the generated data set. We start with loading pre-simulated data:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "ab62da31-aa0b-4afd-be57-b47f6513a088",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "A=\n",
      " [[0.01260816 0.01764458 0.03452967 0.01611023 0.01563345 0.02798979\n",
      "  0.01506833 0.01258677 0.01623321 0.00097393]\n",
      " [0.00730128 0.03002631 0.01766951 0.01769626 0.00318898 0.00061071\n",
      "  0.01110264 0.00899103 0.01113688 0.00530668]\n",
      " [0.01220087 0.00341969 0.01153291 0.01529308 0.00531945 0.00034769\n",
      "  0.00978246 0.01080681 0.00354528 0.00590833]\n",
      " [0.01251189 0.01076195 0.01633443 0.01101116 0.03336868 0.00127255\n",
      "  0.00744018 0.00087327 0.03487245 0.0341294 ]\n",
      " [0.00355148 0.01878006 0.01834508 0.00951758 0.04135814 0.00302429\n",
      "  0.00262684 0.00762387 0.03994496 0.01679362]\n",
      " [0.00777835 0.01450236 0.00046406 0.00150783 0.01572159 0.01030254\n",
      "  0.02146654 0.00778244 0.00594171 0.02226883]\n",
      " [0.00474147 0.0177311  0.02056412 0.00448259 0.01846318 0.01015659\n",
      "  0.01135035 0.01171843 0.02043412 0.01436861]\n",
      " [0.02440679 0.01440883 0.0239751  0.02131508 0.01011738 0.00689372\n",
      "  0.00076656 0.02546235 0.01066212 0.01438986]\n",
      " [0.03844505 0.01477719 0.02439358 0.01476635 0.0135862  0.01481657\n",
      "  0.00165972 0.00864253 0.01009049 0.02234578]\n",
      " [0.01636088 0.01446438 0.00629971 0.00313343 0.01781963 0.00801456\n",
      "  0.00072658 0.00639559 0.01357765 0.01213139]]\n",
      "beta_mat=\n",
      " [[0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1]\n",
      " [0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1]\n",
      " [0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1]\n",
      " [0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1]\n",
      " [0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1]\n",
      " [0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1]\n",
      " [0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1]\n",
      " [0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1]\n",
      " [0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1]\n",
      " [0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1]]\n",
      "mu_vec=\n",
      " [1. 1. 1. 1. 1. 1. 1. 1. 1. 1.]\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from tick.hawkes import SimuHawkesExpKernels\n",
    "\n",
    "n_nodes = 10  # dimension of the Hawkes process\n",
    "np.random.seed(1)\n",
    "\n",
    "# Defining adjacency matrix\n",
    "D = n_nodes\n",
    "adjacency = np.eye(D) # start from the identity matrix\n",
    "adjacency[0,1:int(D/2)] = 1 # 0th type is caused by 1:5\n",
    "\n",
    "idx = np.random.choice(range(1,D),int(D/2),False) # 0th type cause these\n",
    "adjacency[idx,0] = 1\n",
    "\n",
    "idx2 = np.random.choice(range(1,D),int(D/2),False)\n",
    "idx3 = np.random.choice(range(1,D),int(D/2),False)\n",
    "adjacency[np.ix_(idx2,idx3)] = 1\n",
    "\n",
    "adjacency = adjacency + np.random.gamma(1,1,size=[D,D])\n",
    "adjacency = adjacency/(D*D)\n",
    "decays = 0.1 * np.ones((D, D))\n",
    "baseline = 1 * np.ones(D)\n",
    "\n",
    "print('A=\\n',adjacency)\n",
    "print('beta_mat=\\n',decays)\n",
    "print('mu_vec=\\n',baseline)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "e0318e77-ea81-44b1-8647-f1dd0fe831ea",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x216 with 10 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "hawkes = SimuHawkesExpKernels(adjacency=adjacency, decays=decays,\n",
    "                              baseline=baseline, verbose=False, seed=1)\n",
    "run_time = 100\n",
    "hawkes.end_time = run_time\n",
    "dt = 0.1\n",
    "hawkes.track_intensity(dt)\n",
    "hawkes.simulate()\n",
    "Xlist = hawkes.timestamps\n",
    "_,_ = showPoints2(Xlist,alpha=1,marker='|',linewidths=1,markerSize=100,figsize=(12,3))"
   ]
  }
 ],
 "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.7.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
