{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from dataclasses import asdict, dataclass\n",
    "from typing import Any, DefaultDict, Dict, List, Optional, Tuple\n",
    "\n",
    "import dsrl\n",
    "import gymnasium as gym  # noqa\n",
    "import numpy as np\n",
    "import pyrallis\n",
    "import torch\n",
    "from dsrl.offline_env import OfflineEnvWrapper, wrap_env  # noqa\n",
    "from pyrallis import field\n",
    "import sys\n",
    "sys.path.append(\"../CDT/osrl_my_cost\")\n",
    "from torch.utils.data import DataLoader\n",
    "from osrl_my_cost.algorithms import COptiDICE, COptiDICETrainer\n",
    "from osrl_my_cost.common import TransitionDataset\n",
    "from osrl_my_cost.common.exp_util import auto_name, seed_all\n",
    "import pickle\n",
    "import pandas as pd\n",
    "from torch.utils.data import DataLoader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 208,
   "metadata": {},
   "outputs": [],
   "source": [
    "path =f'./Mymodel/coptidice_c6.pt'\n",
    "#path = f'./Mymodel/coptidice_transcost.pt'\n",
    "dataset_path_val = f'./examples_my_cost/data/cost0_data_val.pkl'\n",
    "#path = f'./Mymodel/coptidice_cost0.pt'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 209,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "noise_scale = None\n",
    "eval_episodes = 20\n",
    "best = False\n",
    "device = \"cpu\"\n",
    "threads = 4\n",
    "\n",
    "if device == \"cpu\":\n",
    "    torch.set_num_threads(threads)\n",
    "\n",
    "target_entropy = -2\n",
    "\n",
    "with open(dataset_path_val,'rb') as f:\n",
    "    data_val = pickle.load(f)\n",
    "# model & optimizer & scheduler setup\n",
    "# setup model\n",
    "dataset = TransitionDataset(data_val,\n",
    "                                reward_scale=0.1,\n",
    "                                cost_scale=1,\n",
    "                                state_init=True)\n",
    "    \n",
    "trainloader = DataLoader(\n",
    "    dataset,\n",
    "    batch_size= 512,\n",
    "    pin_memory=True,\n",
    "    num_workers=8,\n",
    ")\n",
    "trainloader_iter = iter(trainloader)\n",
    "init_s_propotion, obs_std, act_std = dataset.get_dataset_states()\n",
    "\n",
    "state_dim = 48\n",
    "action_dim = 2\n",
    "max_action = [1.0,1.0]\n",
    "model = COptiDICE(\n",
    "    state_dim=state_dim,\n",
    "    action_dim=action_dim,\n",
    "    max_action=max_action,\n",
    "    f_type=\"softchi\",\n",
    "    init_state_propotion=init_s_propotion,\n",
    "    observations_std=obs_std,\n",
    "    actions_std=act_std,\n",
    "    a_hidden_sizes=[256, 256],\n",
    "    c_hidden_sizes=[256, 256],\n",
    "    gamma=0.99,\n",
    "    alpha=0.5,\n",
    "    cost_ub_epsilon= 0.01,\n",
    "    num_nu= 2,\n",
    "    num_chi= 2,\n",
    "    cost_limit= 10,\n",
    "    episode_len= 300,\n",
    "    device= \"cpu\",\n",
    ")\n",
    "model.load_state_dict(torch.load(path))\n",
    "model.to(device)\n",
    "\n",
    "trainer = COptiDICETrainer(model,\n",
    "                            logger=None,\n",
    "                            actor_lr= 0.0001,\n",
    "                            critic_lr= 0.0001,\n",
    "                            scalar_lr= 0.0001,\n",
    "                            reward_scale= 0.1,\n",
    "                            cost_scale= 1,\n",
    "                            device= \"cpu\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 210,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import random\n",
    "def get_random1000(path_,seed):\n",
    "    num_trajectories = len(path_['dieds'])\n",
    "    np.random.seed(seed)\n",
    "    batch_inds = np.random.choice(\n",
    "            np.arange(num_trajectories),\n",
    "            size=num_trajectories,\n",
    "            replace=True\n",
    "        )\n",
    "\n",
    "    actions = []\n",
    "    next_observations = []\n",
    "    observations = []\n",
    "    rewards = []\n",
    "    dieds = []\n",
    "    costs = []\n",
    "    terminals = []\n",
    "    #print(len(paths))\n",
    "    die_num, alive_num = 0,0\n",
    "    for i in range(len(batch_inds)):\n",
    "        j = batch_inds[i]\n",
    "        if die_num < 500 and path_['dieds'][j] == 1:\n",
    "            actions.append(path_['actions'][j])\n",
    "            next_observations.append(path_['next_observations'][j])\n",
    "            rewards.append(path_['rewards'][j])\n",
    "            dieds.append(path_['dieds'][j])\n",
    "            costs.append(path_['costs'][j])\n",
    "            observations.append(path_['observations'][j])\n",
    "            terminals.append(path_['terminals'][j])\n",
    "            die_num+=1\n",
    "        elif alive_num<500 and path_['dieds'][j] == 0:\n",
    "            actions.append(path_['actions'][j])\n",
    "            next_observations.append(path_['next_observations'][j])\n",
    "            rewards.append(path_['rewards'][j])\n",
    "            dieds.append(path_['dieds'][j])\n",
    "            costs.append(path_['costs'][j])\n",
    "            observations.append(path_['observations'][j])\n",
    "            terminals.append(path_['terminals'][j])\n",
    "            alive_num+=1\n",
    "        if die_num + alive_num == 1000:\n",
    "            break\n",
    "\n",
    "    out = dict({'actions': np.array(actions),'next_observations': \n",
    "                 np.array(next_observations),'observations': np.array(observations),\n",
    "                 'rewards': np.array(rewards),'terminals': np.array(terminals),'costs':np.array(costs),\n",
    "                 'dieds':np.array(dieds)})\n",
    "    if die_num+alive_num <1000:\n",
    "        print(num_trajectories,die_num,alive_num)\n",
    "        return True,out\n",
    "    return False,out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 211,
   "metadata": {},
   "outputs": [],
   "source": [
    "def eval(seed):\n",
    "\n",
    "    eval_episodes = 1\n",
    "    t = True\n",
    "    while t:\n",
    "        t,data_v = get_random1000(data_val,seed)\n",
    "    #print(\"find data_v which has 100 people.\")\n",
    "    agent_action,phy_action = trainer.evaluate(data_v,eval_episodes)\n",
    "    die = data_v['dieds']\n",
    "    return data_v,agent_action,phy_action,die"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 212,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_term(num,term,actions_a,actions_p,dieds):\n",
    "    t = 0\n",
    "    a = []\n",
    "    p = []\n",
    "    die = -1\n",
    "    for i in range(len(term)):\n",
    "        if term[i]==1:\n",
    "            t+=1\n",
    "        if t==num:\n",
    "            a.append(actions_a[i])\n",
    "            p.append(actions_p[i])\n",
    "            die = dieds[i]\n",
    "        if t>num:\n",
    "            break\n",
    "    return a,p,die"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 213,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_iv_vaso(batch_size,actions_a,actions_p,die,term):\n",
    "    iv_diff = []\n",
    "    diff = []\n",
    "    vaso_diff = []\n",
    "    dies = die\n",
    "\n",
    "    for i in range(batch_size):\n",
    "        ac_dt_iv = actions_a[i][0]\n",
    "        ac_dt_vaso = actions_a[i][1]\n",
    "        ac_ph_iv = actions_p[i][0]\n",
    "        ac_ph_vaso = actions_p[i][1]\n",
    "        iv_diff.append((torch.mean((torch.tensor(ac_dt_iv)-torch.tensor(ac_ph_iv))**2)).detach().cpu().item())\n",
    "        vaso_diff.append((torch.mean((torch.tensor(ac_dt_vaso)-torch.tensor(ac_ph_vaso))**2)).detach().cpu().item())\n",
    "        diff.append((torch.mean((torch.tensor([ac_dt_iv,ac_dt_vaso])-torch.tensor([ac_ph_iv,ac_ph_vaso]))**2)).detach().cpu().item())\n",
    "    return iv_diff,vaso_diff,diff,dies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 214,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_gaps():\n",
    "    seed = [0,1,2,3]\n",
    "    ac_iv = []\n",
    "    ac_vaso = []\n",
    "    ac_diff = []\n",
    "    for i in seed:\n",
    "        val_df,cdt_actions,phy_actions,dieds = eval(i)\n",
    "        dieds = dieds\n",
    "        term = val_df['terminals']\n",
    "        iv_diff,vaso_diff,diff,die=get_iv_vaso(1000,cdt_actions[0],phy_actions[0],dieds,term)\n",
    "\n",
    "        diff_df = pd.DataFrame(columns=['iv','vaso','diff','die'])\n",
    "        diff_df['iv'] = iv_diff\n",
    "        diff_df['vaso'] = vaso_diff\n",
    "        diff_df['diff'] = diff\n",
    "        diff_df['die'] = die\n",
    "        l = ['iv','vaso','diff']\n",
    "        for j in range(len(l)):\n",
    "            df = diff_df.sort_values(l[j])\n",
    "            acc = 0\n",
    "            num = 0\n",
    "            for t in df.index:\n",
    "                if df.loc[t,'die']==0:\n",
    "                    acc=acc+1\n",
    "                num+=1\n",
    "                if num>=500:\n",
    "                    break\n",
    "            acc = acc/num\n",
    "            #print(l[j],\":\",acc)\n",
    "            if j == 0:\n",
    "                ac_iv.append(acc)\n",
    "            elif j == 1:\n",
    "                ac_vaso.append(acc)\n",
    "            else:\n",
    "                ac_diff.append(acc)\n",
    "            #print(diff_df)\n",
    "    return np.mean(ac_iv),np.std(ac_iv),np.mean(ac_vaso),np.std(ac_vaso),np.mean(ac_diff),np.std(ac_diff),diff_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 215,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f12bcef7b89343f4acee765c40aac595",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Evaluating...:   0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c589e491d53c4de7b5287b79e73da559",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Evaluating...:   0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e7ba69f83c4245869f32b26a3ff91b4c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Evaluating...:   0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d3e4537abbd343c6b66115d24f156b17",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Evaluating...:   0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "iv_gap = []\n",
    "vaso_gap = []\n",
    "diff_gap = []\n",
    "x = []\n",
    "\n",
    "ac_iv,ac_iv_std,ac_vaso,ac_vaso_std,ac_diff,ac_diff_std,diff_df = get_gaps()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 216,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.5305 0.013518505834595787\n",
      "0.552 0.0024494897427831805\n",
      "0.5489999999999999 0.010440306508910514\n"
     ]
    }
   ],
   "source": [
    "print(ac_iv,ac_iv_std)\n",
    "print(ac_vaso,ac_vaso_std)\n",
    "print(ac_diff,ac_diff_std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 217,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_val_some_path(path,batch_size=64,seed=10):\n",
    "    num_trajectories = len(path['rewards'])\n",
    "    np.random.seed(seed)\n",
    "    batch_inds = np.random.choice(\n",
    "            np.arange(num_trajectories),\n",
    "            size=batch_size,\n",
    "            replace=True,\n",
    "        )\n",
    "    paths = []\n",
    "\n",
    "    actions = []\n",
    "    costs = []\n",
    "    next_observations = []\n",
    "    observations = []\n",
    "    rewards = []\n",
    "    terminals = []\n",
    "    dieds = []\n",
    "\n",
    "    for i in range(batch_size):\n",
    "        actions.append(path['actions'][batch_inds[i]])\n",
    "        next_observations.append(path['next_observations'][batch_inds[i]])\n",
    "        observations.append(path['observations'][batch_inds[i]])\n",
    "        terminals.append(path['terminals'][batch_inds[i]])\n",
    "        rewards.append(path['rewards'][batch_inds[i]])\n",
    "        dieds.append(path['dieds'][batch_inds[i]])\n",
    "        costs.append(path['costs'][batch_inds[i]])\n",
    "\n",
    "\n",
    "    paths = dict({'actions': np.array(actions),'next_observations': \n",
    "                 np.array(next_observations),'observations': np.array(observations),\n",
    "                 'rewards': np.array(rewards),'terminals': np.array(terminals),'costs':np.array(costs),\n",
    "                 'dieds':np.array(dieds)})\n",
    "        \n",
    "    return paths"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "sudden chagne and two high"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 218,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6b15ee816a8f49249237d033658562e8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Evaluating...:   0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "seed = 23\n",
    "cdt_actions = []\n",
    "phy_actions = []\n",
    "dieds = []\n",
    "val_df = []\n",
    "terminals = []\n",
    "\n",
    "agent_action,phy_action = trainer.evaluate(data_val,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 219,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_iv_vaso_all(action1,action2):\n",
    "    l = len(action1)\n",
    "    iv1,iv2,vaso1,vaso2 = [],[],[],[]\n",
    "    for i in range(l):\n",
    "        if action1[i][0]<0:\n",
    "            action1[i][0]=0\n",
    "        if action2[i][0]<0:\n",
    "            action2[i][0]=0\n",
    "        iv1.append(action1[i][0])\n",
    "        iv2.append(action2[i][0])\n",
    "        vaso1.append(action1[i][1])\n",
    "        vaso2.append(action2[i][1])\n",
    "    return iv1,iv2,vaso1,vaso2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 220,
   "metadata": {},
   "outputs": [],
   "source": [
    "cdt_actions = agent_action[0]\n",
    "phy_actions = phy_action[0]\n",
    "dieds = data_val['dieds']\n",
    "term = data_val['terminals']\n",
    "\n",
    "iv1,iv2,vaso1,vaso2 =get_iv_vaso_all(cdt_actions,phy_actions)\n",
    "\n",
    "df_all = pd.DataFrame(columns=['iv_cdt','vaso_cdt','iv_phy','vaso_phy','die','term'])\n",
    "df_all['iv_cdt'] = [ i*2000 for i in iv1]\n",
    "df_all['vaso_cdt'] =  [x if x>=0 else 0 for x in vaso1]\n",
    "df_all['iv_phy'] = [ i*2000 for i in iv2]\n",
    "df_all['vaso_phy'] = [x if x>=0 else 0 for x in vaso2]\n",
    "df_all['die'] = data_val['dieds']\n",
    "df_all['term'] = data_val['terminals']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 221,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>iv_cdt</th>\n",
       "      <th>vaso_cdt</th>\n",
       "      <th>iv_phy</th>\n",
       "      <th>vaso_phy</th>\n",
       "      <th>die</th>\n",
       "      <th>term</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>135.394141</td>\n",
       "      <td>0.003626</td>\n",
       "      <td>90.000004</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>73.345706</td>\n",
       "      <td>0.002740</td>\n",
       "      <td>140.000001</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>171.682522</td>\n",
       "      <td>0.002526</td>\n",
       "      <td>167.500004</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>140.273109</td>\n",
       "      <td>0.002738</td>\n",
       "      <td>31.500001</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>86.154155</td>\n",
       "      <td>0.000656</td>\n",
       "      <td>39.999999</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       iv_cdt  vaso_cdt      iv_phy  vaso_phy  die  term\n",
       "0  135.394141  0.003626   90.000004       0.0  0.0     0\n",
       "1   73.345706  0.002740  140.000001       0.0  0.0     0\n",
       "2  171.682522  0.002526  167.500004       0.0  0.0     0\n",
       "3  140.273109  0.002738   31.500001       0.0  0.0     1\n",
       "4   86.154155  0.000656   39.999999       0.0  0.0     1"
      ]
     },
     "execution_count": 221,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_all.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "figure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 222,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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rfr16ys+Pr7cwnvNmjXKz89nzEWV4lRz4ALuuOMOSVJmZqbd/IKCAsXExKhJkyaqW7eu7r33Xh05csRsHzVqlBo3bqyioqIy6+zfv79at25tvk5KSlKPHj3k5eWlevXqqXXr1nruuefM9gtdW7Z792498MADatKkidzd3dW6dWv96U9/MtvLu7ZszZo1ioiIkL+/v2w2m1q2bKkXX3xRxcXFduvu06eP2rdvrx9//FF9+/ZVnTp1dMMNN2ju3LmX7LOsrCyNGTNGTZs2lc1mk5+fn+65554rvsbt97+D/Px8Pf300woICJDNZlPr1q318ssvX/T0benC15Zt27ZNgwYNUoMGDVS3bl117NhRCxYskCS9++67cnJy0vfff19mfX/961/l4uKi//73v5e9LwEBAerVq5f+/e9/l/u3ER8fr5YtWyokJOSy1wkANRnjMOPwlY7D7u7uuu+++5ScnKzDhw+XaY+Pj1f9+vV1991369ixY3rmmWfUoUMH1atXTx4eHho4cKB++OGHMsu98cYbateunerUqaMGDRqoa9euio+Pt4v5/vvvNXDgQHl4eKhevXrq16+ftm7detH+wfWBwhu4gL1790pSmVOQnnjiCf3www+aMWOGHnvsMX388ceKjo4220eMGKGjR49q3bp1dstlZWVpw4YNeuihhyRJ6enpuvPOO1VQUKBZs2bplVde0d13362vvvrqonlt375dISEh2rBhg8aNG6cFCxZo8ODB+vjjjy+6XFxcnOrVq6eYmBgtWLBAwcHBio2N1dSpU8vEHj9+XAMGDFCnTp30yiuvqE2bNpoyZYo+/fTTi25jyJAhWrVqlcaMGaNFixbpySef1IkTJ3TgwIGLLnch5/8ODMPQ3Xffrfnz52vAgAF69dVX1bp1a02ePFkxMTEVXndSUpJ69eqlH3/8UU899ZReeeUV9e3bV2vXrpV07lt/d3d3LV26tMyyS5cuVZ8+fXTDDTdUaJuRkZHl/m3s2LFDO3fu5Jt3ADgP4zDj8NWMw5GRkTp79qxWrFhhN//YsWNat26d7r33Xrm7u2vfvn1avXq17rzzTr366quaPHmyduzYod69e+vgwYPmcn//+9/15JNPKigoSK+99ppeeOEFde7cWdu2bTNj0tPT1bNnT/3www969tln9fzzzyszM1N9+vSxi8N1ygCuc++++64hyfjss8+MI0eOGL/88ouxbNkyo1GjRoa7u7vx66+/2sWFhYUZJSUl5vKTJk0yXFxcjJycHMMwDKO4uNho2rSpMXToULvtvPrqq4aTk5Oxb98+wzAMY/78+YYk48iRIxfMLTMz05BkvPvuu+a8Xr16GfXr1zd+/vlnu9jzcyrNNTMz05x36tSpMut/9NFHjTp16hhnzpwx5/Xu3duQZPzzn/805xUUFBi+vr7GkCFDLpjr8ePHDUnGvHnzLhhzITNmzDAkGRkZGcaRI0eMzMxM429/+5ths9kMHx8fIz8/31i9erUhyfjzn/9st+z9999vODk5GXv27DHnNW/e3Bg1apT5+vPPPzckGZ9//rlhGIZx9uxZIzAw0GjevLlx/Phxu/Wd34/Dhw83/P39jeLiYnPed999V+Z3Up7S38E333xjzjt27Jhhs9mM4cOH28VOnTrV3H8AuN4wDjMOn6+yxuGzZ88afn5+RmhoqN38JUuWGJKMdevWGYZhGGfOnLFbv2Gc+73bbDZj1qxZ5rx77rnHaNeu3UW3OXjwYMPV1dXYu3evOe/gwYNG/fr1jV69el10WdR8HPEG/r+wsDA1adJEAQEBGjZsmOrVq6dVq1aV+TZ1/PjxdjcY6dmzp4qLi/Xzzz9LOncdU2RkpD766CO7u2kuXbpUt912mwIDAyVJXl5eks6delZSUnJZOR45ckSbN2/Www8/rGbNmtm1XeqmJ+7u7ubPJ06c0G+//aaePXvq1KlT2r17t11svXr1zCMCkuTq6qpu3bpp3759F12/q6urNm7cqOPHj1/W/vxe69at1aRJEwUGBurRRx9Vq1atlJCQoDp16uiTTz6Ri4uLnnzySbtlnn76aRmGccmjAOf7/vvvlZmZqYkTJ5q/h1Ln9+PIkSN18OBBff755+a8pUuXyt3dXUOGDKnw/jVo0ECDBg3SRx99pPz8fEmSYRhatmyZunbtqptvvrnC6wSAmoJx+H8Yh8+5mnHYxcVFw4YNU0pKit2p9vHx8fLx8VG/fv0kSTabTc7O50qi4uJiHT161Lzs4LvvvjOX8/Ly0q+//qpvvvmm3O0VFxdr/fr1Gjx4sG688UZzvp+fnx588EF9+eWX1+Qd4lF5KLyB/2/hwoVKSkrS559/rh9//FH79u1TeHh4mbjfD7QNGjSQJLtBbuTIkTp9+rRWrVolScrIyFBqaqpGjBhhxgwdOlS33367HnnkEfn4+GjYsGFasWLFRQf/0gG3ffv2Fd6/9PR03XvvvfL09JSHh4eaNGliDuq5ubl2sU2bNi3zAaJBgwYXHchtNpteeuklffrpp/Lx8VGvXr00d+5cZWVlXXaO//nPf5SUlKSNGzdqz5492rlzp4KDgyVJP//8s/z9/VW/fn27Zdq2bWu2X67SU+cu1Y9/+MMf5OfnZ57mVlJSog8++ED33HNPmTwuV2RkpPLz87VmzRpJ0pYtW7R//35OMwdw3WMc/h/G4XOudhwuHVtLr8P+9ddf9cUXX2jYsGHmze9KSko0f/583XTTTbLZbGrcuLGaNGmi7du32/1epkyZonr16qlbt2666aabFBUVZXdZwpEjR3Tq1Cm7ewiUatu2rUpKSvTLL79cMmfUXBTewP/XrVs3hYWFqU+fPmrbtq357efvXegupcZ5NxYJCgpScHCw3n//fUnS+++/L1dXVz3wwANmjLu7uzZv3qzPPvtMI0aM0Pbt2zV06FD94Q9/KHOjlauVk5Oj3r1764cfftCsWbP08ccfKykpSS+99JIklfmQcTn7WJ6JEyfq//7v/zR79my5ubnp+eefV9u2bcu9MUp5evXqpbCwMPXu3VstW7a8rGWs5OLiogcffFD/+c9/dObMGX3++ec6ePCg3VGIirrzzjvl6elpfgiIj483v5UHgOsZ43DF9rE8jMP2goOD1aZNG33wwQeSyn+CyF//+lfFxMSoV69eev/997Vu3TolJSWpXbt2dr+Xtm3bKiMjQ8uWLVOPHj30n//8Rz169NCMGTMqd6dRY1F4AxYZOXKkNmzYoEOHDik+Pl4RERHmt/KlnJ2d1a9fP7366qv68ccfzedlnn9K1flKT13auXNnhXLZuHGjjh49qri4OD311FO68847FRYWViafytCyZUs9/fTTWr9+vXbu3KnCwkK98sorV73e5s2b6+DBg3anDUoyT89r3rx5hXKULq8fR44cqby8PH388cdaunSpmjRpUu4RmMtls9l0//33a/369crOztbKlSt1xx13yNfX94rXCQAoi3GYcVg6d9R7586d2r59u+Lj43XTTTfp1ltvNdv//e9/q2/fvvrHP/6hYcOGqX///goLC1NOTk6ZddWtW1dDhw7Vu+++qwMHDigiIkJ/+ctfdObMGTVp0kR16tRRRkZGmeV2794tZ2dnBQQEXHbeqHkovAGLDB8+XE5OTnrqqae0b9++Mt/OHjt2rMwynTt3lnTuUSnladKkiXr16qV33nmnzB1KL/YteOk35+fHFBYWatGiRZe1L5fj1KlTOnPmjN28li1bqn79+hfcn4oYNGiQiouL9eabb9rNnz9/vpycnDRw4MDLXleXLl0UGBio1157rczA+vt+7Nixozp27Ki3335b//nPfzRs2DDVqlXrivdDOvchoKioSI8++qiOHDnCaeYAYAHGYcZh6X+nm8fGxiotLa3MmOvi4lJmmytXrizzqLKjR4/avXZ1dVVQUJAMw1BRUZFcXFzUv39/rVmzxu6a8uzsbMXHx6tHjx7y8PC47LxR81zdp0cAF9SkSRMNGDBAK1eulJeXlyIiIuzaZ82apc2bNysiIkLNmzfX4cOHtWjRIjVt2lQ9evS44Hpff/119ejRQ126dNH48eMVGBio/fv3KyEhQWlpaeUuc9ttt6lBgwYaNWqUnnzySTk5Oelf//rXJU9Zq4j/+7//U79+/fTAAw8oKChItWrV0qpVq5SdnV0pp1Hfdddd6tu3r/70pz9p//796tSpk9avX681a9Zo4sSJFTolztnZWYsXL9Zdd92lzp07a8yYMfLz89Pu3buVnp5e5hE0I0eO1DPPPCNJV3WaeanevXuradOmWrNmjfmsUQBA5WIcZhyWpMDAQN12223mvVV+X3jfeeedmjVrlsaMGaPbbrtNO3bs0NKlS+1ukCadewa8r6+vbr/9dvn4+GjXrl168803FRERYV5v/uc//9l8Nvzjjz+uWrVq6W9/+5sKCgou6znsqNkovAELjRw5UmvXrtUDDzwgm81m13b33Xdr//79euedd/Tbb7+pcePG6t27t1544QV5enpecJ2dOnXS1q1b9fzzz2vx4sU6c+aMmjdvbnfd2u81atRIa9eu1dNPP63p06erQYMGeuihh9SvX7+rOm36fAEBARo+fLiSk5P1r3/9S7Vq1VKbNm20YsWKK7oD+O85Ozvro48+UmxsrJYvX653331XLVq00Lx58/T0009XeH3h4eH6/PPP9cILL+iVV15RSUmJWrZsqXHjxpWJjYyM1JQpU9SyZUt169atUvZl+PDhmjdvnu66664rvlEbAODiGIcZh0uX37Jli7p166ZWrVrZtT333HPK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JiZGkuRyubRjxw6vD/S1BUuvXr1syftMjh49qv379ysmJkYJCQlq1aqV19gXFRWppKTEGnt/yf21115TZGSkUlJSzhrnz2MfHx+v6Ohor/H2eDzasmWL13iXlZWpoKDAilm/fr1qamqs/1RwuVzauHGjqqqqrJicnBx1797d9suca4vuTz/9VO+99546dOhwzvcUFhYqMDDQuoTbl/mf6vPPP9fXX3/t9fviz+Nf65VXXlFCQoL69et3ztjGHP9zHS8b6pjjcrm8+qiN8Yc5o7k4n7m5pf+7nO/nmblz5+qxxx5Tdna21/0lWoL6jlmPHj20Y8cOFRYWWsvNN9+sG2+8UYWFhYqLi2vM9H3ifH7Prr32Wu3bt8+rYPzPf/6jmJgYr/t9NFfnM2bfffedAgO9S7za/7j44X5jOFmjHv8b/HZtLczSpUuNw+EwixYtMrt37zbjx483ERERXne19ZUJEyaY8PBwk5eX5/V4nu+++84YY8y+ffvMrFmzzLZt20xxcbF56623TNeuXc2QIUOsPmofjzNs2DBTWFhosrOzzcUXX9woj+R66KGHTF5enikuLjYfffSRSUpKMh07djSHDh0yxvzwaJ/OnTub9evXm23bthmXy2VcLpdf5F7rxIkTpnPnzmbKlCle6/1x7L/99luzfft2s337diPJPPXUU2b79u3WXb/nzJljIiIizFtvvWU++eQTc8stt9T5OLGrrrrKbNmyxXz44Yfmsssu83qcVVlZmYmKijJjx441O3fuNEuXLjWtW7dukMdBnS3/yspKc/PNN5tOnTqZwsJCr7+H2rtNb9q0ycyfP98UFhaa/fv3m7///e/m4osvNnfeeafP8//222/N73//e5Ofn2+Ki4vNe++9Z/r3728uu+wyc/z4casPfx3/WuXl5aZ169ZmwYIFp73f1+N/ruOlMQ1zzKl9bMnkyZPNnj17TFZWFo8Ts8G55uaxY8eaqVOnWvEfffSRCQ4ONk888YTZs2ePmTFjRot8nFh9xmzOnDkmJCTE/OMf//D6m/n22299tQuNrr5jdqqWeFfz+o5ZSUmJadu2rcnIyDBFRUVm1apVJjIy0vz5z3/21S40uvqO2YwZM0zbtm3NG2+8YT777DOzbt06c+mll5pf/epXvtqFRnWuzyNTp041Y8eOteIbc16m8G4Azz33nOncubMJCQkxAwcONJs3b/Z1SsaYH26hX9fy2muvGWN+OJgNGTLEtG/f3jgcDtOtWzczefJkr2dJG2PMgQMHzIgRI0xYWJjp2LGjeeihh0xVVZXt+d92220mJibGhISEmJ/85CfmtttuM/v27bPav//+e/Pb3/7WtGvXzrRu3dr8/Oc/N1999ZVf5F5r7dq1RpIpKiryWu+PY//+++/X+fsybtw4Y8wPjxT705/+ZKKioozD4TBDhw49bb++/vprc/vtt5uLLrrIOJ1Oc/fdd5/2Iezf//63ue6664zD4TA/+clPzJw5c2zPv7i4+Ix/D7XPVS8oKDCJiYkmPDzchIaGmp49e5rHH3/cq7D1Vf7fffedGTZsmLn44otNq1atTJcuXcx999132n/w+ev41/rrX/9qwsLCTFlZ2Wnv9/X4n+t4aUzDHXPef/99c+WVV5qQkBDTtWtXr22g4Zxtbr7++uu9fjeNMWb58uXm8ssvNyEhIeaKK64wq1evbuSMfa8+Y9alS5c6/2ZmzJjR+In7UH1/z07WEgtvY+o/Zps2bTKJiYnG4XCYrl27mv/3//6fqa6ubuSsfas+Y1ZVVWVmzpxpLr30UhMaGmri4uLMb3/7W/PNN980fuI+cK7PI+PGjTPXX3/9ae9pjHk5wBiuOQAAAAAAwC58xxsAAAAAABtReAMAAAAAYCMKbwAAAAAAbEThDQAAAACAjSi8AQAAAACwEYU3AAAAAAA2ovAGAAAAAMBGFN4AAAAAANiIwhsAAAAAABtReAMAAAAAYCMKbwAAAAAAbEThDQAAAACAjf4/rBJpwd3B/n0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x800 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "fig, axs = plt.subplots(2, 2, figsize=(10, 8))\n",
    "\n",
    "axs[0, 0].hist(df_all['iv_cdt'], range=[0, 2000], bins=100)\n",
    "axs[0, 0].set_title('Our Policy IV')\n",
    "\n",
    "axs[0, 1].hist(df_all['vaso_cdt'], range=[0, 1], bins=100)\n",
    "axs[0, 1].set_title('Our Policy Vaso')\n",
    "\n",
    "axs[1, 0].hist(df_all['iv_phy'], range=[0, 2000], bins=100)\n",
    "axs[1, 0].set_title('Physician\\'s Policy IV')\n",
    "\n",
    "axs[1, 1].hist(df_all['vaso_phy'], range=[0, 1], bins=100)\n",
    "axs[1, 1].set_title('Physician\\'s Policy Vaso')\n",
    "\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 223,
   "metadata": {},
   "outputs": [],
   "source": [
    "alive_df = df_all[df_all['die']==0]\n",
    "die_df = df_all[df_all['die']==1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 224,
   "metadata": {},
   "outputs": [],
   "source": [
    "# \n",
    "def make_df_diff(_agent,_phy):\n",
    "    iv_diff = np.array(_agent['iv']) - np.array(_phy['iv'])\n",
    "    vaso_diff = np.array(_agent['vaso']) - np.array(_phy['vaso'])\n",
    "    df_diff = pd.DataFrame()\n",
    "    df_diff['mort'] = np.array(_phy['died_in_hosp'])\n",
    "    df_diff['iv_diff'] = iv_diff\n",
    "    df_diff['vaso_diff'] = vaso_diff\n",
    "    return df_diff"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 225,
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.stats import sem\n",
    "def make_iv_plot_data(df_diff):\n",
    "    bin_medians_iv = []\n",
    "    mort_iv = []\n",
    "    mort_std_iv= []\n",
    "    i = -800\n",
    "    while i <= 1000:\n",
    "        count =df_diff.loc[(df_diff['iv_diff']>i-100) & (df_diff['iv_diff']<i+100)]\n",
    "        try:\n",
    "            res = sum(count['mort'])/float(len(count))\n",
    "            if len(count) >=50:\n",
    "                bin_medians_iv.append(i)\n",
    "                mort_iv.append(res)\n",
    "                mort_std_iv.append(sem(count['mort']))\n",
    "        except ZeroDivisionError:\n",
    "            pass\n",
    "        i += 200\n",
    "    return bin_medians_iv, mort_iv, mort_std_iv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 226,
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.stats import sem\n",
    "def make_vaso_plot_data(df_diff):\n",
    "    bin_medians_vaso = []\n",
    "    mort_vaso= []\n",
    "    mort_std_vaso= []\n",
    "    i = -0.3\n",
    "    while i <= 0.3:\n",
    "        count =df_diff.loc[(df_diff['vaso_diff']>i-0.015) & (df_diff['vaso_diff']<i+0.015)]\n",
    "        try:\n",
    "            res = sum(count['mort'])/float(len(count)) \n",
    "            if len(count) >=50:\n",
    "                bin_medians_vaso.append(i)\n",
    "                mort_vaso.append(res)\n",
    "                mort_std_vaso.append(sem(count['mort']))\n",
    "        except ZeroDivisionError:\n",
    "            pass\n",
    "        i += 0.03\n",
    "    return bin_medians_vaso, mort_vaso, mort_std_vaso "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 227,
   "metadata": {},
   "outputs": [],
   "source": [
    "def sliding_mean(data_array, window=1):\n",
    "    new_list = []\n",
    "    for i in range(len(data_array)):\n",
    "        indices = range(max(i - window + 1, 0),\n",
    "                        min(i + window + 1, len(data_array)))\n",
    "        avg = 0\n",
    "        for j in indices:\n",
    "            avg += data_array[j]\n",
    "        avg /= float(len(indices))\n",
    "        new_list.append(avg)     \n",
    "    return np.array(new_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 228,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.775, -0.03, 'Difference between optimal and physician IV dose')"
      ]
     },
     "execution_count": 228,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA0wAAAGkCAYAAAACFaVxAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAA9hAAAPYQGoP6dpAACjMElEQVR4nOzdd3iUVdrH8e9Mek9I6ARC70VBsCCgoojdddcCa1/Lrq66drdY1oK67q77unZXZVVEZVXsiCgqiiC9994hkEJC6pz3j5NJMiQDSaYm+X2ua8jMM0+558mQZ+4559zHYYwxiIiIiIiISA3OUAcgIiIiIiISrpQwiYiIiIiIeKGESURERERExAslTCIiIiIiIl4oYRIREREREfFCCZOIiIiIiIgXSphERERERES8UMIkIiIiIiLihRImERERERERL5QwiYiIiDQTZWVl3H333WRmZuJ0OrngggsAcDgcPPjggw3aZ1ZWFlddddVR13v99ddxOBxs2rSpQccRCRUlTCI+OO+884iPjyc/P9/rOuPHjyc6Oprs7OwgRiYiIo2ZO7mYN28eAAMGDKBjx44YY7xuc9JJJ9G6dWvKysq8rvPqq6/yt7/9jV/+8pdMnDiRP/zhD36PXaSpUcIk4oPx48dz6NAhPvjgg1qfLywsZOrUqZx55pmkp6cHOToREWkqxo8fz9atW/n+++9rfX7Tpk3Mnj2bSy65hMjISK/7+frrr2nfvj3//Oc/ufzyyxk5cqTPsa1evZqXX37Z5/2IhCslTCI+OO+880hKSmLSpEm1Pj916lQKCgoYP358kCPzjTGGQ4cOhTqMeikoKAh1CCIiATNu3DgcDofX683bb7+NMeao15s9e/aQmprq19hiYmKIiory6z5FwokSJhEfxMXF8Ytf/IIZM2awZ8+eGs9PmjSJpKQkhg8fzp133kn//v1JTEwkOTmZsWPHsnjx4hrbPPPMM/Tt25f4+HjS0tIYMmRIjQvkwoULGTt2LMnJySQmJnLaaafx008/eazj7s7x3XffccMNN5Cenk5ycjJXXHEFBw4c8Fg3KyuLc845h2nTpjFkyBDi4uJ48cUXAcjJyeG2224jMzOTmJgYunXrxhNPPIHL5fLYx+TJkxk8eDBJSUkkJyfTv39//vWvf1U+X1paykMPPUT37t2JjY0lPT2d4cOHM336dI/9fP3115x88skkJCSQmprK+eefz8qVKz3WefDBB3E4HKxYsYJx48aRlpbG8OHDAdi1axdXX301HTp0ICYmhrZt23L++eerz7yINGqZmZmMGDGCKVOmUFpaWuP5SZMm0bVrV4YNG1br9ps2bcLhcPDNN9+wfPlyHA4HDoeDmTNn1rr+VVddRVZWVo3l7r+/1dU2hmn58uWceuqpxMXF0aFDBx555JEa1w2AefPmMWbMGDIyMoiLi6Nz585cc801tZ8EkRDx3mYrInUyfvx4Jk6cyLvvvsvNN99cuXz//v1MmzaNyy67jJ07d/Lhhx/yq1/9is6dO7N7925efPFFRo4cyYoVK2jXrh0AL7/8Mrfccgu//OUvufXWWykqKmLJkiXMmTOHcePGAfYidPLJJ5OcnMzdd99NVFQUL774IqNGjeLbb7+tcbG8+eabSU1N5cEHH2T16tU8//zzbN68mZkzZ3pc9FavXs1ll13GDTfcwHXXXUfPnj0pLCxk5MiRbN++nRtuuIGOHTvy448/ct9997Fz506efvppAKZPn85ll13GaaedxhNPPAHAypUr+eGHH7j11lsBe5GdMGECv/nNbxg6dCh5eXnMmzePBQsWcPrppwPw1VdfMXbsWLp06cKDDz7IoUOHeOaZZzjppJNYsGBBjYv3r371K7p3785jjz1W2a//oosuYvny5fz+978nKyuLPXv2MH36dLZs2VLrxV9EpLEYP348119/PdOmTeOcc86pXL506VKWLVvG/fff73Xbli1b8sYbb/Doo49y8OBBJkyYAEDv3r39HueuXbs45ZRTKCsr49577yUhIYGXXnqJuLg4j/X27NnDGWecQcuWLbn33ntJTU1l06ZNvP/++36PScQnRkR8UlZWZtq2bWtOOOEEj+UvvPCCAcy0adNMUVGRKS8v93h+48aNJiYmxvz1r3+tXHb++eebvn37HvF4F1xwgYmOjjbr16+vXLZjxw6TlJRkRowYUbnstddeM4AZPHiwKSkpqVz+5JNPGsBMnTq1clmnTp0MYL744guPYz388MMmISHBrFmzxmP5vffeayIiIsyWLVuMMcbceuutJjk52ZSVlXmNe+DAgebss88+4msbNGiQadWqlcnOzq5ctnjxYuN0Os0VV1xRueyBBx4wgLnssss8tj9w4IABzN/+9rcjHkdEJNy5/4b//PPPlcv2799vYmJiavztu/feew1gVq9efdT9jhw5stbrDGAeeOCBysdXXnml6dSpU4313H9/q+vUqZO58sorKx/fdtttBjBz5sypXLZnzx6TkpJiALNx40ZjjDEffPBBjdcoEo7UJU/ERxEREVx66aXMnj3bo9vXpEmTaN26NaeddhoxMTE4nfa/W3l5OdnZ2SQmJtKzZ08WLFhQuU1qairbtm3j559/rvVY5eXlfPnll1xwwQV06dKlcnnbtm0ZN24cs2bNIi8vz2Ob66+/3qNv+W9/+1siIyP57LPPPNbr3LkzY8aM8Vj23nvvcfLJJ5OWlsa+ffsqb6NHj6a8vJzvvvuuMu6CgoIa3euqS01NZfny5axdu7bW53fu3MmiRYu46qqraNGiReXyAQMGcPrpp9eIF+DGG2/0eBwXF0d0dDQzZ86s0e1QRKSxS0tL46yzzuKjjz6qHLdpjGHy5MkMGTKEHj16hDhC67PPPuP4449n6NChlctatmxZY3yVeyzVJ598Ums3Q5FwoYRJxA/cFwH3WKNt27bx/fffc+mllxIREYHL5eKf//wn3bt3JyYmhoyMDFq2bMmSJUvIzc2t3M8999xDYmIiQ4cOpXv37tx000388MMPlc/v3buXwsJCevbsWSOG3r1743K52Lp1q8fy7t27ezxOTEykbdu2Ncb0dO7cucY+165dyxdffEHLli09bqNHjwaoHLf1u9/9jh49ejB27Fg6dOjANddcwxdffOGxr7/+9a/k5OTQo0cP+vfvz1133cWSJUsqn9+8eTOA19e2b9++GoUdDo85JiaGJ554gs8//5zWrVszYsQInnzySXbt2lVjnyIijdH48eMpKChg6tSpAPz4449s2rQprIoLbd68uca1B2r+fR85ciQXXXQRDz30EBkZGZx//vm89tprFBcXBytUkTpRwiTiB4MHD6ZXr168/fbbQM1qRY899hi33347I0aM4M0332TatGlMnz6dvn37egyC7d27N6tXr2by5MkMHz6c//3vfwwfPpwHHngg4K/h8L7lAC6Xi9NPP53p06fXervooosAaNWqFYsWLeKjjz7ivPPO45tvvmHs2LFceeWVlfsaMWIE69ev59VXX6Vfv3688sorHHvssbzyyit+jfm2225jzZo1TJgwgdjYWP7yl7/Qu3dvFi5c2ODjiIiEi3POOYeUlJTKL+gmTZpU2dPBnw4v7OBWXl7u12NMmTKF2bNnc/PNN7N9+3auueYaBg8ezMGDB/12HBFfKWES8ZPx48ezbNkylixZwqRJk+jevTvHHXccAFOmTOGUU07hP//5D5deeilnnHEGo0ePJicnp8Z+EhISuOSSS3jttdfYsmULZ599No8++ihFRUW0bNmS+Ph4Vq9eXWO7VatW4XQ6yczM9Fh+eBe4gwcPsnPnzjoVQOjatSsHDx5k9OjRtd46duxYuW50dDTnnnsuzz33HOvXr+eGG27gv//9L+vWratcp0WLFlx99dW8/fbbbN26lQEDBlTOLN+pUycAr68tIyODhISEo8bsjvuOO+7gyy+/ZNmyZZSUlPD3v/+9TtuKiISzmJgYfvnLX/Lll1+ye/du3nvvPU499VTatGnj1+OkpaXVeo1y9wY4kk6dOtXa/bq2v+8Axx9/PI8++ijz5s3jrbfeYvny5UyePLneMYsEihImET9xtybdf//9LFq0yKN7RERERI3Z2d977z22b9/usSw7O9vjcXR0NH369MEYQ2lpKREREZxxxhlMnTrVo0vd7t27mTRpEsOHDyc5OdljHy+99JJH3/Dnn3+esrIyxo4de9TXdPHFFzN79mymTZtW47mcnJzK2eQPj9vpdDJgwACAyq4Vh6+TmJhIt27dKp9v27YtgwYNYuLEiR4X6WXLlvHll19y1llnHTXewsJCioqKPJZ17dqVpKQkdfEQkSZj/PjxlJaWcsMNN7B3796AdMfr2rUrubm5Hl2nd+7c6XWi9urOOussfvrpJ+bOnVu5bO/evbz11lse6x04cKDGtXHQoEEA+pstYUVlxUX8pHPnzpx44omV/cqrX8DOOecc/vrXv3L11Vdz4oknsnTpUt566y2Pwg0AZ5xxBm3atOGkk06idevWrFy5kn//+9+cffbZJCUlAfDII48wffp0hg8fzu9+9zsiIyN58cUXKS4u5sknn6wRV0lJCaeddhoXX3wxq1ev5rnnnmP48OGcd955R31Nd911Fx999BHnnHMOV111FYMHD6agoIClS5cyZcoUNm3aREZGBr/5zW/Yv38/p556Kh06dGDz5s0888wzDBo0qLJkbZ8+fRg1ahSDBw+mRYsWzJs3jylTpniUYv/b3/7G2LFjOeGEE7j22msry4qnpKRUtkQdyZo1aypfa58+fYiMjOSDDz5g9+7dfu+uIiISKiNHjqRDhw5MnTq1cj5Af7v00ku55557uPDCC7nlllsoLCzk+eefp0ePHh7Fimpz991388Ybb3DmmWdy6623VpYV79Spk0cCNnHiRJ577jkuvPBCunbtSn5+Pi+//DLJycl1+pJMJGhCWqNPpIl59tlnDWCGDh3qsbyoqMjccccdpm3btiYuLs6cdNJJZvbs2WbkyJFm5MiRleu9+OKLZsSIESY9Pd3ExMSYrl27mrvuusvk5uZ67G/BggVmzJgxJjEx0cTHx5tTTjnF/Pjjjx7ruEvSfvvtt+b66683aWlpJjEx0YwfP96jbLcxtiSst5Lf+fn55r777jPdunUz0dHRJiMjw5x44onmqaeeqixXPmXKFHPGGWeYVq1amejoaNOxY0dzww03mJ07d1bu55FHHjFDhw41qampJi4uzvTq1cs8+uijHiXPjTHmq6++MieddJKJi4szycnJ5txzzzUrVqzwWMdd1nbv3r0ey/ft22duuukm06tXL5OQkGBSUlLMsGHDzLvvvlvraxMRCVe1lRWv7q677jKAufjii+u137qWFTfGmC+//NL069fPREdHm549e5o333yzTmXFjTFmyZIlZuTIkSY2Nta0b9/ePPzww+Y///mPR1nxBQsWmMsuu8x07NjRxMTEmFatWplzzjnHzJs3r16vSSTQHMYc1hYqIk3C66+/ztVXX83PP//MkCFDQh2OiIiISKOkMUwiIiIiIiJeKGESERERERHxQgmTiIiIiIiIFxrDJCIiIiIi4oVamERERERERLxQwiQiIiIiIuKFJq4NEJfLxY4dO0hKSsLhcIQ6HBGRZsMYQ35+Pu3atcPpDM33groGiIiEjr+vA0qYAmTHjh1kZmaGOgwRkWZr69atdOjQISTH1jVARCT0/HUdUMIUIElJSYD9RSUnJ9dr29LSUr788kvOOOMMoqKiAhFeo6Fz4Unno4rOhSedjyr79++nc+fOlX+HQ8GXawCE/+9T8flG8flG8fkm3OMD32PMy8sjMzPTb9cBJUwB4u6CkZyc3KCEKT4+nuTk5LB9IweLzoUnnY8qOheedD6qlJaWAoS0K5wv1wAI/9+n4vON4vON4vNNuMcH/ovRX9cBFX0QERERERHxQgmTiIiIiIiIF0qYREREREREvFDCJCIiIiIi4oUSJhERERERES+U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iyQiItLUORy2FSY+AVq3P/r6rnI4mH+EBCvPrnfsSTbBqZ7wHJ4ERUUH7GWJiASDEiYRERHx5IywY4GSU6G2/Mrdpeyq29WlTESaPOfRVxEREREREWmelDCJiIiIiIh4oYRJRERERETECyVMIiIiIiIiXihhEhERERER8UIJk4iIiIiIiBdKmERERERERLxQwiQiIiIiIuKFEiYREREREREvlDCJiIiIiIh4oYRJRERERETEi8hQB9BUGWMAyMvLq/e2paWlFBYWkpeXR1RUlL9Da1R0LjzpfFTRufCk81ElPz8fqPo7HAq+XAMg/H+fis83is83is834R4f+B6j+2+vv64DSpgCxH3BzszMDHEkIiLNU3Z2NikpKSE5tq4BIiKhl5+f75frgMOE8iu4JszlcrFjxw6SkpJwOBz12jYvL4/MzEy2bt1KcnJygCJsHHQuPOl8VNG58KTzUSU3N5eOHTty4MABUlNTQxKDL9cACP/fp+LzjeLzjeLzTbjHB77HaIwhPz+fdu3a4XT6PgJJLUwB4nQ66dChg0/7SE5ODts3crDpXHjS+aiic+FJ56OKPy6Svhzb12sAhP/vU/H5RvH5RvH5JtzjA99i9GcPAxV9EBERERER8UIJk4iIiIiIiBdKmMJQTEwMDzzwADExMaEOJeR0LjzpfFTRufCk81GlKZyLcH8Nis83is83is834R4fhF+MKvogIiIiIiLihVqYREREREREvFDCJCIiIiIi4oUSJhERERERES+UMImIiIiIiHihhCkM7N+/n/Hjx5OcnExqairXXnstBw8ePOI2N9xwA127diUuLo6WLVty/vnns2rVqiBFHFj1PR/79+/n97//PT179iQuLo6OHTtyyy23kJubG8SoA6Mh742XXnqJUaNGkZycjMPhICcnJzjBBsCzzz5LVlYWsbGxDBs2jLlz5x5x/ffee49evXoRGxtL//79+eyzz4IUaXDU53wsX76ciy66iKysLBwOB08//XTwAg2C+pyLl19+mZNPPpm0tDTS0tIYPXr0Ud9LwbJmzRrOP/98MjIySE5OZvjw4XzzzTce62zZsoWzzz6b+Ph4WrVqxV133UVZWZnHOjNnzuTYY48lJiaGbt268frrr/stxk8//ZRhw4YRFxdHWloaF1xwQVjFB1BcXMygQYNwOBwsWrTI47klS5Zw8sknExsbS2ZmJk8++WSN7QP1t2PTpk1ce+21dO7cmbi4OLp27coDDzxASUlJ2MRYm/r+7fWHCRMmcNxxx5GUlESrVq244IILWL16tcc6RUVF3HTTTaSnp5OYmMhFF13E7t27Pdapy/vRHx5//HEcDge33XZb2MS3fft2fv3rX5Oenk5cXBz9+/dn3rx5lc8bY7j//vtp27YtcXFxjB49mrVr13rsoyGfO+qivLycv/zlLx7/Fx5++GGq154LZXxHZSTkzjzzTDNw4EDz008/me+//95069bNXHbZZUfc5sUXXzTffvut2bhxo5k/f74599xzTWZmpikrKwtS1IFT3/OxdOlS84tf/MJ89NFHZt26dWbGjBmme/fu5qKLLgpi1IHRkPfGP//5TzNhwgQzYcIEA5gDBw4EJ1g/mzx5somOjjavvvqqWb58ubnuuutMamqq2b17d63r//DDDyYiIsI8+eSTZsWKFebPf/6ziYqKMkuXLg1y5IFR3/Mxd+5cc+edd5q3337btGnTxvzzn/8MbsABVN9zMW7cOPPss8+ahQsXmpUrV5qrrrrKpKSkmG3btgU58pq6d+9uzjrrLLN48WKzZs0a87vf/c7Ex8ebnTt3GmOMKSsrM/369TOjR482CxcuNJ999pnJyMgw9913X+U+NmzYYOLj483tt99uVqxYYZ555hkTERFhvvjiC5/jmzJliklLSzPPP/+8Wb16tVm+fLl55513Kp8PdXxut9xyixk7dqwBzMKFCyuX5+bmmtatW5vx48ebZcuWmbffftvExcWZF198sXKdQP7t+Pzzz81VV11lpk2bZtavX2+mTp1qWrVqZe64446wifFw9f3/5S9jxowxr732mlm2bJlZtGiROeuss0zHjh3NwYMHK9e58cYbTWZmppkxY4aZN2+eOf74482JJ55Y+Xxd3o/+MHfuXJOVlWUGDBhgbr311rCIb//+/aZTp07mqquuMnPmzDEbNmww06ZNM+vWratc5/HHHzcpKSnmww8/NIsXLzbnnXee6dy5szl06FDlOg353FEXjz76qElPTzeffPKJ2bhxo3nvvfdMYmKi+de//hUW8R2NEqYQW7FihQHMzz//XLns888/Nw6Hw2zfvr3O+1m8eLEBPP5jNEb+Oh/vvvuuiY6ONqWlpYEIMyh8PRfffPNNo06Yhg4dam666abKx+Xl5aZdu3ZmwoQJta5/8cUXm7PPPttj2bBhw8wNN9wQ0DiDpb7no7pOnTo1qYTJl3NhjP3QkpSUZCZOnBioEOtk7969BjDfffdd5bK8vDwDmOnTpxtjjPnss8+M0+k0u3btqlzn+eefN8nJyaa4uNgYY8zdd99t+vbt67HvSy65xIwZM8an+EpLS0379u3NK6+84nWdUMZXPYZevXqZ5cuX10iYnnvuOZOWllYZizHG3HPPPaZnz56Vj4P9t+PJJ580nTt3DtsYff3/5S979uwxgPn222+NMcbk5OSYqKgo895771Wus3LlSgOY2bNnG2Pq9n70VX5+vunevbuZPn26GTlyZGXCFOr47rnnHjN8+HCvz7tcLtOmTRvzt7/9rXJZTk6OiYmJMW+//bYxxn+fwWpz9tlnm2uuucZj2S9+8Qszfvz4sIjvaNQlL8Rmz55NamoqQ4YMqVw2evRonE4nc+bMqdM+CgoKeO211+jcuTOZmZmBCjUo/HE+AHJzc0lOTiYyMjIQYQaFv85FY1RSUsL8+fMZPXp05TKn08no0aOZPXt2rdvMnj3bY32AMWPGeF2/MWnI+Wiq/HEuCgsLKS0tpUWLFoEKs07S09Pp2bMn//3vfykoKKCsrIwXX3yRVq1aMXjwYMC+r/v370/r1q0rtxszZgx5eXksX768cp1AvPcXLFjA9u3bcTqdHHPMMbRt25axY8eybNmyynVCGR/A7t27ue6663jjjTeIj4+v8fzs2bMZMWIE0dHRHsdevXo1Bw4cCHh8tcnNzfV474VTjOH0t8bdrd59rubPn09paalHbL169aJjx46VsdXl/eirm266ibPPPrvG7yPU8X300UcMGTKEX/3qV7Rq1YpjjjmGl19+ufL5jRs3smvXLo/4UlJSGDZsmEd8gfrcceKJJzJjxgzWrFkDwOLFi5k1axZjx44Ni/iORglTiO3atYtWrVp5LIuMjKRFixbs2rXriNs+99xzJCYmkpiYyOeff8706dM9/uA2Rr6cD7d9+/bx8MMPc/311wcixKDxx7lorPbt20d5ebnHRQWgdevWXl/7rl276rV+Y9KQ89FU+eNc3HPPPbRr167GB55gczgcfPXVVyxcuJCkpCRiY2P5xz/+wRdffEFaWhrg/X3tfu5I6+Tl5XHo0KEGx7dhwwYAHnzwQf785z/zySefkJaWxqhRo9i/f3/I4zPGcNVVV3HjjTd6fICqzpf4AvF/a926dTzzzDPccMMNYRljuPytcblc3HbbbZx00kn069cPsOcgOjqa1NRUr7HV5Vz6YvLkySxYsIAJEybUeC7U8W3YsIHnn3+e7t27M23aNH77299yyy23MHHiRI/9H+l3G8jPHffeey+XXnopvXr1IioqimOOOYbbbruN8ePHh0V8R6OEKUDuvfdeHA7HEW++FmkYP348Cxcu5Ntvv6VHjx5cfPHFFBUV+ekV+FcwzgdAXl4eZ599Nn369OHBBx/0PfAACNa5EJGaHn/8cSZPnswHH3xAbGxsQI5R1//jxhhuuukmWrVqxffff8/cuXO54IILOPfcc9m5c2dAYqtPfC6XC4A//elPXHTRRQwePJjXXnsNh8PBe++9F/L4nnnmGfLz87nvvvsCFouvMVa3fft2zjzzTH71q19x3XXXBT3mxuSmm25i2bJlTJ48OdShVNq6dSu33norb731VsD+dvjC5XJx7LHH8thjj3HMMcdw/fXXc9111/HCCy+EOjQA3n33Xd566y0mTZrEggULmDhxIk899VRlQhfuGm9/pTB3xx13cNVVVx1xnS5dutCmTRv27NnjsbysrIz9+/fTpk2bI26fkpJCSkoK3bt35/jjjyctLY0PPviAyy67zNfw/S4Y5yM/P58zzzyTpKQkPvjgA6KionwNOyCCcS4au4yMDCIiImpUF9q9e7fX196mTZt6rd+YNOR8NFW+nIunnnqKxx9/nK+++ooBAwYELMa6/h//+uuv+eSTTzhw4ADJycmA7Tkwffp0Jk6cyL333kubNm1qVChzv3b36/X23k9OTiYuLq7B8bmTtj59+lQuj4mJoUuXLmzZsqXy2KGK7+uvv2b27NnExMR4PDdkyBDGjx/PxIkTvR67LvEd6f1U1xjdduzYwSmnnMKJJ57ISy+95LFeoGJsiHD4W3PzzTfzySef8N1339GhQ4fK5W3atKGkpIScnByPVpzqsdXl/dhQ8+fPZ8+ePRx77LGVy8rLy/nuu+/497//zbRp00IaX9u2bT3+rwL07t2b//3vfx773717N23btvU4/qBBgyrXCdTnjrvuuquylQmgf//+bN68mQkTJnDllVeGPL6jCugIKTkq9wC2efPmVS6bNm1avQewFRUVmbi4OPPaa68FIMrgaej5yM3NNccff7wZOXKkKSgoCEaoAefre6MpFH24+eabKx+Xl5eb9u3bH7HowznnnOOx7IQTTmhSRR/qcz6qa4pFH+p7Lp544gmTnJxcOfg6HHz00UfG6XSa/Px8j+U9evQwjz76qDGmapB49QplL774oklOTjZFRUXGGFtUoV+/fh77uOyyy3wuqpCbm2tiYmI8ij6UlJSYVq1aVVZwC2V8mzdvNkuXLq28TZs2zQBmypQpZuvWrcaYqoIKJSUlldvdd999NQoqBPJvx7Zt20z37t3NpZdeWmsl23CIsTpf/tb4wuVymZtuusm0a9fOrFmzpsbz7qIKU6ZMqVy2atWqWosqHOn92FB5eXke77elS5eaIUOGmF//+tdm6dKlIY/vsssuq1H04bbbbjMnnHCCMaaqqMJTTz1V+bz7//jhRRV8/UxamxYtWpjnnnvOY9ljjz1munfvHhbxHY0SpjBw5plnmmOOOcbMmTPHzJo1y3Tv3t2jROK2bdtMz549zZw5c4wxxqxfv9489thjZt68eWbz5s3mhx9+MOeee65p0aJFwMt+BkN9z0dubq4ZNmyY6d+/v1m3bp3ZuXNn5a2xl1mv77kwxpidO3eahQsXmpdffrmyAtfChQtNdnZ2KF5Cg02ePNnExMSY119/3axYscJcf/31JjU1tbK60OWXX27uvffeyvV/+OEHExkZaZ566imzcuVK88ADDzS5suL1OR/FxcVm4cKFZuHChaZt27bmzjvvNAsXLjRr164N1Uvwm/qei8cff9xER0ebKVOmePx9ODxRCba9e/ea9PR084tf/MIsWrTIrF692tx5550mKirKLFq0yBhTVYb4jDPOMIsWLTJffPGFadmyZa1lu++66y6zcuVK8+yzz/qtbPett95q2rdvb6ZNm2ZWrVplrr32WtOqVSuzf//+sIivuo0bN9aokpeTk2Nat25tLr/8crNs2TIzefJkEx8fX6Nkd6D+dmzbts1069bNnHbaaWbbtm0e779wifFwR/v/FSi//e1vTUpKipk5c6bHeSosLKxc58YbbzQdO3Y0X3/9tZk3b5454YQTKhMCY+r2fvSn6lXyQh3f3LlzTWRkpHn00UfN2rVrzVtvvWXi4+PNm2++WbnO448/blJTU83UqVPNkiVLzPnnn19r2e4jfe5oqCuvvNK0b9++sqz4+++/bzIyMszdd98dFvEdjRKmMJCdnW0uu+wyk5iYaJKTk83VV1/tcSF3XwS++eYbY4wx27dvN2PHjjWtWrUyUVFRpkOHDmbcuHFm1apVIXoF/lXf8+FuSanttnHjxtC8CD+p77kwxpgHHnig1nPRGFsfn3nmGdOxY0cTHR1thg4dan766afK50aOHGmuvPJKj/Xfffdd06NHDxMdHW369u1rPv300yBHHFj1OR/u98bht5EjRwY/8ACoz7no1KlTrefigQceCH7gh/n555/NGWecYVq0aGGSkpLM8ccfbz777DOPdTZt2mTGjh1r4uLiTEZGhrnjjjtqTJnwzTffmEGDBpno6GjTpUsXv/1/LykpMXfccYdp1aqVSUpKMqNHjzbLli0Lm/iqqy1hMsZOuzF8+HATExNj2rdvbx5//PEa2wbqb8drr73m9foULjHW5kj/vwLF23mq/l45dOiQ+d3vfmfS0tJMfHy8ufDCCz2ST2Pq9n70l8MTplDH9/HHH5t+/fqZmJgY06tXL/PSSy95PO9yucxf/vIX07p1axMTE2NOO+00s3r1ao91jva5o6Hy8vLMrbfeajp27GhiY2NNly5dzJ/+9CePcuqhjO9oHMZUm2JXREREREREKqlKnoiIiIiIiBdKmERERERERLxQwiQiIiIiIuKFEiYREREREREvlDCJiIiIiIh4oYRJRERERETECyVMIiIiIiIiXihhEhERERER8UIJk4iIiIiIiBdKmERERERERLxQwiQiIiIiIuKFEiYREREREREvlDCJiIiIiIh4oYRJRERERETECyVMIiIiIiIiXihhEhERERER8UIJk4iIiIiIiBdKmERERERERLwIWMLkcDj48MMPKx+vWrWK448/ntjYWAYNGuR1WVPy+uuvk5qaGuowmqRNmzbhcDhYtGhRkzhObR588EGf/18E+j04c+ZMHA4HOTk5dVp/1KhR3HbbbQGLR0InKyuLp59+OtRhNDu61upaG0i61taNrrX+Vd/XGwz1SpiuuuoqHA4HDoeDqKgoWrduzemnn86rr76Ky+XyWHfnzp2MHTu28vEDDzxAQkICq1evZsaMGV6XSU2HXxCbm6uuuooLLrjAY1lmZiY7d+6kX79+oQlKADjxxBPZuXMnKSkpdVr//fff5+GHHw5wVCKNm661oaFrra614Spcr7Xu/zO7d+8mKiqKyZMn17retddey7HHHhvweAKp3i1MZ555Jjt37mTTpk18/vnnnHLKKdx6662cc845lJWVVa7Xpk0bYmJiKh+vX7+e4cOH06lTJ9LT070uq6+SkpIGbSeNW0REBG3atCEyMjLUoTRr0dHRtGnTBofDUaf1W7RoQVJSUoCjapzC8W9ZaWlpqENotnStlXCga214CPdrbevWrTn77LN59dVXazxXUFDAu+++y7XXXhu0eAKh3glTTEwMbdq0oX379hx77LH88Y9/ZOrUqXz++ee8/vrrletV/6bG4XAwf/58/vrXv+JwOHjwwQdrXQawdetWLr74YlJTU2nRogXnn38+mzZtqtyv+xuQRx99lHbt2tGzZ896bffUU0/Rtm1b0tPTuemmmzw+EBQXF3PPPfeQmZlJTEwM3bp14z//+U/l88uWLWPs2LEkJibSunVrLr/8cvbt23fUc/bhhx/SvXt3YmNjGTNmDFu3bvV4furUqRx77LHExsbSpUsXHnroocoLYlZWFgAXXnghDoeDrKwscnNziYiIYN68eQC4XC5atGjB8ccfX7nPN998k8zMzMrHRzs/AK+88gq9e/cmNjaWXr168dxzz1U+524uf//99znllFOIj49n4MCBzJ49+4ivfcuWLZx//vkkJiaSnJzMxRdfzO7duyufdzeFv/jii2RmZhIfH8/FF19Mbm5u5fMTJ05k6tSpld+4zpw5s0bzvbv5dtq0aRxzzDHExcVx6qmnsmfPHj7//HN69+5NcnIy48aNo7CwsPL4X3zxBcOHDyc1NZX09HTOOecc1q9ff8TXdLg33niDIUOGkJSURJs2bRg3bhx79uypfN4d24wZMxgyZAjx8fGceOKJrF692mM/jz/+OK1btyYpKYlrr72WoqKiIx7Xvd9PP/2UAQMGEBsby/HHH8+yZctqrDtt2jR69+5NYmJi5QcxgO+++46oqCh27drlsf5tt93GySefDMDmzZs599xzSUtLIyEhgb59+/LZZ595xFC92fyHH35g1KhRxMfHk5aWxpgxYzhw4ABQs5uAv85ddSeeeCL33HOPx7K9e/cSFRXFd999V6fjHjhwgPHjx9OyZUvi4uLo3r07r732WuXzS5cu5dRTTyUuLo709HSuv/56Dh48WPm8++/NQw89RMuWLUlOTubGG2/0+NA5atQobr75Zm677TYyMjIYM2YMcPS/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",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "_agent = pd.DataFrame(columns=['iv','vaso'])\n",
    "_phy = pd.DataFrame(columns=['iv','vaso','died_in_hosp'])\n",
    "\n",
    "_agent['iv']= df_all['iv_cdt']\n",
    "_agent['vaso']= df_all['vaso_cdt']\n",
    "\n",
    "_phy['iv']= df_all['iv_phy']\n",
    "_phy['vaso']= df_all['vaso_phy']\n",
    "_phy['died_in_hosp'] = df_all['die']\n",
    "\n",
    "df_diff_CDT = make_df_diff(_agent,_phy)\n",
    "bin_med_iv_CDT, mort_iv_CDT, mort_std_iv_CDT = make_iv_plot_data(df_diff_CDT)\n",
    "bin_med_vaso_CDT, mort_vaso_CDT, mort_std_vaso_CDT = make_vaso_plot_data(df_diff_CDT)\n",
    "\n",
    "f, (ax1,ax2) = plt.subplots(1, 2, sharex='col', sharey='row', figsize = (8,4))\n",
    "ax1.plot(bin_med_vaso_CDT, sliding_mean(mort_vaso_CDT), color='r')\n",
    "ax1.fill_between(bin_med_vaso_CDT, sliding_mean(mort_vaso_CDT) - 1*mort_std_vaso_CDT,  \n",
    "                 sliding_mean(mort_vaso_CDT) + 1*mort_std_vaso_CDT, color='tomato')\n",
    "ax1.set_title('Vasopressors')\n",
    "x_r = [i/100.0 for i in range(-30,30,10)]\n",
    "y_r = [float(i)/10.0 for i in range(0,100,1)]\n",
    "ax1.set_xticks(x_r)\n",
    "ax1.set_yticks(y_r)\n",
    "ax1.grid()\n",
    "\n",
    "ax2.plot(bin_med_iv_CDT, sliding_mean(mort_iv_CDT), color='r')\n",
    "ax2.fill_between(bin_med_iv_CDT, sliding_mean(mort_iv_CDT) - 1*mort_std_iv_CDT,  \n",
    "                 sliding_mean(mort_iv_CDT) + 1*mort_std_iv_CDT, color='tomato')\n",
    "ax2.set_title('IV fluids')\n",
    "x_iv = [i for i in range(-800,900,200)]\n",
    "ax2.set_xticks(x_iv)\n",
    "ax2.grid()\n",
    "\n",
    "plt.tight_layout()\n",
    "f.text(0.225, -0.03, 'Difference between optimal and physician vasopressor dose', ha='center', fontsize=10)\n",
    "f.text(0.775, -0.03, 'Difference between optimal and physician IV dose', ha='center', fontsize=10)\n",
    "# f.text(-0.02, 0.5, 'Observed Mortality', va='center', rotation='vertical', fontsize = 10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 229,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "800 -800\n",
      "0.14999999999999997 -0.3\n"
     ]
    }
   ],
   "source": [
    "print(max(bin_med_iv_CDT),min(bin_med_iv_CDT))\n",
    "print(max(bin_med_vaso_CDT),min(bin_med_vaso_CDT))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 230,
   "metadata": {},
   "outputs": [],
   "source": [
    "# sudden change\n",
    "\n",
    "def sudden_change_and_too_high(df,item_vaso,item_iv,ifdie,max_sudden_change_vaso_data,max_sudden_change_iv_data,too_high_iv,too_high_vaso):\n",
    "    delta_iv = []\n",
    "    delta_vaso = []\n",
    "    a = []\n",
    "    b = []\n",
    "    a_iv_delta,a_vaso_delta = 0.0,0.0\n",
    "\n",
    "    for i in df.index:\n",
    "        if df.loc[i,'die'] ==ifdie  or i == 0:\n",
    "            continue\n",
    "        if df.loc[i-1,'term'] == False:\n",
    "\n",
    "            a_vaso_delta = max(df.loc[i,item_vaso] - df.loc[i-1,item_vaso],a_vaso_delta)\n",
    "            a_iv_delta = max(df.loc[i,item_iv] - df.loc[i-1,item_iv],a_iv_delta)\n",
    "            a.append(df.loc[i,item_vaso])\n",
    "            b.append(df.loc[i,item_iv])\n",
    "\n",
    "        elif df.loc[i-1,'term'] == True:\n",
    "            delta_iv.append(a_iv_delta)\n",
    "            delta_vaso.append(a_vaso_delta)\n",
    "            a_iv_delta,a_vaso_delta = 0.0,0.0\n",
    "\n",
    "    if ifdie:\n",
    "        print(\"die\")\n",
    "    else:\n",
    "        print(\"alive\")\n",
    "    print(\"change_vaso>\",max_sudden_change_vaso_data,\":\",sum(value > max_sudden_change_vaso_data for value in delta_vaso)/len(delta_vaso))\n",
    "    print(\"change_iv>\",max_sudden_change_iv_data,\":\",sum(value > max_sudden_change_iv_data for value in delta_iv)/len(delta_iv))\n",
    "    print(\"-------\"*10)\n",
    "    print(\"too high vaso>:\",too_high_vaso,\":\",sum(value > too_high_vaso for value in a)/len(a))\n",
    "\n",
    "    print(\"too high iv>:\",too_high_iv,\":\",sum(value > too_high_iv for value in b)/len(b))\n",
    "    print(\"-****---\"*10)\n",
    "\n",
    "    return delta_iv,delta_vaso,a,b"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 231,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "die\n",
      "change_vaso> 0.9 : 0.0066068900424728644\n",
      "change_iv> 1000 : 0.09627182633317603\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.010783580621039788\n",
      "too high iv>: 1000 : 0.062025266637805505\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "alive\n",
      "change_vaso> 0.9 : 0.0328515111695138\n",
      "change_iv> 1000 : 0.17082785808147175\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.04916439953361834\n",
      "too high iv>: 1000 : 0.08725223474543335\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "die\n",
      "change_vaso> 0.75 : 0.008966493629070316\n",
      "change_iv> 1500 : 0.04884379424256725\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.010783580621039788\n",
      "too high iv>: 1000 : 0.062025266637805505\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "alive\n",
      "change_vaso> 0.75 : 0.03942181340341656\n",
      "change_iv> 1500 : 0.08804204993429698\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.04916439953361834\n",
      "too high iv>: 1000 : 0.08725223474543335\n",
      "-****----****----****----****----****----****----****----****----****----****---\n"
     ]
    }
   ],
   "source": [
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_phy','iv_phy',1,0.9,1000,1000,0.75)\n",
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_phy','iv_phy',0,0.9,1000,1000,0.75)\n",
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_phy','iv_phy',1,0.75,1500,1000,0.75)\n",
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_phy','iv_phy',0,0.75,1500,1000,0.75)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 232,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "die\n",
      "change_vaso> 0.9 : 0.0\n",
      "change_iv> 1000 : 0.0007078810759792355\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.0\n",
      "too high iv>: 1000 : 0.0007477665394151679\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "alive\n",
      "change_vaso> 0.9 : 0.0\n",
      "change_iv> 1000 : 0.002628120893561104\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.000388651379712398\n",
      "too high iv>: 1000 : 0.009521958802953751\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "die\n",
      "change_vaso> 0.75 : 0.0\n",
      "change_iv> 1500 : 0.0\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.0\n",
      "too high iv>: 1000 : 0.0007477665394151679\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "alive\n",
      "change_vaso> 0.75 : 0.0\n",
      "change_iv> 1500 : 0.0\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.000388651379712398\n",
      "too high iv>: 1000 : 0.009521958802953751\n",
      "-****----****----****----****----****----****----****----****----****----****---\n"
     ]
    }
   ],
   "source": [
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_cdt','iv_cdt',1,0.9,1000,1000,0.75)\n",
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_cdt','iv_cdt',0,0.9,1000,1000,0.75)\n",
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_cdt','iv_cdt',1,0.75,1500,1000,0.75)\n",
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_cdt','iv_cdt',0,0.75,1500,1000,0.75)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 233,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.7682427167892456"
      ]
     },
     "execution_count": 233,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "max(df_all['vaso_cdt'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 234,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_all = pd.DataFrame(columns=['iv_cdt','vaso_cdt','iv_phy','vaso_phy','die'])\n",
    "delta_iv = []\n",
    "delta_vaso = []\n",
    "a = []\n",
    "b = []\n",
    "a_iv_delta,a_vaso_delta = 0.0,0.0\n",
    "j=0\n",
    "for i in df_all.index:\n",
    "    if df_all.loc[i,'die'] == 1  or i == 0 :\n",
    "        continue\n",
    "    if df_all.loc[i-1,'term'] == True:\n",
    "        delta_iv.append(a_iv_delta)\n",
    "        delta_vaso.append(a_vaso_delta)\n",
    "        a_iv_delta,a_vaso_delta = 0.0,0.0\n",
    "        continue\n",
    "        \n",
    "    a_vaso_delta = max(df_all.loc[i,'vaso_cdt'] - df_all.loc[i-1,'vaso_cdt'],a_vaso_delta)\n",
    "    a_iv_delta = max(df_all.loc[i,'iv_cdt'] - df_all.loc[i-1,'iv_cdt'],a_iv_delta)\n",
    "    a.append(df_all.loc[i,'vaso_cdt'])\n",
    "    b.append(df_all.loc[i,'iv_cdt'])\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 235,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.5876854099333286 2366030.8942198753\n"
     ]
    }
   ],
   "source": [
    "print(max(delta_vaso),max(delta_iv)*2000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 236,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0\n",
      "0.7871637564889099\n"
     ]
    }
   ],
   "source": [
    "print(sum(value > 0.75 for value in delta_vaso)/len(delta_vaso))\n",
    "print(sum(value*2000 > 1000 for value in delta_iv)/len(delta_iv))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "py37",
   "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.17"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
