{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Counterfactuals in SIR epidemic (Ebola)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Dependencies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "if '../../' not in sys.path:\n",
    "    sys.path.append('../../')\n",
    "import copy\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import networkx as nx\n",
    "import matplotlib.pyplot as plt \n",
    "import seaborn as sns\n",
    "import plotutils\n",
    "from graph_generation import make_ebola_network\n",
    "from dynamics import SimulationSIR, sample_seeds\n",
    "from tqdm import tqdm\n",
    "from multiprocessing import cpu_count, Pool\n",
    "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": "markdown",
   "metadata": {},
   "source": [
    "## Predefined Network settings"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Run the following commented cells (codes) in case you want to generate and sample a new outbreak, otherwise ignore them and proceed to load our pre-sampled data and replicate the paper results."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# n_nodes = 8000  # Desired number of nodes (we only keep the giant component, so actual number of nodes may be smaller)\n",
    "# p_in = 0.01  # Intra-district edge probability\n",
    "# p_out = {  # Inter-district edge probability\n",
    "#            'Guinea': 0.00215,\n",
    "#           'Liberia': 0.00300, \n",
    "#      'Sierra Leone': 0.00315, \n",
    "#     'inter-country': 0.0019\n",
    "# }\n",
    "\n",
    "# # Generate scaled graph with settings\n",
    "# G = make_ebola_network(n_nodes=n_nodes, p_in=p_in, p_out=p_out, seed=None)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Run simulation on graph with predefined settings"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Sample seeds from the dataset (random set from infections seen before the given date, taking into account possible random recovery)\n",
    "# init_event_list = sample_seeds(graph=G, delta=1.0 / 11.4, method='data', max_date='2014-01-01')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# alls = []\n",
    "# for _ in range(100):\n",
    "#     init_event_list = sample_seeds(graph=G, delta=1.0 / 11.4, method='data', max_date='2014-01-01', verbose=False)\n",
    "#     distric = {}\n",
    "#     for i in range(0, len(init_event_list), 2):\n",
    "#         j =init_event_list[i] \n",
    "#         if G.nodes(data = True)[j[0][0]]['district'].title() not in distric.keys():\n",
    "#             distric[G.nodes(data = True)[j[0][0]]['district'].title()] = 1\n",
    "#         else:\n",
    "#             distric[G.nodes(data = True)[j[0][0]]['district'].title()] += 1\n",
    "#     alls.append(distric)\n",
    "#     alls.append('\\n')\n",
    "\n",
    "# import json\n",
    "# with open('seeds.json', 'w') as fout:\n",
    "#     json.dump(alls, fout)\n",
    "#     print(sir_obj.G.nodes(data = True)[j[0][0]]['district'].title(), end = ', ')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# with open('seeds.txt', 'w+') as file:\n",
    "#     for dct in alls:\n",
    "#         file.write(str(dct))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "# with open('Data_seed/seed1', 'wb') as fp:\n",
    "#     pickle.dump(init_event_list, fp)\n",
    "# later to load\n",
    "with open ('Data_seed/seed1', 'rb') as fp:\n",
    "    init_event_list = pickle.load(fp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# # Initialize object\n",
    "# sir_obj = SimulationSIR(G, # Graph of individuals\n",
    "#                         beta=1.0 / 15.3,  # Infection rate (advised by literature)\n",
    "#                         delta=1.0 / 11.4,  # Recovery rate (advised by literature)\n",
    "#                         gamma=0.0, rho=0.0,  # Treatement values, should remain zero\n",
    "#                         verbose=False)\n",
    "\n",
    "# # Run the sumulation\n",
    "# sir_obj.launch_epidemic(init_event_list=init_event_list, max_time=120)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# def save_object(obj, filename):\n",
    "#     with open(filename, 'wb') as outp:  # Overwrites any existing file.\n",
    "#         pickle.dump(obj, outp, pickle.HIGHEST_PROTOCOL)  \n",
    "# save_object(sir_obj, 'Data_seed/sir_obj1')\n",
    "\n",
    "with open ('Data_seed/sir_obj1', 'rb') as fp:\n",
    "    sir_obj = pickle.load(fp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Western, Pujehun, Tonkolili, Western, Gueckedou, Gueckedou, "
     ]
    }
   ],
   "source": [
    "for i in range(0, len(init_event_list), 2):\n",
    "    j =init_event_list[i]\n",
    "    print(sir_obj.G.nodes(data = True)[j[0][0]]['district'].title(), end = ', ')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of different blocks (districts) is: 55\n"
     ]
    }
   ],
   "source": [
    "# creates a map between districts and blocks. (Will be needed in isolation and anslysis)\n",
    "blocks = []\n",
    "districts = []\n",
    "block_to_district = {}\n",
    "district_to_block ={}\n",
    "for k, v in enumerate(sir_obj.G.nodes(data=True)):\n",
    "    if v[1]['block'] not in blocks:\n",
    "        blocks.append(v[1]['block'])\n",
    "    if v[1]['district'] not in districts:\n",
    "        districts.append(v[1]['district'])\n",
    "    block_to_district[v[1]['block']] = v[1]['district']\n",
    "    district_to_block[v[1]['district']] = v[1]['block']\n",
    "print('number of different blocks (districts) is: {}'.format(len(blocks)))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Utility functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Returns whether nodes are infected at some time or not.\n",
    "def nodes_at_time(time, type, sir_obj):\n",
    "    if type == 'ori':\n",
    "        return sir_obj.nodes_at_time('I', time)\n",
    "    elif type == 'cf':\n",
    "        return (sir_obj.cf_rec > time) * (sir_obj.cf_inf < time)\n",
    "    else:\n",
    "        print('Invalid type.')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Intervention 1: Isolation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "\n",
    "def isolate_district(district_name, G):\n",
    "    # Cuts all edges between the district and the rest of the graph.\n",
    "    block = district_to_block[district_name]\n",
    "    for node in np.array(G.nodes()):\n",
    "        if G.nodes()[node]['block'] == block:\n",
    "            for neighbor in list(G.neighbors(node)):\n",
    "                if G.nodes()[neighbor]['block'] != block:\n",
    "                    G.remove_edge(node, neighbor)\n",
    "                    \n",
    "def isolate_interior(district_name, G):\n",
    "    # within one distric, cuts edges with 50% probability\n",
    "    block = district_to_block[district_name]\n",
    "    edges = copy.deepcopy(G.edges)\n",
    "    for edge in edges:\n",
    "        if G.nodes()[edge[0]]['block'] == block and G.nodes()[edge[1]]['block'] == block:\n",
    "            if random.random() < 0.5:\n",
    "                G.remove_edge(edge[0], edge[1])                   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<BarContainer object of 120 artists>"
      ]
     },
     "execution_count": 14,
     "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": [
    "ori_number_of_cases = [np.count_nonzero(nodes_at_time(i, 'ori', sir_obj)) for i in range(sir_obj.max_time)]\n",
    "plt.bar(range(sir_obj.max_time), ori_number_of_cases)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/knoorbakhsh/code/ebola/gumbel.py:4: RuntimeWarning: divide by zero encountered in log\n",
      "  gumbel = np.random.gumbel() + np.log(alpha)\n",
      "/home/knoorbakhsh/code/ebola/gumbel.py:25: RuntimeWarning: divide by zero encountered in log\n",
      "  return gumbels - np.log(np.array([p_0, p_1]))\n",
      "/home/knoorbakhsh/code/ebola/gumbel.py:25: RuntimeWarning: invalid value encountered in subtract\n",
      "  return gumbels - np.log(np.array([p_0, p_1]))\n",
      "/home/knoorbakhsh/code/ebola/counterfactual_tpp.py:26: RuntimeWarning: divide by zero encountered in log\n",
      "  up = np.argmax(np.log(np.array([pp_0, pp_1])) + post)\n",
      "/home/knoorbakhsh/code/ebola/counterfactual_tpp.py:26: RuntimeWarning: invalid value encountered in add\n",
      "  up = np.argmax(np.log(np.array([pp_0, pp_1])) + post)\n"
     ]
    }
   ],
   "source": [
    "sir_obj.calculate_counterfactual(sir_obj.beta, sir_obj.G)\n",
    "maximum_days = sir_obj.max_time + 20"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[26, 35, 50]\n"
     ]
    }
   ],
   "source": [
    "# find the days that the number of total cases exceeded some threshold\n",
    "number_of_cases = [np.count_nonzero(nodes_at_time(i,'ori', sir_obj)) for i in range(maximum_days)]\n",
    "cases_thresholds = [300, 600, 900]\n",
    "cut_thresholds = []\n",
    "for t in cases_thresholds:\n",
    "    for day, nc in enumerate(number_of_cases):\n",
    "        if nc >= t:\n",
    "            cut_thresholds.append(day)\n",
    "            break\n",
    "print(cut_thresholds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['WESTERN', 'WESTERN', 'WESTERN']\n"
     ]
    }
   ],
   "source": [
    "# find the cities in which had the max #cases/population untill that time threshold.\n",
    "population = np.zeros(55)\n",
    "for k, v in enumerate(sir_obj.G.nodes(data=True)):\n",
    "    population[v[1]['block']] += 1\n",
    "cut_districts = []\n",
    "for day in cut_thresholds:\n",
    "    cases = np.zeros(55)\n",
    "    for k, v in enumerate(sir_obj.G.nodes(data=True)):\n",
    "        if sir_obj.inf_occured_at[sir_obj.node_to_idx[v[0]]] <= day:\n",
    "            cases[v[1]['block']] += 1\n",
    "    max_district = block_to_district[np.argmax(cases/population)]\n",
    "    cut_districts.append(max_district)\n",
    "print(cut_districts)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "def counterfactual(_):\n",
    "    sir_obj.calculate_counterfactual(sir_obj.beta, G_prime, intervention_time = _)\n",
    "    res = np.array([np.count_nonzero(nodes_at_time(i, 'cf', sir_obj)) for i in range(maximum_days)])\n",
    "    return res"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:26<00:00,  1.32s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:24<00:00,  1.23s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:18<00:00,  1.07it/s]\n"
     ]
    }
   ],
   "source": [
    "number_of_counterfactuals = 20\n",
    "target_dfs = []\n",
    "for i, day in enumerate(cut_thresholds):\n",
    "    G_prime = copy.deepcopy(sir_obj.G)\n",
    "    isolate_district(cut_districts[i], G_prime)\n",
    "    isolate_interior(cut_districts[i], G_prime)\n",
    "    with Pool(48) as pool:\n",
    "        resultt = list(tqdm(pool.imap(counterfactual, [day for i in range(number_of_counterfactuals)]), total = number_of_counterfactuals))\n",
    "    d = []\n",
    "    for i in range(maximum_days):\n",
    "        for j in range(len(resultt)):\n",
    "            d.append([i + 1, resultt[j][i]])\n",
    "\n",
    "    df = pd.DataFrame(d, columns=['days', 'Number of cases'])\n",
    "    target_dfs.append(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f41f9453700>"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.776x158.888 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "number_of_cases = [np.count_nonzero(nodes_at_time(i,'ori', sir_obj)) for i in range(maximum_days)]\n",
    "width_pt = 397\n",
    "fig_height, fig_aspect = plotutils.get_fig_dim(width_pt, fraction=0.65)\n",
    "fig, ax = plt.subplots(figsize=(fig_height * 2, fig_height))\n",
    "ax.plot(range(maximum_days), number_of_cases, label = 'Observation', linewidth=2.0, color = 'k')\n",
    "sns.lineplot(data=target_dfs[0], x=\"days\", y=\"Number of cases\", label = r'Threshold $= {}$'.format(cases_thresholds[0]), color ='green').set(xlabel= \"$t$ [days]\", ylabel= \"Number of active cases\")\n",
    "sns.lineplot(data=target_dfs[1], x=\"days\", y=\"Number of cases\", label = r'Threshold $= {}$'.format(cases_thresholds[1]), color ='orange').set(xlabel= \"$t$ [days]\", ylabel= \"Number of active cases\")\n",
    "sns.lineplot(data=target_dfs[2], x=\"days\", y=\"Number of cases\", label = r'Threshold $= {}$'.format(cases_thresholds[2]), color ='red').set(xlabel= \"$t$ [days]\", ylabel= \"Number of active cases\")\n",
    "# sns.lineplot(data=target_dfs[3], x=\"days\", y=\"Number of cases\", label = r'Active cases $> {}$'.format(cases_thresholds[3]), color ='red').set(xlabel= \"t [days]\", ylabel= \"Number of Active cases\")\n",
    "plt.plot([0, cut_thresholds[0]],[cases_thresholds[0], cases_thresholds[0]],'--', color ='green', alpha = 0.5)\n",
    "plt.plot([0, cut_thresholds[1]],[cases_thresholds[1], cases_thresholds[1]],'--', color ='orange', alpha = 0.5)\n",
    "plt.plot([0, cut_thresholds[2]],[cases_thresholds[2], cases_thresholds[2]],'--', color ='red', alpha = 0.5)\n",
    "# plt.plot([0, cut_thresholds[3]],[cases_thresholds[3], cases_thresholds[3]],'--', color ='red', alpha = 0.5)\n",
    "ax.set_yticks(range(0,1500,300))\n",
    "ax.set_xticks(range(0,150,50))\n",
    "ax.legend(loc = 'upper right', fontsize=8)\n",
    "# ax.legend(loc = 'upper right', bbox_to_anchor=(1.5, 1))\n",
    "# fig.savefig('FIG/sir_isolation.pdf', bbox_inches = 'tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Here, we wish to sparcify the network with some percentage and compare different percentages : 5%, 10%, 15%, 20%, 25%"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "def sparcify(percentage, G):\n",
    "    edges = copy.deepcopy(G.edges)\n",
    "    for edge in edges:\n",
    "        if random.random() < percentage:\n",
    "            G.remove_edge(edge[0], edge[1])              "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/knoorbakhsh/code/ebola/gumbel.py:4: RuntimeWarning: divide by zero encountered in log\n",
      "  gumbel = np.random.gumbel() + np.log(alpha)\n",
      "/home/knoorbakhsh/code/ebola/gumbel.py:25: RuntimeWarning: divide by zero encountered in log\n",
      "  return gumbels - np.log(np.array([p_0, p_1]))\n",
      "/home/knoorbakhsh/code/ebola/gumbel.py:25: RuntimeWarning: invalid value encountered in subtract\n",
      "  return gumbels - np.log(np.array([p_0, p_1]))\n",
      "/home/knoorbakhsh/code/ebola/counterfactual_tpp.py:26: RuntimeWarning: divide by zero encountered in log\n",
      "  up = np.argmax(np.log(np.array([pp_0, pp_1])) + post)\n",
      "/home/knoorbakhsh/code/ebola/counterfactual_tpp.py:26: RuntimeWarning: invalid value encountered in add\n",
      "  up = np.argmax(np.log(np.array([pp_0, pp_1])) + post)\n"
     ]
    }
   ],
   "source": [
    "dfss = []\n",
    "percentages = [0.05, 0.1, 0.15, 0.2, 0.25]\n",
    "maximum_days = sir_obj.max_time + 20\n",
    "sir_obj.calculate_counterfactual(sir_obj.beta, sir_obj.G)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "def counterfactual2(_):\n",
    "    # Change the index in cut_thresholds[2] in the following line to obtain different threshold results (it can be 0, 1, 2)\n",
    "    sir_obj.calculate_counterfactual(sir_obj.beta, G_prime, intervention_time = cut_thresholds[2])\n",
    "    res = np.array([np.count_nonzero(nodes_at_time(i, 'cf', sir_obj)) for i in range(maximum_days)])\n",
    "    return res"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:17<00:00,  1.17it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:17<00:00,  1.14it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:17<00:00,  1.14it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:17<00:00,  1.15it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:17<00:00,  1.15it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:16<00:00,  1.25it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:16<00:00,  1.23it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:15<00:00,  1.26it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:15<00:00,  1.25it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:16<00:00,  1.23it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:14<00:00,  1.35it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:14<00:00,  1.36it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:14<00:00,  1.37it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:14<00:00,  1.37it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:14<00:00,  1.37it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:13<00:00,  1.48it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:13<00:00,  1.46it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:13<00:00,  1.48it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:13<00:00,  1.51it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:13<00:00,  1.49it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:12<00:00,  1.65it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:12<00:00,  1.59it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:12<00:00,  1.65it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:12<00:00,  1.65it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:12<00:00,  1.63it/s]\n"
     ]
    }
   ],
   "source": [
    "number_of_counterfactuals = 20\n",
    "for per in percentages:\n",
    "    d = []\n",
    "    for k in range(5):\n",
    "        G_prime = copy.deepcopy(sir_obj.G)\n",
    "        sparcify(per, G_prime)\n",
    "        with Pool(48) as pool:\n",
    "            resultt = list(tqdm(pool.imap(counterfactual2, list(range(number_of_counterfactuals))), total = number_of_counterfactuals))\n",
    "        for i in range(maximum_days):\n",
    "            for j in range(len(resultt)):\n",
    "                d.append([i + 1, resultt[j][i]])\n",
    "\n",
    "    df = pd.DataFrame(d, columns=['days', 'Number of cases'])\n",
    "    dfss.append(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.2, 0.9, 'Threshold $= 900$')"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.776x158.888 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "number_of_cases = [np.count_nonzero(nodes_at_time(i,'ori', sir_obj)) for i in range(maximum_days)]\n",
    "width_pt = 397\n",
    "fig_height, fig_aspect = plotutils.get_fig_dim(width_pt, fraction=0.65)\n",
    "fig, ax = plt.subplots(figsize=(2 * fig_height, fig_height))\n",
    "import matplotlib.pylab as pl\n",
    "# Greens, Wistia\n",
    "colors = pl.cm.Reds(np.linspace(0,1,10))\n",
    "ax.plot(range(maximum_days), number_of_cases, label = 'Observation', linewidth=2.0, color = 'k')\n",
    "sns.lineplot(data=dfss[0], x=\"days\", y=\"Number of cases\", label = '5% isolation', color = colors[9]).set(xlabel= \"$t$ [days]\", ylabel= \"Number of active cases\")\n",
    "sns.lineplot(data=dfss[1], x=\"days\", y=\"Number of cases\", label = '10% isolation', color = colors[8]).set(xlabel= \"$t$ [days]\", ylabel= \"Number of active cases\")\n",
    "sns.lineplot(data=dfss[2], x=\"days\", y=\"Number of cases\", label = '15% isolation', color = colors[7]).set(xlabel= \"$t$ [days]\", ylabel= \"Number of active cases\")\n",
    "sns.lineplot(data=dfss[3], x=\"days\", y=\"Number of cases\", label = '20% isolation', color = colors[5]).set(xlabel= \"$t$ [days]\", ylabel= \"Number of active cases\")\n",
    "sns.lineplot(data=dfss[4], x=\"days\", y=\"Number of cases\", label = '25% isolation', color = colors[3]).set(xlabel= \"$t$ [days]\", ylabel= \"Number of active cases\")\n",
    "ax.set_yticks(range(0,1500,300))\n",
    "ax.set_xticks(range(0,150, 50))\n",
    "ax.legend(loc = 'upper right', fontsize=8)\n",
    "ax.text(0.2, 0.9,'Threshold $= 900$',\n",
    "     horizontalalignment='center',\n",
    "     verticalalignment='center',\n",
    "     transform = ax.transAxes)\n",
    "# ax.legend(loc = 'upper right', bbox_to_anchor=(1.5, 1))\n",
    "# fig.savefig('FIG/sir_multi_isolation_3.pdf', bbox_inches = 'tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Intervention 2: Vaccination"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Current Beta:  0.06535947712418301\n",
      "Vaccinated Beta:  0.006535947712418302\n"
     ]
    }
   ],
   "source": [
    "reduction = 0.1\n",
    "number_of_counterfactuals = 20\n",
    "maximum_days = sir_obj.max_time + 20\n",
    "print('Current Beta: ', sir_obj.beta)\n",
    "print('Vaccinated Beta: ', reduction * sir_obj.beta)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/knoorbakhsh/code/ebola/gumbel.py:4: RuntimeWarning: divide by zero encountered in log\n",
      "  gumbel = np.random.gumbel() + np.log(alpha)\n",
      "/home/knoorbakhsh/code/ebola/gumbel.py:25: RuntimeWarning: divide by zero encountered in log\n",
      "  return gumbels - np.log(np.array([p_0, p_1]))\n",
      "/home/knoorbakhsh/code/ebola/gumbel.py:25: RuntimeWarning: invalid value encountered in subtract\n",
      "  return gumbels - np.log(np.array([p_0, p_1]))\n",
      "/home/knoorbakhsh/code/ebola/counterfactual_tpp.py:26: RuntimeWarning: divide by zero encountered in log\n",
      "  up = np.argmax(np.log(np.array([pp_0, pp_1])) + post)\n",
      "/home/knoorbakhsh/code/ebola/counterfactual_tpp.py:26: RuntimeWarning: invalid value encountered in add\n",
      "  up = np.argmax(np.log(np.array([pp_0, pp_1])) + post)\n"
     ]
    }
   ],
   "source": [
    "reduction = 0.1\n",
    "vaccinated = np.random.choice(a=[False, True], size=(sir_obj.n_nodes,), p=[1 - 0.5, 0.5])\n",
    "sir_obj.calculate_counterfactual(reduction * sir_obj.beta, sir_obj.G, vaccine = vaccinated)\n",
    "# Ignore the warnings"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "# return the number of infected people after intervention during the pandemic.\n",
    "def counterfactualr(_):\n",
    "    sir_obj.calculate_counterfactual(_ * sir_obj.beta, sir_obj.G, vaccine = vaccinated)\n",
    "    res = [sir_obj.cf_inf[i] for i in range(sir_obj.n_nodes) if sir_obj.cf_inf[i]!=np.inf]\n",
    "    return len(res)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.39s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:26<00:00,  1.35s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.35s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.35s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:26<00:00,  1.31s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:21<00:00,  1.07s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:22<00:00,  1.13s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:22<00:00,  1.11s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:22<00:00,  1.11s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:21<00:00,  1.09s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:18<00:00,  1.08it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:16<00:00,  1.22it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:17<00:00,  1.12it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:14<00:00,  1.34it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:16<00:00,  1.21it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:11<00:00,  1.80it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:11<00:00,  1.74it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:09<00:00,  2.18it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:08<00:00,  2.50it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:08<00:00,  2.41it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:05<00:00,  3.84it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:04<00:00,  4.86it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:03<00:00,  5.68it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:05<00:00,  3.66it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:04<00:00,  4.64it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:02<00:00,  7.66it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:02<00:00,  9.82it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:02<00:00,  8.87it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:03<00:00,  5.87it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:02<00:00,  9.56it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:01<00:00, 17.07it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:01<00:00, 17.11it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:01<00:00, 14.77it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:01<00:00, 15.19it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:01<00:00, 11.00it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:00<00:00, 31.47it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:00<00:00, 22.84it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:01<00:00, 14.04it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:00<00:00, 25.88it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:00<00:00, 24.02it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.39s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.37s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.36s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:29<00:00,  1.45s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:28<00:00,  1.44s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:23<00:00,  1.20s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:24<00:00,  1.25s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:24<00:00,  1.23s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:24<00:00,  1.23s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:24<00:00,  1.23s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:17<00:00,  1.13it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:20<00:00,  1.04s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:20<00:00,  1.02s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:18<00:00,  1.05it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:19<00:00,  1.00it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:15<00:00,  1.29it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:13<00:00,  1.46it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:14<00:00,  1.42it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:11<00:00,  1.69it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:12<00:00,  1.59it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:09<00:00,  2.11it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:10<00:00,  1.97it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:09<00:00,  2.19it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:08<00:00,  2.23it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:07<00:00,  2.65it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:06<00:00,  3.18it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:04<00:00,  4.69it/s]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:05<00:00,  3.58it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:04<00:00,  4.20it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:05<00:00,  3.74it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:02<00:00,  8.01it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:03<00:00,  6.34it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:03<00:00,  5.54it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:03<00:00,  6.17it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:02<00:00,  6.95it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:02<00:00,  8.61it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:02<00:00,  9.68it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:01<00:00, 10.24it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:01<00:00, 10.66it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:01<00:00, 13.75it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:28<00:00,  1.42s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:28<00:00,  1.40s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:28<00:00,  1.44s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:29<00:00,  1.47s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:28<00:00,  1.42s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.36s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:26<00:00,  1.31s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:26<00:00,  1.34s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:26<00:00,  1.31s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:26<00:00,  1.32s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:23<00:00,  1.18s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:20<00:00,  1.04s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:22<00:00,  1.15s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:23<00:00,  1.17s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:22<00:00,  1.11s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:19<00:00,  1.05it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:17<00:00,  1.15it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:17<00:00,  1.12it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:18<00:00,  1.06it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:18<00:00,  1.09it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:15<00:00,  1.30it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:13<00:00,  1.50it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:14<00:00,  1.39it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:15<00:00,  1.33it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:13<00:00,  1.49it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:08<00:00,  2.36it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:08<00:00,  2.33it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:09<00:00,  2.02it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:10<00:00,  1.84it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:09<00:00,  2.21it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:05<00:00,  3.85it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:05<00:00,  3.66it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:06<00:00,  3.20it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:05<00:00,  3.76it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:05<00:00,  3.85it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:03<00:00,  5.57it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:05<00:00,  3.66it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:05<00:00,  3.45it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:03<00:00,  5.28it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:05<00:00,  3.61it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:29<00:00,  1.46s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:29<00:00,  1.47s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:28<00:00,  1.44s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:28<00:00,  1.42s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:29<00:00,  1.46s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.37s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.38s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.36s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.37s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.39s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:24<00:00,  1.22s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:26<00:00,  1.30s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:24<00:00,  1.23s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:23<00:00,  1.20s/it]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:26<00:00,  1.30s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:21<00:00,  1.10s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:22<00:00,  1.10s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:23<00:00,  1.16s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:22<00:00,  1.14s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:22<00:00,  1.11s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:17<00:00,  1.12it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:16<00:00,  1.20it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:19<00:00,  1.03it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:17<00:00,  1.17it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:16<00:00,  1.24it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:13<00:00,  1.46it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:12<00:00,  1.62it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:18<00:00,  1.11it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:16<00:00,  1.24it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:13<00:00,  1.54it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:10<00:00,  1.85it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:11<00:00,  1.81it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:10<00:00,  1.99it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:11<00:00,  1.76it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:12<00:00,  1.56it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:06<00:00,  3.13it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:06<00:00,  3.06it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:05<00:00,  3.61it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:07<00:00,  2.69it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:06<00:00,  3.07it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:30<00:00,  1.51s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:30<00:00,  1.51s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:28<00:00,  1.43s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:29<00:00,  1.50s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:29<00:00,  1.48s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:28<00:00,  1.42s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:28<00:00,  1.43s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:28<00:00,  1.41s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.40s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:28<00:00,  1.43s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:26<00:00,  1.35s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:25<00:00,  1.28s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:26<00:00,  1.34s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:27<00:00,  1.37s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:26<00:00,  1.31s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:25<00:00,  1.27s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:24<00:00,  1.22s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:24<00:00,  1.23s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:25<00:00,  1.28s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:25<00:00,  1.29s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:22<00:00,  1.10s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:21<00:00,  1.08s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:21<00:00,  1.08s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:23<00:00,  1.16s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:22<00:00,  1.14s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:20<00:00,  1.04s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:18<00:00,  1.08it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:18<00:00,  1.06it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:18<00:00,  1.10it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:21<00:00,  1.05s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:17<00:00,  1.13it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:17<00:00,  1.17it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:16<00:00,  1.20it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:18<00:00,  1.09it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:19<00:00,  1.03it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:13<00:00,  1.49it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:13<00:00,  1.44it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:10<00:00,  1.97it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:10<00:00,  1.92it/s]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 20/20 [00:10<00:00,  1.86it/s]\n"
     ]
    }
   ],
   "source": [
    "beta_reductions = [0.1, 0.2, 0.3, 0.4, 0.5]\n",
    "percentage_vaccinated = [0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8]\n",
    "number_of_counterfactuals = 20\n",
    "dfs = []\n",
    "all_cases = {}\n",
    "for bet in beta_reductions:\n",
    "    for per in percentage_vaccinated:\n",
    "        cases = 0\n",
    "        for k in range(5):\n",
    "            vaccinated = np.random.choice(a=[False, True], size=(sir_obj.n_nodes,), p=[1 - per, per])\n",
    "            with Pool(48) as pool:\n",
    "                result = list(tqdm(pool.imap(counterfactualr, [bet for i in range(number_of_counterfactuals)]), total = number_of_counterfactuals))\n",
    "            cases += sum(result)\n",
    "        all_cases[(bet, per)] = cases / 250"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4922\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(5, 8)"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "obs_infected = [sir_obj.inf_occured_at[i] for i in range(sir_obj.n_nodes) if sir_obj.inf_occured_at[i]!=np.inf]\n",
    "obseved_cases = len(obs_infected)\n",
    "obs_infected = [sir_obj.inf_occured_at[i] for i in range(sir_obj.n_nodes) if sir_obj.inf_occured_at[i]!=np.inf]\n",
    "print(obseved_cases)\n",
    "effectvity = pd.DataFrame(columns=['Beta', 'vacc', 'reduction'])\n",
    "i = 0\n",
    "for k, v in all_cases.items():\n",
    "    effectvity.loc[i] = [100 - k[0] * 100, k[1] * 100, (obseved_cases - v) * 100 / obseved_cases]\n",
    "    i += 1\n",
    "effectvity = effectvity.astype({\"Beta\": int, \"vacc\": int})\n",
    "# effectvity = effectvity.sort_values(['Beta'], ascending=[True])\n",
    "# effectvity = effectvity.pivot(\"Beta\", \"vacc\", \"reduction\")\n",
    "effectvity.sort_values('vacc',axis=0,ascending=True, inplace = True)\n",
    "effectvity.sort_values('Beta',axis=0,ascending=True, inplace = True)\n",
    "effectvity_copy = copy.deepcopy(effectvity)\n",
    "effectvity = effectvity.pivot(\"Beta\", \"vacc\", \"reduction\")\n",
    "arr = np.zeros((5, 8))\n",
    "for i in range(5):\n",
    "    for j in range(8):\n",
    "        arr[4 - i, j] = effectvity.iloc[i, j]\n",
    "effectvity.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[Text(0.5, 10.5, '% vaccinated'),\n",
       " Text(27.186917696247164, 0.5, '% reduction in $\\\\beta$')]"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 349.495x216 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "width_pt = 397\n",
    "fig_height, fig_aspect = plotutils.get_fig_dim(width_pt, fraction=0.65)\n",
    "fig, ax = plt.subplots(figsize=(fig_aspect * 3, 3))\n",
    "plt.rcParams[\"xtick.bottom\"] = False\n",
    "plt.rcParams[\"ytick.left\"] = False\n",
    "sns.heatmap(arr, xticklabels = [10, 20, 30, 40, 50, 60, 70, 80], yticklabels = [90, 80, 70, 60, 50], cbar_kws={'label': '% reduction of infections\\n(effectivity)'}, cmap = 'YlGn').set(xlabel = '% vaccinated', ylabel = r'% reduction in $\\beta$')\n",
    "# fig.savefig('FIG/sir_obj_effectivity.pdf', bbox_inches = 'tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "# points = effectvity_copy[['Beta', 'vacc']].to_numpy()\n",
    "# i, j = 0, 1\n",
    "# points.T[[i, j]] = points.T[[j, i]]\n",
    "# values = effectvity_copy[['reduction']].to_numpy()\n",
    "# print(points.shape)\n",
    "# print(values.shape)\n",
    "# np.save('Data_seed/points.npy', points)\n",
    "# np.save('Data_seed/values.npy', values)\n",
    "points = np.load('Data_seed/points.npy')\n",
    "values = np.load('Data_seed/values.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.colors as colors\n",
    "from scipy.interpolate import griddata\n",
    "import matplotlib"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 345.6x216 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "zmin, zmax_color, zmax_colorbar = 65, 100, 100\n",
    "cmap='RdYlGn'\n",
    "stepsize = 5\n",
    "norm = colors.Normalize(vmin=zmin, vmax=zmax_color)\n",
    "levels = np.arange(zmin, zmax_colorbar + stepsize, stepsize)\n",
    "fig, axs = plt.subplots(1, 1, figsize=(1.6 * 3, 3))\n",
    "x = np.array([10, 20, 30, 40, 50, 60, 70, 80])\n",
    "y = np.array([50, 60, 70, 80, 90])\n",
    "z = arr\n",
    "xbounds = min(x), max(x)\n",
    "ybounds = min(y), max(y)\n",
    "axs.set_xlabel('% vaccinated')\n",
    "xi = np.linspace(xbounds[0], xbounds[1], 100)\n",
    "yi = np.linspace(ybounds[0], ybounds[1], 100)\n",
    "zi = griddata(points, values, (xi[None,:], yi[:,None]), method='linear').reshape((100, 100))\n",
    "axs.contour(xi, yi, zi, linewidths=0.5, colors='k', norm=norm, levels=levels)\n",
    "contourplot = axs.contourf(xi, yi, zi, cmap=cmap, norm=norm, levels=levels)\n",
    "\n",
    "# axis\n",
    "axs.set_xlim(xbounds)\n",
    "axs.set_ylim(ybounds)\n",
    "\n",
    "axs.set_yticks(y)\n",
    "axs.set_xticks(x)\n",
    "axs.set_ylabel(r'% reduction in $\\beta$')\n",
    "fig.tight_layout()\n",
    "fig.subplots_adjust(right=0.8)\n",
    "\n",
    "cbar_ax = fig.add_axes([0.86, 0.16, 0.05, 0.77])\n",
    "cbar = matplotlib.colorbar.ColorbarBase(\n",
    "    cbar_ax, cmap=plt.cm.RdYlGn,\n",
    "    norm=norm,\n",
    "    boundaries=levels,\n",
    "    ticks=levels[::2],\n",
    "    orientation='vertical')\n",
    "cbar.set_label('% reduction of infections\\n(effectivity)', labelpad=5.0)\n",
    "# fig.savefig('FIG/effectivity.pdf', bbox_inches = 'tight')"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "5f89c732eb85bc78217fc56a6c50f77c7ae628e219514d1b3cad167235aa8a40"
  },
  "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": 4
}
