{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 35,
   "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 examples_my_cost.configs.bcql_configs import BCQL_DEFAULT_CONFIG, BCQLTrainConfig\n",
    "from osrl_my_cost.algorithms import BCQL, BCQLTrainer\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",
    "from torch.utils.data import DataLoader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 212,
   "metadata": {},
   "outputs": [],
   "source": [
    "#path =f'./Mymodel/bcql_c6.pt'\n",
    "#dataset_path_val = f'./examples_my_cost/data/my_cdt_data_val_noauto_c6.pkl'\n",
    "#dataset_path_val = f'./examples_my_cost/data/transicrl_data_val.pkl'\n",
    "path = f'./Mymodel/bcql_transcost.pt'\n",
    "\n",
    "dataset_path_val = f'./examples_my_cost/data/cost0_data_val.pkl'\n",
    "#path = f'./Mymodel/bcql_cost0.pt'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 213,
   "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 = torch.tensor([1.0,1.0],dtype=torch.float32)\n",
    "model = BCQL(\n",
    "        state_dim=state_dim,\n",
    "        action_dim=action_dim,\n",
    "        max_action=max_action,\n",
    "        a_hidden_sizes=[256, 256],\n",
    "        c_hidden_sizes=[256, 256],\n",
    "        vae_hidden_sizes=400,\n",
    "        sample_action_num=10,\n",
    "        PID=[0.1, 0.003, 0.001],\n",
    "        gamma=0.99,\n",
    "        tau=0.005,\n",
    "        lmbda=0.75,\n",
    "        beta= 0.5,\n",
    "        phi= 0.05,\n",
    "        num_q= 2,\n",
    "        num_qc=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 = BCQLTrainer(model,\n",
    "                          logger=None,\n",
    "                          actor_lr=0.001,\n",
    "                          critic_lr=0.001,\n",
    "                          vae_lr=0.001,\n",
    "                          reward_scale=0.1,\n",
    "                          cost_scale=1,\n",
    "                          device=\"cpu\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 214,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5907.0\n"
     ]
    }
   ],
   "source": [
    "print(sum(data_val['dieds']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 215,
   "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": 216,
   "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": 217,
   "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": 218,
   "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": 219,
   "metadata": {},
   "outputs": [],
   "source": [
    "def accuracy(TP,TN,FP,FN):\n",
    "    return (TP+TN)/(TP+TN+FP+FN)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 220,
   "metadata": {},
   "outputs": [],
   "source": [
    "def precision(TP,TN,FP,FN):\n",
    "    return TP/(TP+FP)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 221,
   "metadata": {},
   "outputs": [],
   "source": [
    "def recall(TP,TN,FP,FN):\n",
    "    return TP/(TP+FN)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 222,
   "metadata": {},
   "outputs": [],
   "source": [
    "def f1_score(TP,TN,FP,FN):\n",
    "    pre = precision(TP,TN,FP,FN)\n",
    "    rec = recall(TP,TN,FP,FN)\n",
    "    return 2*pre*rec/(pre+rec)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 223,
   "metadata": {},
   "outputs": [],
   "source": [
    "def print_(acc_iv,pre_iv,recall_iv,f1_iv,str):\n",
    "    print(\"+\"*10,str,\"+\"*10)\n",
    "    print(\"accuracy:\",np.mean(acc_iv),\"std\",np.std(acc_iv))\n",
    "    print(\"precision:\",np.mean(pre_iv),\"std\",np.std(pre_iv))\n",
    "    print(\"recall:\",np.mean(recall_iv),\"std\",np.std(recall_iv))\n",
    "    print(\"f1-score:\",np.mean(f1_iv),\"std\",np.std(f1_iv))\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 224,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "def get_gaps():\n",
    "    seed = [0,1,2,3]\n",
    "    acc_iv,pre_iv,recall_iv,f1_iv = [],[],[],[]\n",
    "    acc_vaso,pre_vaso,recall_vaso,f1_vaso = [],[],[],[]\n",
    "    acc_diff,pre_diff,recall_diff,f1_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",
    " \n",
    "        for j in range(len(l)):\n",
    "            df = diff_df.sort_values(l[j])\n",
    "            TP,FP,FN,TN = 0,0,0,0\n",
    "            num = 0\n",
    "            for t in df.index:\n",
    "                if df.loc[t,'die']==0:\n",
    "                    TP=TP+1\n",
    "                num+=1\n",
    "                if num>500:\n",
    "                    break\n",
    "            FP = num-TP\n",
    "            FN = num-TP\n",
    "            TN = TP\n",
    "            #print(l[j],\":\",acc)\n",
    "            if j == 0:\n",
    "                acc_iv.append(accuracy(TP,TN,FP,FN))\n",
    "                pre_iv.append(precision(TP,TN,FP,FN))\n",
    "                recall_iv.append(recall(TP,TN,FP,FN))\n",
    "                f1_iv.append(f1_score(TP,TN,FP,FN))\n",
    "            elif j == 1:\n",
    "                acc_vaso.append(accuracy(TP,TN,FP,FN))\n",
    "                pre_vaso.append(precision(TP,TN,FP,FN))\n",
    "                recall_vaso.append(recall(TP,TN,FP,FN))\n",
    "                f1_vaso.append(f1_score(TP,TN,FP,FN))\n",
    "            else:\n",
    "                acc_diff.append(accuracy(TP,TN,FP,FN))\n",
    "                pre_diff.append(precision(TP,TN,FP,FN))\n",
    "                recall_diff.append(recall(TP,TN,FP,FN))\n",
    "                f1_diff.append(f1_score(TP,TN,FP,FN))\n",
    "            #print(diff_df)\n",
    "    print_(acc_iv,pre_iv,recall_iv,f1_iv,\"iv\")\n",
    "    print_(acc_vaso,pre_vaso,recall_vaso,f1_vaso,\"vaso\")\n",
    "    print_(acc_diff,pre_diff,recall_diff,f1_diff,\"diff\")\n",
    "    return diff"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 225,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1b861b8408e34b1780582d3f4ac64ecb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Evaluating...:   0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/fn/OSRL/osrl/common/net.py:340: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  return torch.tensor(self.act_lim,dtype=torch.float32) * torch.tanh(self.d3(a))\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bf31f3a56b014f61bd054f48a1a9acff",
       "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": "2ad7a114c10f45d794f9c519246aab48",
       "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": "36d486feb49840729bb6ceb25fd8d400",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Evaluating...:   0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "++++++++++ iv ++++++++++\n",
      "accuracy: 0.5214570858283433 std 0.01031136642703187\n",
      "precision: 0.5214570858283433 std 0.01031136642703187\n",
      "recall: 0.5214570858283433 std 0.01031136642703187\n",
      "f1-score: 0.5214570858283433 std 0.01031136642703187\n",
      "++++++++++ vaso ++++++++++\n",
      "accuracy: 0.5523952095808383 std 0.010783524343799587\n",
      "precision: 0.5523952095808383 std 0.010783524343799587\n",
      "recall: 0.5523952095808383 std 0.010783524343799587\n",
      "f1-score: 0.5523952095808383 std 0.010783524343799587\n",
      "++++++++++ diff ++++++++++\n",
      "accuracy: 0.5429141716566867 std 0.008585154957128357\n",
      "precision: 0.5429141716566867 std 0.008585154957128357\n",
      "recall: 0.5429141716566867 std 0.008585154957128357\n",
      "f1-score: 0.5429141716566867 std 0.008585154957128357\n"
     ]
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "iv_gap = []\n",
    "vaso_gap = []\n",
    "diff_gap = []\n",
    "x = []\n",
    "\n",
    "diff_df = get_gaps()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 226,
   "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": 227,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "48cf657fa0be47df87f75c23ef52ab7f",
       "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": 228,
   "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": 229,
   "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'] = vaso1\n",
    "df_all['iv_phy'] = [ i*2000 for i in iv2]\n",
    "df_all['vaso_phy'] = vaso2\n",
    "df_all['die'] = data_val['dieds']\n",
    "df_all['term'] = data_val['terminals']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 230,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0\n"
     ]
    }
   ],
   "source": [
    "print(min(iv2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 231,
   "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>550.963998</td>\n",
       "      <td>0.052449</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>355.821401</td>\n",
       "      <td>0.050906</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>416.300148</td>\n",
       "      <td>0.051672</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>350.473702</td>\n",
       "      <td>0.051936</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>112.976044</td>\n",
       "      <td>0.051532</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  550.963998  0.052449   90.000004       0.0  0.0     0\n",
       "1  355.821401  0.050906  140.000001       0.0  0.0     0\n",
       "2  416.300148  0.051672  167.500004       0.0  0.0     0\n",
       "3  350.473702  0.051936   31.500001       0.0  0.0     1\n",
       "4  112.976044  0.051532   39.999999       0.0  0.0     1"
      ]
     },
     "execution_count": 231,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_all.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "figure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 232,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA94AAAMWCAYAAAAH1l7yAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAA9hAAAPYQGoP6dpAACxJ0lEQVR4nOzde1gWdf7/8Reg3IIKiMopEUlLxWNS4l0eV1ZUOlhWaqRWlllYqeVp1zzVhmlmVqbbtoW7SR52U0tKJU2tRCtW8sw3FdNWbzQNUFRAmN8f/Zj1DjygDCA8H9c118U9n/fMvGeA+3O/75n5jIthGIYAAAAAAIAlXCs6AQAAAAAAqjIKbwAAAAAALEThDQAAAACAhSi8AQAAAACwEIU3AAAAAAAWovAGAAAAAMBCFN4AAAAAAFiIwhsAAAAAAAtReAMAAAAAYCEKbwCWOHjwoFxcXBQfH2/Omzp1qlxcXCouKQAAqgH6YKDyofAGKoFdu3bp4Ycf1g033CCbzaagoCDFxMRo165d5ZpH9+7d5eLiYk6+vr667bbb9P7776uwsLBccykrjzzyiOrUqSNJOnbsmGrUqKGHH374ovGnTp2Sh4eH7rvvvvJKEQBQgeiDy15+fr4aNGigzp07XzTGMAwFBwerQ4cO5ZgZUHEovIEK9vHHH6tDhw5at26dHn30Ub3zzjsaNmyYvvzyS3Xo0EHLly8v13waNWqkf/7zn/rnP/+pF198UefPn9ewYcP0pz/96ZrXPWnSJJ09e7YMsrw6fn5++uMf/6iVK1fqzJkzJcZ8/PHHOnfu3CWLcwBA1UAfbI2aNWvqgQce0ObNm/XTTz+VGLNp0yb9/PPP9LeoPgwAFWbfvn2Gp6en0aJFC+PYsWNObcePHzdatGhh1K5d29i/f3+ZbK+goMA4e/bsRdu7detmtGrVymleTk6O0ahRI6N27dpGXl7eFW8rPT3dkGR88MEHV5tumRg6dKhRu3Zt8/U///lPQ5Lx0UcflRjfq1cvw9vb2zh37lx5pQgAqAD0wdb66quvDElGXFxcie3Dhw83XF1djf/+97/lnBlQMTjjDVSgWbNm6cyZM3r33XfVsGFDp7YGDRror3/9q3JycjRz5kxz/iOPPKImTZoUW1dJ9265uLho5MiRWrRokVq1aiWbzabVq1eXKkdPT0916tRJOTk5On78uCTpwIEDeuCBB+Tr62u2JyYmXnZdF7u/7MMPP1THjh3l6empevXqqWvXrlq7dq0kaejQoWrQoIHy8/OLLderVy81b968VPtz7733qnbt2kpISCjWduzYMa1bt07333+/bDZbqdYLALi+0Af/xqo++I477lCTJk1K7G/z8/P1r3/9Sz169FBQUJC2b9+uRx55RDfeeKNq1aqlgIAAPfbYYzpx4oTTcqdOndKoUaPUpEkT2Ww280q2//znP05xy5YtU3h4uDw8PNSgQQM9/PDD+u9//3vZYwRYicIbqECffvqpmjRpoi5dupTY3rVrVzVp0uSKOtSLWb9+vUaPHq0BAwZo7ty5JX5guJwDBw7Izc1NPj4+ysjI0O233641a9bo6aef1l/+8hedO3dOd99991Vdkjdt2jQNHjxYNWvW1PTp0zVt2jQFBwdr/fr1kqTBgwfrxIkTWrNmjdNyDodD69evL/UlarVr19Y999yjNWvW6OTJk05tS5YsUUFBgWJiYkq9HwCA6wt9sLV9sIuLix566CHt2LGj2P3yq1ev1smTJ83+NikpSQcOHNCjjz6qt956SwMHDtTixYvVt29fGYZhLjdixAjNnz9f/fv31zvvvKMXXnhBHh4e2rNnjxkTHx+vBx98UG5uboqLi9MTTzyhjz/+WJ07d1ZmZmapjxFQZir6lDtQXWVmZhqSjHvuueeScXfffbchycjOzjYM47dLp0NCQorFTZkyxfj9v7Qkw9XV1di1a9cV5dStWzejRYsWxvHjx43jx48be/bsMZ599llDknHXXXcZhmEYo0aNMiQZX331lbncqVOnjNDQUKNJkyZGQUGBYRglX+b2+xx//PFHw9XV1bj33nvN5YoUFhYahvHbpXmNGjUyBgwY4NT++uuvGy4uLsaBAwcuuU+/v9TcMAwjMTHRkGT89a9/dZrfqVMn44YbbiiWCwCgaqEPLp8+eNeuXYYkY+LEiU7zBw4caNSqVcvIysoyDMMwzpw5U2zZjz76yJBkbNq0yZzn7e1txMbGXnR7eXl5hp+fn9G6dWuny/pXrVplSDImT558yXwBK3HGG6ggp06dkiTVrVv3knFF7dnZ2Ve1nW7duiksLOyK4/fu3auGDRuqYcOGatmypd566y1FR0fr/ffflyR99tln6tixo9NIpXXq1NHw4cN18OBB7d69+4q3tWLFChUW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F96XG8hFknr37q2jR4+a00cffeTUXhYDuQAAgIsLCAiQJGVkZDjNz8jIMNsCAgJ07Ngxp/bz58/r5MmTTjElrePCbVwspqi9JDabTV5eXk4TAADXqzIvvPv06aOXX35Z995770VjbDabAgICzKlevXpm2549e7R69Wq99957ioiIUOfOnfXWW29p8eLFOnLkiCRp0aJFysvL0/vvv69WrVpp4MCBevbZZ/X666+X9e4AAFAlhYaGKiAgQOvWrTPnZWdna+vWrbLb7ZIku92uzMxMpaSkmDHr169XYWGhIiIizJhNmzYpPz/fjElKSlLz5s3N/t1utzttpyimaDsAAFR1FTK42oYNG+Tn56fmzZvrqaee0okTJ8y2shrIpSQM1AIAqE5Onz6t1NRUpaamSvptQLXU1FQdOnRILi4uGjVqlF5++WV98skn2rFjh4YMGaKgoCBz5POWLVuqd+/eeuKJJ/Ttt9/qm2++0ciRIzVw4EAFBQVJkh566CG5u7tr2LBh2rVrl5YsWaK5c+dqzJgxZh7PPfecVq9erdmzZ2vv3r2aOnWqvv/+e40cObK8DwkAABWi3Avv3r176x//+IfWrVunV199VRs3blSfPn1UUFAg6coHcilpkJaitouJi4uTt7e3OQUHB5flrgEAUKl8//33uuWWW3TLLbdIksaMGaNbbrlFkydPliSNGzdOzzzzjIYPH67bbrtNp0+f1urVq1WrVi1zHYsWLVKLFi3Us2dP9e3bV507d3a6tcvb21tr165Venq6wsPD9fzzz2vy5MlOt4jdfvvtSkhI0Lvvvqt27drpX//6l1asWKHWrVuX05EAAKBilfuo5gMHDjR/btOmjdq2baumTZtqw4YN6tmzp6XbnjhxotM38NnZ2RTfAIAqq3v37jIM46LtLi4umj59uqZPn37RGF9fXyUkJFxyO23bttVXX311yZgHHnhADzzwwKUTBgCgiqrw53jfeOONatCggfbt2yep7AZyKQkDtQAAAAAAyluFF94///yzTpw4ocDAQEllN5ALAAAAAACVQZlfan769Gnz7LX0v4FcfH195evrq2nTpql///4KCAjQ/v37NW7cODVr1kxRUVGSnAdyWbBggfLz80scyGXatGkaNmyYxo8fr507d2ru3LmaM2dOWe9OldBkQqLT64MzoisoEwAAAACofsr8jPel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eHioefPm+vOf/2y2l3Rv2cqVKxUdHa2goCDZbDY1bdpUL730kgoKCpzW3b17d7Vu3Vq7d+9Wjx495OnpqRtuuEEzZ8687DFzOBx69NFH1ahRI9lsNgUGBuqee+656nvcfv87yMnJ0fPPP6/g4GDZbDY1b95cr7322iUv35Yufm/Z1q1b1bdvX9WrV0+1a9dW27ZtNXfuXEnSBx98IBcXF23btq3Y+l555RW5ubnpv//97xXvS3BwsLp27ap//etfJf5tJCQkqGnTpoqIiLjidQJAVUY/TD98tf2wh4eH7rvvPq1bt07Hjh0r1p6QkKC6devq7rvv1smTJ/XCCy+oTZs2qlOnjry8vNSnTx/98MMPxZZ766231KpVK3l6eqpevXq69dZblZCQ4BSzbds29enTR15eXqpTp4569uypLVu2XPL4oHqg8AYuYv/+/ZJU7BKkZ555Rj/88IOmTJmip556Sp9++qlGjhxptg8ePFgnTpzQmjVrnJZzOBxav369Hn74YUnSrl27dOeddyo3N1fTp0/X7Nmzdffdd+ubb765ZF7bt29XRESE1q9fryeeeEJz585Vv3799Omnn15yufj4eNWpU0djxozR3LlzFR4ersmTJ2vChAnFYn/99Vf17t1b7dq10+zZs9WiRQuNHz9en3/++SW30b9/fy1fvlyPPvqo3nnnHT377LM6deqUDh06dMnlLubC34FhGLr77rs1Z84c9e7dW6+//rqaN2+usWPHasyYMaVed1JSkrp27ardu3frueee0+zZs9WjRw+tWrVK0m/f+nt4eGjRokXFll20aJG6d++uG264oVTbjImJKfFvY8eOHdq5cyffvAPABeiH6YevpR+OiYnR+fPntXTpUqf5J0+e1Jo1a3TvvffKw8NDBw4c0IoVK3TnnXfq9ddf19ixY7Vjxw5169ZNR44cMZf729/+pmeffVZhYWF64403NG3aNLVv315bt241Y3bt2qUuXbrohx9+0Lhx4/Tiiy8qPT1d3bt3d4pDNWUA1dwHH3xgSDK++OIL4/jx48bhw4eNxYsXG/Xr1zc8PDyMn3/+2SkuMjLSKCwsNJcfPXq04ebmZmRmZhqGYRgFBQVGo0aNjAEDBjht5/XXXzdcXFyMAwcOGIZhGHPmzDEkGcePH79obunp6YYk44MPPjDnde3a1ahbt67x008/OcVemFNRrunp6ea8M2fOFFv/k08+aXh6ehrnzp0z53Xr1s2QZPzjH/8w5+Xm5hoBAQFG//79L5rrr7/+akgyZs2addGYi5kyZYohyUhLSzOOHz9upKenG3/9618Nm81m+Pv7Gzk5OcaKFSsMScbLL7/stOz9999vuLi4GPv27TPnhYSEGEOHDjVff/nll4Yk48svvzQMwzDOnz9vhIaGGiEhIcavv/7qtL4Lj+OgQYOMoKAgo6CgwJz3n//8p9jvpCRFv4PvvvvOnHfy5EnDZrMZgwYNcoqdMGGCuf8AUN3QD9MPX6is+uHz588bgYGBht1ud5q/YMECQ5KxZs0awzAM49y5c07rN4zffu82m82YPn26Oe+ee+4xWrVqdclt9uvXz3B3dzf2799vzjty5IhRt25do2vXrpdcFlUfZ7yB/y8yMlINGzZUcHCwBg4cqDp16mj58uXFvk0dPny40wAjXbp0UUFBgX766SdJv93HFBMTo08++cRpNM1Fixbp9ttvV2hoqCTJx8dH0m+XnhUWFl5RjsePH9emTZv02GOPqXHjxk5tlxv0xMPDw/z51KlT+uWXX9SlSxedOXNGe/fudYqtU6eOeUZAktzd3dWxY0cdOHDgkut3d3fXhg0b9Ouvv17R/vxe8+bN1bBhQ4WGhurJJ59Us2bNlJiYKE9PT3322Wdyc3PTs88+67TM888/L8MwLnsW4ELbtm1Tenq6Ro0aZf4eilx4HIcMGaIjR47oyy+/NOctWrRIHh4e6t+/f6n3r169eurbt68++eQT5eTkSJIMw9DixYt166236uabby71OgGgqqAf/h/64d9cSz/s5uamgQMHKjk52elS+4SEBPn7+6tnz56SJJvNJlfX30qigoICnThxwrzt4D//+Y+5nI+Pj37++Wd99913JW6voKBAa9euVb9+/XTjjTea8wMDA/XQQw/p66+/vi5HiEfZofAG/r958+YpKSlJX375pXbv3q0DBw4oKiqqWNzvO9p69epJklMnN2TIEJ09e1bLly+XJKWlpSklJUWDBw82YwYMGKA77rhDjz/+uPz9/TVw4EAtXbr0kp1/UYfbunXrUu/frl27dO+998rb21teXl5q2LCh2alnZWU5xTZq1KjYB4h69epdsiO32Wx69dVX9fnnn8vf319du3bVzJkz5XA4rjjHf//730pKStKGDRu0b98+7dy5U+Hh4ZKkn376SUFBQapbt67TMi1btjTbr1TRpXOXO45//OMfFRgYaF7mVlhYqI8++kj33HNPsTyuVExMjHJycrRy5UpJ0ubNm3Xw4EEuMwdQ7dEP/w/98G+utR8u6luL7sP++eef9dVXX2ngwIHm4HeFhYWaM2eObrrpJtlsNjVo0EANGzbU9u3bnX4v48ePV506ddSxY0fddNNNio2Ndbot4fjx4zpz5ozTGAJFWrZsqcLCQh0+fPiyOaPqovAG/r+OHTsqMjJS3bt3V8uWLc1vP3/vYqOUGhcMLBIWFqbw8HB9+OGHkqQPP/xQ7u7uevDBB80YDw8Pbdq0SV988YUGDx6s7du3a8CAAfrjH/9YbKCVa5WZmalu3brphx9+0PTp0/Xpp58qKSlJr776qiQV+5BxJftYklGjRun//u//FBcXp1q1aunFF19Uy5YtSxwYpSRdu3ZVZGSkunXrpqZNm17RMlZyc3PTQw89pH//+986d+6cvvzySx05csTpLERp3XnnnfL29jY/BCQkJJjfygNAdUY/XLp9LAn9sLPw8HC1aNFCH330kaSSnyDyyiuvaMyYMeratas+/PBDrVmzRklJSWrVqpXT76Vly5ZKS0vT4sWL1blzZ/373/9W586dNWXKlLLdaVRZFN6ARYYMGaL169fr6NGjSkhIUHR0tPmtfBFXV1f17NlTr7/+unbv3m0+L/PCS6ouVHTp0s6dO0uVy4YNG3TixAnFx8frueee05133qnIyMhi+ZSFpk2b6vnnn9fatWu1c+dO5eXlafbs2de83pCQEB05csTpskFJ5uV5ISEhpcpRurLjOGTIEGVnZ+vTTz/VokWL1LBhwxLPwFwpm82m+++/X2vXrlVGRoaWLVumP/zhDwoICLjqdQIAiqMfph+WfjvrvXPnTm3fvl0JCQm66aabdNttt5nt//rXv9SjRw/9/e9/18CBA9WrVy9FRkYqMzOz2Lpq166tAQMG6IMPPtChQ4cUHR2tv/zlLzp37pwaNmwoT09PpaWlFVtu7969cnV1VXBw8BXnjaqHwhuwyKBBg+Ti4qLnnntOBw4cKPbt7MmTJ4st0759e0m/PSqlJA0bNlTXrl31/vvvFxuh9FLfghd9c35hTF5ent55550r2pcrcebMGZ07d85pXtOmTVW3bt2L7k9p9O3bVwUFBXr77bed5s+ZM0cuLi7q06fPFa+rQ4cOCg0N1RtvvFGsY/39cWzbtq3atm2r9957T//+9781cOBA1ahR46r3Q/rtQ0B+fr6efPJJHT9+nMvMAcAC9MP0w9L/LjefPHmyUlNTi/W5bm5uxba5bNmyYo8qO3HihNNrd3d3hYWFyTAM5efny83NTb169dLKlSud7inPyMhQQkKCOnfuLC8vryvOG1XPtX16BHBRDRs2VO/evbVs2TL5+PgoOjraqX369OnatGmToqOjFRISomPHjumdd95Ro0aN1Llz54uu980331Tnzp3VoUMHDR8+XKGhoTp48KASExOVmppa4jK333676tWrp6FDh+rZZ5+Vi4uL/vnPf172krXS+L//+z/17NlTDz74oMLCwlSjRg0tX75cGRkZZXIZ9V133aUePXroz3/+sw4ePKh27dpp7dq1WrlypUaNGlWqS+JcXV01f/583XXXXWrfvr0effRRBQYGau/evdq1a1exR9AMGTJEL7zwgiRd02XmRbp166ZGjRpp5cqV5rNGAQBli36YfliSQkNDdfvtt5tjq/y+8L7zzjs1ffp0Pfroo7r99tu1Y8cOLVq0yGmANOm3Z8AHBATojjvukL+/v/bs2aO3335b0dHR5v3mL7/8svls+Kefflo1atTQX//6V+Xm5l7Rc9hRtVF4AxYaMmSIVq1apQcffFA2m82p7e6779bBgwf1/vvv65dfflGDBg3UrVs3TZs2Td7e3hddZ7t27bRlyxa9+OKLmj9/vs6dO6eQkBCn+9Z+r379+lq1apWef/55TZo0SfXq1dPDDz+snj17XtNl0xcKDg7WoEGDtG7dOv3zn/9UjRo11KJFCy1duvSqRgD/PVdXV33yySeaPHmylixZog8++EBNmjTRrFmz9Pzzz5d6fVFRUfryyy81bdo0zZ49W4WFhWratKmeeOKJYrExMTEaP368mjZtqo4dO5bJvgwaNEizZs3SXXfdddUDtQEALo1+mH64aPnNmzerY8eOatasmVPbn/70J+Xk5CghIUFLlixRhw4dlJiYWOz56k8++aQWLVqk119/XadPn1ajRo307LPPatKkSWZMq1at9NVXX2nixImKi4tTYWGhIiIi9OGHHyoiIqLUeaNqcTHK8qs2AE5Wrlypfv36adOmTerSpUtFp4Or9MsvvygwMFCTJ0/Wiy++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dVfsp1+/ftq5c2elcwQAAAAAoLrY/hxvAAAAAADqMwpvAAAAAABsROENAEA9NX36dPn4+Hgs7du3t9rPnj2rlJQUNWvWTDfccIOGDh16yaM88/PzlZiYqIYNGyosLEwTJkzQuXPnPGI2bdqk7t27KzAwUG3bttXixYurY/cAAKgxKLwBAKjHbr31Vh07dsxaPvnkE6tt/Pjxev/997Vq1Spt3rxZR48e1f3332+1nz9/XomJiSopKdHWrVu1ZMkSLV68WFOnTrVi8vLylJiYqLvvvls5OTkaN26cHnvsMa1fv75a9xMAAG+q8pur4ce5cbLnY88Oz0r0UiYAgPrM399fERERl6wvKirSm2++qWXLlumnP/2pJGnRokXq0KGDtm3bpl69emnDhg3at2+fPvzwQ4WHh+u2227TM888o0mTJmn69OkKCAjQwoULFRMTo+eff16S1KFDB33yySeaO3cuTyIBANQbnPGuIW6cvNZjAQCgOnzxxReKiopSmzZtlJSUpPz8fElSdna2SktLFR8fb8W2b99erVq1UlZWliQpKytLnTt3Vnh4uBWTkJAgt9utvXv3WjEX9lEeU97H5RQXF8vtdnssAADUVhTeAADUU3FxcVq8eLHS09O1YMEC5eXlqU+fPvruu+/kcrkUEBCg0NBQj/eEh4fL5XJJklwul0fRXd5e3nalGLfbrTNnzlw2t5kzZyokJMRaoqOjr3d3AQDwGi41BwCgnho0aJD1c5cuXRQXF6fWrVtr5cqVCg4O9mJm0pQpU5SWlma9drvdFN8AgFqLM94AAECSFBoaqltuuUUHDx5URESESkpKVFhY6BFTUFBgfSc8IiLikrucl7++WozD4bhicR8YGCiHw+GxAABQW1F4AwAASdKpU6d06NAhRUZGKjY2Vg0aNFBmZqbVnpubq/z8fDmdTkmS0+nU7t27dfz4cSsmIyNDDodDHTt2tGIu7KM8prwPAADqAwpvAADqqd///vfavHmzDh8+rK1bt+rnP/+5/Pz8NHz4cIWEhCg5OVlpaWn66KOPlJ2drUceeUROp1O9evWSJA0YMEAdO3bUiBEj9O9//1vr16/XU089pZSUFAUGBkqSxowZoy+//FITJ07UgQMH9Oqrr2rlypUaP368N3cdAIBqxXe8AQCop7766isNHz5c33zzjVq0aKE777xT27ZtU4sW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+uvq06ePmjRpoiZNmig+Pr7GfP6pTtf6GXD58uXy8fHRkCFD7E2wBqrsmBUWFiolJUWRkZEKDAzULbfcUu/+Pis7Zi+++KLatWun4OBgRUdHa/z48Tp79mw1ZetdV/s8UpFqm5cNrsvy5ctNQECAeeutt8zevXvNqFGjTGhoqCkoKPB2aiYhIcEsWrTI7Nmzx+Tk5JjBgwebVq1amVOnTlkxd911lxk1apQ5duyYtRQVFVnt586dM506dTLx8fFm586dZt26daZ58+ZmypQptuc/bdo0c+utt3rkduLECat9zJgxJjo62mRmZpodO3aYXr16mTvuuKNG5G6MMcePH/fIPSMjw0gyH330kTGm5o39unXrzB//+Efzz3/+00gy77zzjkf7rFmzTEhIiFm9erX597//be69914TExNjzpw5Y8UMHDjQdO3a1Wzbts18/PHHpm3btmb48OFWe1FRkQkPDzdJSUlmz5495u233zbBwcHmr3/9q635FxYWmvj4eLNixQpz4MABk5WVZXr27GliY2M9+mjdurWZMWOGx7/JhX8v3srfGGNGjhxpBg4c6JHbyZMnPWJq6vgbYzzyPnbsmHnrrbeMj4+POXTokBXjzfH/McfLqjjmfPnll6Zhw4YmLS3N7Nu3z7z88svGz8/PpKenX/c+4P9Udm7+9NNPjZ+fn5k9e7bZt2+feeqpp0yDBg3M7t27qzlz76nsmD344INm/vz5ZufOnWb//v3m4YcfNiEhIearr76q5sy951o/A+bl5Zmf/OQnpk+fPua+++6rnmRriMqOWXFxsenRo4cZPHiw+eSTT0xeXp7ZtGmTycnJqebMvaeyY7Z06VITGBholi5davLy8sz69etNZGSkGT9+fDVn7h1X+zxyseqclym8r1PPnj1NSkqK9fr8+fMmKirKzJw504tZVez48eNGktm8ebO17q677jJPPPHEZd+zbt064+vra1wul7VuwYIFxuFwmOLiYjvTNdOmTTNdu3atsK2wsNA0aNDArFq1ylq3f/9+I8lkZWV5PfeKPPHEE+amm24yZWVlxpiaPfYXH6jKyspMRESEmTNnjrWusLDQBAYGmrffftsYY8y+ffuMJPP5559bMR988IHx8fExX3/9tTHGmFdffdU0adLEI/9JkyaZdu3a2Zp/RT777DMjyfz3v/+11rVu3drMnTv3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zvbLnMuL7i+++EIffvihmjVrdtX35OTkyNfX17qE25v5X+yrr77SN9984/H7UpPHv9ybb76p2NhYde3a9aqx1Tn+VzteVtUxx+l0evRRHlMT5oy64lrm5vr+73Ktn2dmz56tZ555Runp6R73l6gPKjtm7du31+7du5WTk2Mt9957r+6++27l5OQoOjq6OtP3imv5Pevdu7cOHjzoUTD+5z//UWRkpMf9Puqqaxmz77//Xr6+niVe+X9c/HC/MVyoWo//VX67tnpm+fLlJjAw0CxevNjs27fPjB492oSGhnrc1dZbxo4da0JCQsymTZs8Hs/z/fffG2OMOXjwoJkxY4bZsWOHycvLM++++65p06aN6du3r9VH+eNxBgwYYHJyckx6erpp0aJFtTyS68knnzSbNm0yeXl55tNPPzXx8fGmefPm5vjx48aYHx7t06pVK7Nx40azY8cO43Q6jdPprBG5lzt//rxp1aqVmTRpksf6mjj23333ndm5c6fZuXOnkWReeOEFs3PnTuuu37NmzTKhoaHm3XffNbt27TL33XdfhY8T69atm9m+fbv55JNPzM033+zxOKvCwkITHh5uRowYYfbs2WOWL19uGjZsWCWPg7pS/iUlJebee+81LVu2NDk5OR5/D+V3m966dauZO3euycnJMYcOHTJ///vfTYsWLcxDDz3k9fy/++478/vf/95kZWWZvLw88+GHH5ru3bubm2++2Zw9e9bqo6aOf7mioiLTsGFDs2DBgkve7+3xv9rx0piqOeaUP7ZkwoQJZv/+/Wb+/Pk8TswGV5ubR4wYYSZPnmzFf/rpp8bf398899xzZv/+/WbatGn18nFilRmzWbNmmYCAAPOPf/zD42/mu+++89YuVLvKjtnF6uNdzSs7Zvn5+aZx48YmNTXV5ObmmjVr1piwsDDz5z//2Vu7UO0qO2bTpk0zjRs3Nm+//bb58ssvzYYNG8xNN91kfvWrX3lrF6rV1T6PTJ482YwYMcKKr855mcK7Crz88sumVatWJiAgwPTs2dNs27bN2ykZY364hX5Fy6JFi4wxPxzM+vbta5o2bWoCAwNN27ZtzYQJEzyeJW2MMYcPHzaDBg0ywcHBpnnz5ubJJ580paWltuf/wAMPmMjISBMQEGB+8pOfmAceeMAcPHjQaj9z5oz57W9/a5o0aWIaNmxofv7zn5tjx47ViNzLrV+/3kgyubm5Hutr4th/9NFHFf6+jBw50hjzwyPF/vSnP5nw8HATGBho+vfvf8l+ffPNN2b48OHmhhtuMA6HwzzyyCOXfAj797//be68804TGBhofvKTn5hZs2bZnn9eXt5l/x7Kn6uenZ1t4uLiTEhIiAkKCjIdOnQwzz77rEdh6638v//+ezNgwADTokUL06BBA9O6dWszatSoS/6Dr6aOf7m//vWvJjg42BQWFl7yfm+P/9WOl8ZU3THno48+MrfddpsJCAgwbdq08dgGqs6V5ua77rrL43fTGGNWrlxpbrnlFhMQEGBuvfVWs3bt2mrO2PsqM2atW7eu8G9m2rRp1Z+4F1X29+xC9bHwNqbyY7Z161YTFxdnAgMDTZs2bcz/+3//z5w7d66as/auyoxZaWmpmT59urnppptMUFCQiY6ONr/97W/Nt99+W/2Je8HVPo+MHDnS3HXXXZe8pzrmZR9juOYAAAAAAAC78B1vAAAAAABsROENAAAAAICNKLwBAAAAALARhTcAAAAAADai8AYAAAAAwEYU3gAAAAAA2IjCGwAAAAAAG1F4AwAAAABgIwpvAAAAAABsROENAAAAAICNKLwBAAAAALARhTcAAAAAADb6/0YFIprzso9FAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x800 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "fig, axs = plt.subplots(2, 2, figsize=(10, 8))\n",
    "\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",
    "plt.tight_layout()\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 233,
   "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": 234,
   "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": 235,
   "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": 236,
   "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": 237,
   "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": 238,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.775, -0.03, 'Difference between optimal and physician IV dose')"
      ]
     },
     "execution_count": 238,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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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": 239,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1000 -800\n",
      "0.29999999999999993 -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": 240,
   "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": 241,
   "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": 242,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "die\n",
      "change_vaso> 0.9 : 0.003067484662576687\n",
      "change_iv> 1000 : 0.07951864086833411\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.008815773938368295\n",
      "too high iv>: 1000 : 0.0680861112204337\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "alive\n",
      "change_vaso> 0.9 : 0.01576872536136662\n",
      "change_iv> 1000 : 0.1340341655716163\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.04275165176836378\n",
      "too high iv>: 1000 : 0.11329187718616401\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "die\n",
      "change_vaso> 0.75 : 0.00778669183577159\n",
      "change_iv> 1500 : 0.02052855120339783\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.008815773938368295\n",
      "too high iv>: 1000 : 0.0680861112204337\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "alive\n",
      "change_vaso> 0.75 : 0.0328515111695138\n",
      "change_iv> 1500 : 0.03679369250985545\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.04275165176836378\n",
      "too high iv>: 1000 : 0.11329187718616401\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": 243,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.0"
      ]
     },
     "execution_count": 243,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "max(df_all['vaso_cdt'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 244,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 每个患者的药物剂量平均值\n",
    "# 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": 245,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.96397257 4000000.0\n"
     ]
    }
   ],
   "source": [
    "print(max(delta_vaso),max(delta_iv)*2000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 246,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.00778669183577159\n",
      "0.8282208588957055\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
}
