{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "d5facc25",
   "metadata": {},
   "source": [
    "Dependencies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "75aac03a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import scipy\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "import sys\n",
    "from counterfactual_tpp import sample_counterfactual, superposition, combine, check_monotonicity, distance\n",
    "from sampling_utils import homogenous_poisson, thinning, thinning_T\n",
    "from multiprocessing import cpu_count, Pool\n",
    "from tqdm import tqdm\n",
    "import utils"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f7730e50",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "48"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cpu_count()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c442648a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "means [0.55 1.8  2.6  3.4  4.2 ]\n",
      "sds [0.27440675 0.35759468 0.30138169 0.27244159 0.2118274 ]\n",
      "amps [22.91788226 18.75174423 27.83546002 29.27325521 17.66883038]\n"
     ]
    }
   ],
   "source": [
    "def normal(x, mean, sd, amp):  \n",
    "    return amp * (1/(sd * (np.sqrt(2*np.pi)))) * np.exp(-0.5*((x-mean)/sd)**2)\n",
    "\n",
    "# Setting the parameters of the original intensity\n",
    "T = 5\n",
    "number_of_gaussians = 5\n",
    "np.random.seed(0)\n",
    "means = np.arange(1, T , step = (T - 1) / number_of_gaussians)\n",
    "means[0] = 0.55\n",
    "sds = np.random.uniform(low=0, high=0.5, size=number_of_gaussians)\n",
    "amps = 10 * np.random.uniform(low=1.0, high=3.0, size=number_of_gaussians)\n",
    "print('means', means)\n",
    "print('sds', sds)\n",
    "print('amps', amps)\n",
    "#**********************\n",
    "def original(x):\n",
    "    res = 0\n",
    "    for i in range(number_of_gaussians):\n",
    "        res += normal(x, means[i], sds[i], amps[i])\n",
    "    return res"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "0c92dbb3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='time', ylabel='intensity'>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plotting the original intensity\n",
    "x = np.linspace(0, T, 10000)\n",
    "sns.lineplot(data = pd.DataFrame({'time':x, 'intensity':original(x)}), x=\"time\", y=\"intensity\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "cba60480",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "index 4\n",
      "previous amp 17.668830376515555\n",
      "new amp [9.84107533]\n"
     ]
    }
   ],
   "source": [
    "# intervention intensity\n",
    "#******************* To replicate figure 5:\n",
    "# run this cell 1 time for lambda'>lambda\n",
    "# run this cell 12 times for lambda'<lambda \n",
    "modified_index = np.random.choice(a = np.arange(number_of_gaussians), size = 1)[0]\n",
    "print('index', modified_index)\n",
    "new_amp = amps[modified_index] + np.random.normal(loc=0.0, scale=10, size=1)\n",
    "print('previous amp', amps[modified_index])\n",
    "print('new amp', new_amp)\n",
    "new_amps = np.zeros(amps.shape)\n",
    "for i in range(len(new_amps)):\n",
    "    if i == modified_index:\n",
    "        new_amps[i] = new_amp[0]\n",
    "    else:\n",
    "        new_amps[i] = amps[i]\n",
    "                    \n",
    "def intervention(x):\n",
    "    res = 0\n",
    "    for i in range(number_of_gaussians):\n",
    "        res += normal(x, means[i], sds[i], new_amps[i])\n",
    "    return res"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c92b50a4",
   "metadata": {},
   "source": [
    "Run this if lambda'< lambda"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "4567e10c",
   "metadata": {},
   "outputs": [],
   "source": [
    "window_radious = (means[modified_index] - means[modified_index - 1]) / 2\n",
    "window_center = means[modified_index]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ce0b022d",
   "metadata": {},
   "source": [
    "Run this if lambda'>lambda"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "21e7989c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# window_radious = (means[modified_index + 1] - means[modified_index]) / 2\n",
    "# window_center = means[modified_index]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "81ff4978",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "beginning of the interval:  3.8000000000000003\n",
      "ending of the interval:  4.6\n",
      "window center 4.2\n"
     ]
    }
   ],
   "source": [
    "# specifying interventional intervall.\n",
    "begin = window_center - window_radious\n",
    "end = window_center + window_radious\n",
    "if begin < 0:\n",
    "    t = 0 - begin\n",
    "    begin = 0\n",
    "    end = end - t\n",
    "print('beginning of the interval: ', begin)\n",
    "print('ending of the interval: ', end)\n",
    "print('window center', window_center)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "9cfd3b09",
   "metadata": {},
   "outputs": [],
   "source": [
    "path = 'figs/new_figs/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "5d663981",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f3754629040>"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Visualizing both intensities\n",
    "sns.lineplot(data = pd.DataFrame({'time':x, 'intensity':original(x)}), x=\"time\", y=\"intensity\", label = 'Original')\n",
    "sns.lineplot(data = pd.DataFrame({'time':x, 'intensity':intervention(x)}), x=\"time\", y=\"intensity\", label = 'Intervention')\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "131ff908",
   "metadata": {},
   "outputs": [],
   "source": [
    "lambda_max = 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "504068b7",
   "metadata": {},
   "outputs": [],
   "source": [
    "def counterfactual(_):\n",
    "    sample, indicators = thinning_T(0, intensity=original, lambda_max=lambda_max, T=T)\n",
    "    lambdas = original(np.asarray(sample))\n",
    "    sample = np.asarray(sample)\n",
    "    counters = []\n",
    "    for counter in range(100):\n",
    "        counterfactuals, counterfactual_indicators = sample_counterfactual(sample, lambdas, lambda_max, indicators, intervention)\n",
    "        counters.append(counterfactuals)\n",
    "    return sample[indicators], counters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "8d5f89cd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def counterfactual1(_):\n",
    "    sample, indicators = thinning_T(0, intensity=original, lambda_max=lambda_max, T=T)\n",
    "    lambdas = original(np.asarray(sample))\n",
    "    sample = np.asarray(sample)\n",
    "    counters = []\n",
    "    for counter in range(100):\n",
    "        counterfactuals, counterfactual_indicators = sample_counterfactual(sample, lambdas, lambda_max, indicators, intervention)\n",
    "        if check_monotonicity(sample, counterfactuals, original, intervention, sample[indicators]) != 'MONOTONIC':\n",
    "            print('Not monotonic')\n",
    "        counters.append(counterfactuals)\n",
    "    return sample[indicators], counters, sample, indicators"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "cc5d6bea",
   "metadata": {},
   "outputs": [],
   "source": [
    "def counterfactual2(_):\n",
    "    sample = samples_load[_]\n",
    "    indicators = indicators_load[_]\n",
    "    h_observed = sample[indicators]\n",
    "    lambda_observed = [original(i) for i in h_observed]\n",
    "    lambda_bar = lambda x: lambda_max - original(x)\n",
    "    h_rejected, _ = thinning_T(0, intensity=lambda_bar, lambda_max=lambda_max,T=T)\n",
    "    sample, _, indicators = combine(h_observed, lambda_observed, h_rejected, original)\n",
    "    lambdas = original(sample)\n",
    "    counters = []\n",
    "    for counter in range(100):\n",
    "        counterfactuals, counterfactual_indicators = sample_counterfactual(sample, lambdas, lambda_max, indicators, intervention)\n",
    "        if check_monotonicity(sample, counterfactuals, original, intervention, sample[indicators]) != 'MONOTONIC':\n",
    "            print('Not monotonic')\n",
    "        counters.append(counterfactuals)\n",
    "    return sample[indicators], counters"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5fd6aa53",
   "metadata": {},
   "source": [
    "Run the following 3 cells in order to generate youe new samples, othewise skip the cell and continue to load our generated data and replicate the paper results."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "a3f7942d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# with Pool(48) as pool:\n",
    "#     result = list(tqdm(pool.imap(counterfactual1, list(range(1000))), total = 1000))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8a6b2773",
   "metadata": {},
   "outputs": [],
   "source": [
    "# # Save\n",
    "# all_samples_save = [result[i][2] for i in range(1000)]\n",
    "# import json\n",
    "# np.save('Data/allsamples.npy', all_samples_save, allow_pickle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "2d2a4534",
   "metadata": {},
   "outputs": [],
   "source": [
    "# all_indicators_save = [result[i][3] for i in range(1000)]\n",
    "# with open('Data/allindicators.json', 'w') as fout:\n",
    "#     json.dump(all_indicators_save , fout)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ca849159",
   "metadata": {},
   "source": [
    "The following cells will read our ramdomly generated data in order to replecate the paper results."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "b9b8e19a",
   "metadata": {},
   "outputs": [],
   "source": [
    "samples_load = np.load('data_inhomogeneous/allsamples.npy', allow_pickle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "d986286a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "with open(r'data_inhomogeneous/allindicators.json', \"r\") as read_file:\n",
    "    indicators_load = json.load(read_file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "3b91d3cd",
   "metadata": {},
   "outputs": [],
   "source": [
    "f = [samples_load[i][indicators_load[i]] for i in range(1000)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "16415662",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████| 1000/1000 [34:16<00:00,  2.06s/it]\n"
     ]
    }
   ],
   "source": [
    "with Pool(48) as pool:\n",
    "    result = list(tqdm(pool.imap(counterfactual2, list(range(1000))), total = 1000))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "501e07d1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def count_interval(start, end, samples):\n",
    "    return len(samples[(start <= samples) & (samples < end)])\n",
    "\n",
    "def filter_interval(start, end, samples):\n",
    "    return samples[(start <= samples) & (samples < end)]\n",
    "\n",
    "    \n",
    "def distance(accepted, counterfactuals, T):\n",
    "    # Calculates the distance between oserved and counterfactual realizaitons\n",
    "    k1 = len(accepted)\n",
    "    k2 = len(counterfactuals)\n",
    "    if k1 <= k2:\n",
    "        d = np.sum(np.abs(accepted[0:k1] - counterfactuals[0:k1]))\n",
    "        if k2 - k1 > 0:\n",
    "            d += np.sum(np.abs(T - counterfactuals[k1:]))\n",
    "    else:\n",
    "        d = np.sum(np.abs(accepted[0:k2] - counterfactuals[0:k2]))\n",
    "        if k1 - k2 > 0:\n",
    "            d += np.sum(np.abs(T - accepted[k2:]))\n",
    "    return d\n",
    "\n",
    "def count_bins(start, end, delta, samples):\n",
    "    intervals = np.arange(start, end, delta)\n",
    "    bins = np.zeros(len(intervals) - 1)\n",
    "    for i in range(len(bins)):\n",
    "        bins[i] = count_interval(intervals[i], intervals[i + 1], samples)\n",
    "    return bins, intervals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "f4976e8d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1000"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "number_of_events = [count_interval(window_center - window_radious, window_center + window_radious, f[i]) for i in range(len(f))]\n",
    "len(number_of_events)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "31b4e5bb",
   "metadata": {},
   "outputs": [],
   "source": [
    "number_of_groups = 3\n",
    "quantile_indices = pd.qcut(number_of_events, number_of_groups, labels = range(number_of_groups)).to_numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "970860bf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0, 0, 0, 0, 0, ..., 1, 1, 1, 2, 1]\n",
       "Length: 1000\n",
       "Categories (3, int64): [0 < 1 < 2]"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.qcut(number_of_events, number_of_groups, labels = range(number_of_groups))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "4e2b0589",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([0, 0, 0, 0, 0, ..., 1, 1, 1, 2, 1]\n",
       " Length: 1000\n",
       " Categories (3, int64): [0 < 1 < 2],\n",
       " array([11., 16., 23., 29.]))"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.qcut(number_of_events, number_of_groups, labels = range(number_of_groups), retbins=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a690b69e",
   "metadata": {},
   "source": [
    "The following includes the pre-processings needed for binning and plotting."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "5b922cf9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3.36\n",
      "4.22\n",
      "2.42\n"
     ]
    }
   ],
   "source": [
    "groups = [[] for i in range(number_of_groups)]\n",
    "groups_general = [[] for i in range(number_of_groups)]\n",
    "for i in range(1000):\n",
    "    k = quantile_indices[i]\n",
    "    groups[k].extend(result[i][1])\n",
    "    groups_general[k].append(f[i])\n",
    "    \n",
    "for i in range(number_of_groups):\n",
    "    print(len(groups_general[i]) / 100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "279319b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = 0.09 # 0.1 for lambda'>lambda\n",
    "number_of_bins = len(np.arange(begin, end, delta)) - 1\n",
    "bin_numbers = []\n",
    "for i in range(number_of_groups):\n",
    "    bin_number = np.zeros(number_of_bins)\n",
    "    \n",
    "    for counter in groups[i]:\n",
    "        num , _ = count_bins(begin, end, delta, np.array(counter))\n",
    "        \n",
    "        bin_number += num\n",
    "         \n",
    "    bin_number = bin_number / len(groups[i]) \n",
    "    bin_numbers.append(bin_number)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "33054456",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = 0.09\n",
    "number_of_bins = len(np.arange(begin, end, delta)) - 1\n",
    "original_bin_numbers = []\n",
    "for i in range(number_of_groups):\n",
    "    bin_number = np.zeros(number_of_bins)\n",
    "    \n",
    "    for ori in groups_general[i]:\n",
    "        num , _ = count_bins(begin, end, delta, np.array(ori))\n",
    "        \n",
    "        bin_number += num\n",
    "         \n",
    "    bin_number = bin_number / len(groups_general[i]) \n",
    "#     bin_number = bin_number / delta \n",
    "    original_bin_numbers.append(bin_number)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "d127ec1f",
   "metadata": {},
   "outputs": [],
   "source": [
    "width_pt = 397\n",
    "fig_height, fig_aspect = utils.get_fig_dim(width_pt, fraction=0.65)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "c381afb7",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.style.use(['science','no-latex'])\n",
    "plt.rcParams[\"axes.spines.right\"] = False\n",
    "plt.rcParams[\"axes.spines.top\"] = False\n",
    "plt.rcParams[\"xtick.top\"] = False\n",
    "plt.rcParams[\"ytick.right\"] = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "d6633bd6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.axis.YTick at 0x7f36e66c9670>,\n",
       " <matplotlib.axis.YTick at 0x7f36e67136a0>,\n",
       " <matplotlib.axis.YTick at 0x7f36e67133d0>,\n",
       " <matplotlib.axis.YTick at 0x7f36e6648d60>,\n",
       " <matplotlib.axis.YTick at 0x7f36e66bdee0>,\n",
       " <matplotlib.axis.YTick at 0x7f36e664dc40>]"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 257.086x158.888 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(fig_height*fig_aspect,fig_height))\n",
    "ax.plot(x, original(x), label = 'original')\n",
    "ax.plot(x, intervention(x), label = 'intervention')\n",
    "ax.set_xlabel('time', fontsize = 10)\n",
    "ax.set_ylabel('intensity', fontsize = 10)\n",
    "ax.axvline(x=begin, color = 'k', ls = '--', alpha = 0.5)\n",
    "ax.axvline(x=end, color = 'k', ls = '--', alpha = 0.5)\n",
    "ax.legend(loc='lower right', fontsize = 10)\n",
    "ax.set_xticks(np.arange(0,T +1,1))\n",
    "ax.set_yticks(np.arange(0,60,10))\n",
    "# plt.savefig('{}/intensities1.pdf'.format(path), format = 'pdf', dpi = 900)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "aefb92af",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.axis.XTick at 0x7f36e67305e0>,\n",
       " <matplotlib.axis.XTick at 0x7f36e6730550>,\n",
       " <matplotlib.axis.XTick at 0x7f36e65c9d90>,\n",
       " <matplotlib.axis.XTick at 0x7f36e658fd90>]"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 257.086x158.888 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(fig_height*fig_aspect,fig_height))\n",
    "k = 0 # k = 0 or 1 0r 2\n",
    "weights = [0.25, 0.5, 0.25]\n",
    "out_f = np.convolve(bin_numbers[k],np.array(weights)[::-1],'same')\n",
    "out_o = np.convolve(original_bin_numbers[k],np.array(weights)[::-1],'same')\n",
    "s = len(out_f)\n",
    "xnew_bar = np.arange(begin, end, delta)\n",
    "xnew_bar = 0.5 * (xnew_bar[:-1] + xnew_bar[1:])\n",
    "for i in range(len(out_f)):\n",
    "    a = np.abs(out_f[i]) # counterfactual\n",
    "    b = np.abs(out_o[i]) # original\n",
    "    if a > b:\n",
    "        ax.bar(xnew_bar[i], a, label='cubic', width = delta, color = 'yellowgreen', edgecolor='green')\n",
    "        ax.bar(xnew_bar[i], b, label='cubic', width = delta, color = 'white', edgecolor='grey')\n",
    "    else:\n",
    "        ax.bar(xnew_bar[i], b, label='cubic', width = delta, color = 'salmon', edgecolor='red')\n",
    "        ax.bar(xnew_bar[i], a, label='cubic', width = delta, color = 'white', edgecolor='grey')\n",
    "        \n",
    "    \n",
    "# ax.bar(xnew_bar, np.abs(f_cubic[2](xnew_bar)), label='cubic', width = (end - begin) / 17, color = 'yellowgreen')\n",
    "# ax.bar(xnew_bar, np.abs(o_cubic[2](xnew_bar)), label='cubic', width = (end - begin) / 17, color = 'red')\n",
    "ax.set_xlabel('time')\n",
    "ax.set_ylabel('Average Number \\n of Events')\n",
    "ax.set_yticks(np.arange(0,6,1))\n",
    "ax.set_xticks(np.arange(begin,end,0.2))\n",
    "# plt.savefig('{}/groups1_{}_lmax_{}_delta_{}.pdf'.format(path, k + 1, lambda_max, delta), format = 'pdf', dpi = 900)"
   ]
  }
 ],
 "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.8.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
