{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [],
   "source": [
    "from dataclasses import asdict, dataclass\n",
    "from typing import Any, DefaultDict, Dict, List, Optional, Tuple\n",
    "import sys\n",
    "sys.path.append(\"../Our-Model/CDT\")\n",
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "from CDT.osrl_cdt.algorithms import CDT, CDTTrainer\n",
    "from CDT.osrl_cdt.common.exp_util import load_config_and_model, seed_all\n",
    "import pickle\n",
    "from CDT.osrl_cdt.algorithms import CDT, CDTTrainer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "def get_val_path(path_,batch_size=200):\n",
    "    num_trajectories = len(path_)\n",
    "    \n",
    "    paths = []\n",
    "    die = 0 \n",
    "    nodie = 0\n",
    "    num = batch_size/2\n",
    "    for i in range(num_trajectories):\n",
    "        if die < num and path_[i]['dieds'][0] == 1: \n",
    "            traj = path_[i]\n",
    "            paths.append(traj)\n",
    "            die += 1\n",
    "        if nodie< num and path_[i]['dieds'][0] == 0:\n",
    "            traj = path_[i]\n",
    "            paths.append(traj)\n",
    "            nodie += 1\n",
    "        if die > num and nodie > num:\n",
    "            break\n",
    "    actions = []\n",
    "    next_observations = []\n",
    "    observations = []\n",
    "    rewards = []\n",
    "    dieds = []\n",
    "    costs = []\n",
    "    terminals = []\n",
    "    #print(len(paths))\n",
    "    for i in range(len(paths)):\n",
    "        path = paths[i]\n",
    "        for j in range(len(path['dieds'])):\n",
    "            path['actions'][j][0] = path['actions'][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",
    "\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",
    "    print(len((paths)))\n",
    "    return out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "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": 71,
   "metadata": {},
   "outputs": [],
   "source": [
    "#path  = \"./My_model/cdt_cost0.pt\"\n",
    "path  = \"./My_model/cdt3.pt\"\n",
    "#path = f'./My_model/cdt_without_atten.pt'\n",
    "\n",
    "#path = f'./Mymodel/coptidice_transcost.pt'\n",
    "dataset_path_val = f'../CDT/examples_my_cost/data/cost0_data_val.pkl'\n",
    "noise_scale = None\n",
    "eval_episodes = 20\n",
    "best = False\n",
    "device = \"cpu\"\n",
    "threads = 4\n",
    "\n",
    "# cfg, model = load_config_and_model(args.path, args.best)\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",
    "cdt_model = CDT(\n",
    "    state_dim=48,\n",
    "    action_dim=2,\n",
    "    max_action=[1,1],\n",
    "    embedding_dim=128,\n",
    "    seq_len=10,\n",
    "    episode_len=300,\n",
    "    num_layers=3,\n",
    "    num_heads=8,\n",
    "    attention_dropout=0.1,\n",
    "    residual_dropout=0.1,\n",
    "    embedding_dropout=0.1,\n",
    "    time_emb=True,\n",
    "    use_rew=True,\n",
    "    use_cost=True,\n",
    "    cost_transform=True,\n",
    "    add_cost_feat=False,\n",
    "    mul_cost_feat=False,\n",
    "    cat_cost_feat=False,\n",
    "    action_head_layers=1,\n",
    "    cost_prefix=False,\n",
    "    stochastic=True,\n",
    "    init_temperature=0.1,\n",
    "    target_entropy=target_entropy,\n",
    ")\n",
    "cdt_model.load_state_dict(torch.load(path))\n",
    "cdt_model.to(device)\n",
    "\n",
    "trainer = CDTTrainer(cdt_model,\n",
    "                        #env,\n",
    "                        reward_scale=0.1,\n",
    "                        cost_scale=1,\n",
    "                        cost_reverse=False,\n",
    "                        device=device)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [],
   "source": [
    "def eval(returns,costs,seed):\n",
    "\n",
    "    \n",
    "    rets = returns\n",
    "    costs = costs\n",
    "    eval_episodes = 1\n",
    "    # assert len(rets) == len(\n",
    "    #     costs\n",
    "    # ), f\"The length of returns {len(rets)} should be equal to costs {len(costs)}!\"\n",
    "    \n",
    "    cdt_actions = []\n",
    "    phy_actions = []\n",
    "    dieds = []\n",
    "    val_df = []\n",
    "    t = True\n",
    "    for target_ret, target_cost in zip(rets, costs):\n",
    "        seed_all(seed)\n",
    "        while t:\n",
    "            t,data_v = get_random1000(data_val,seed)\n",
    "        agent_action,phy_action,action_ems = trainer.evaluate(data_v,eval_episodes,\n",
    "                                             target_ret * 0.1,\n",
    "                                             target_cost * 1)\n",
    "        \n",
    "        cdt_actions=agent_action\n",
    "        phy_actions=phy_action\n",
    "        dieds=data_v['dieds']\n",
    "        #print(\"target ret:\",target_ret,\"target cost:\",target_cost)\n",
    "        val_df=data_v\n",
    "    return val_df,cdt_actions,phy_actions,dieds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "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": 62,
   "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 = []\n",
    "    actions_a = actions_a[0]\n",
    "    actions_p = actions_p[0]\n",
    "    print(len(actions_a))\n",
    "    print(len(actions_p))\n",
    "    for j in range(len(actions_p)):\n",
    "        w_a = actions_a[j]\n",
    "        w_p= actions_p[j]\n",
    "        #print(w_a[0],w_p[0])\n",
    "        iv_diff.append((torch.mean((torch.tensor(w_a[0])-torch.tensor(w_p[0]))**2)).detach().cpu().item())\n",
    "        vaso_diff.append((torch.mean((torch.tensor(w_a[1])-torch.tensor(w_p[1]))**2)).detach().cpu().item())\n",
    "        diff.append((torch.mean((torch.tensor([w_a[0],w_a[1]])-torch.tensor([w_p[0],w_p[1]]))**2)).detach().cpu().item())\n",
    "        dies.append(die[j])\n",
    "    return iv_diff,vaso_diff,diff,dies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import random\n",
    "def get_gaps(returns,costs):\n",
    "    seed = [0,10,20,30]\n",
    "    ac_iv = []\n",
    "    ac_vaso = []\n",
    "    ac_diff = []\n",
    "    for i in seed:\n",
    "        val_df,cdt_actions,phy_actions,dieds = eval(returns,costs,i)\n",
    "        # time = 0\n",
    "        # cdt_actions = cdt_actions[time][0]\n",
    "        # phy_actions = phy_actions[time][0]\n",
    "        # dieds = dieds[time]\n",
    "        term = val_df['terminals']\n",
    "        iv_diff,vaso_diff,diff,die=get_iv_vaso(1000,cdt_actions,phy_actions,dieds,term)\n",
    "        # iv_diff_,vaso_diff_,diff_,die_=get_iv_vaso(200,cdt_actions,phy_actions,dieds,term)\n",
    "\n",
    "        # die_0 = [i for i, value in enumerate(die_) if value==0]\n",
    "        # die_1 = [i for i, value in enumerate(die_) if value==1]\n",
    "\n",
    "        # random.seed(i)\n",
    "\n",
    "        # selected_0 = random.sample(die_0,500)\n",
    "        # selected_1 = random.sample(die_1,500)\n",
    "\n",
    "        # iv_diff =[iv_diff_[i] for i in selected_0] + [iv_diff_[i] for i in selected_1]\n",
    "\n",
    "        # vaso_diff =[vaso_diff_[i] for i in selected_0] + [vaso_diff_[i] for i in selected_1]\n",
    "\n",
    "        # diff =[diff_[i] for i in selected_0] + [diff_[i] for i in selected_1]\n",
    "\n",
    "        # die =[die_[i] for i in selected_0] + [die_[i] for i in selected_1]\n",
    "\n",
    "        # print(sum(die))\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",
    "        #print(\"seed:\",i,\"_CDT排序正确的比率\")\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(\"num:\",num)\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": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a85dee3430c945798a6bcd9a79ee33c0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Evaluating...:   0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[1;32m/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb 单元格 9\u001b[0m line \u001b[0;36m7\n\u001b[1;32m      <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=4'>5</a>\u001b[0m x \u001b[39m=\u001b[39m []\n\u001b[1;32m      <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=5'>6</a>\u001b[0m \u001b[39mfor\u001b[39;00m r \u001b[39min\u001b[39;00m \u001b[39mrange\u001b[39m(\u001b[39m15\u001b[39m,\u001b[39m40\u001b[39m,\u001b[39m1\u001b[39m):\n\u001b[0;32m----> <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=6'>7</a>\u001b[0m         a,_,b,_,c,_,diff_df \u001b[39m=\u001b[39m get_gaps([r],[\u001b[39m0\u001b[39;49m])\n\u001b[1;32m      <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=7'>8</a>\u001b[0m         x\u001b[39m.\u001b[39mappend(r)\n\u001b[1;32m      <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=8'>9</a>\u001b[0m         iv_gap\u001b[39m.\u001b[39mappend(a)\n",
      "\u001b[1;32m/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb 单元格 9\u001b[0m line \u001b[0;36m9\n\u001b[1;32m      <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=6'>7</a>\u001b[0m ac_diff \u001b[39m=\u001b[39m []\n\u001b[1;32m      <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=7'>8</a>\u001b[0m \u001b[39mfor\u001b[39;00m i \u001b[39min\u001b[39;00m seed:\n\u001b[0;32m----> <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=8'>9</a>\u001b[0m     val_df,cdt_actions,phy_actions,dieds \u001b[39m=\u001b[39m \u001b[39meval\u001b[39;49m(returns,costs,i)\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=9'>10</a>\u001b[0m     \u001b[39m# time = 0\u001b[39;00m\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=10'>11</a>\u001b[0m     \u001b[39m# cdt_actions = cdt_actions[time][0]\u001b[39;00m\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=11'>12</a>\u001b[0m     \u001b[39m# phy_actions = phy_actions[time][0]\u001b[39;00m\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=12'>13</a>\u001b[0m     \u001b[39m# dieds = dieds[time]\u001b[39;00m\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=13'>14</a>\u001b[0m     term \u001b[39m=\u001b[39m val_df[\u001b[39m'\u001b[39m\u001b[39mterminals\u001b[39m\u001b[39m'\u001b[39m]\n",
      "\u001b[1;32m/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb 单元格 9\u001b[0m line \u001b[0;36m2\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=17'>18</a>\u001b[0m \u001b[39mwhile\u001b[39;00m t:\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=18'>19</a>\u001b[0m     t,data_v \u001b[39m=\u001b[39m get_random1000(data_val,seed)\n\u001b[0;32m---> <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=19'>20</a>\u001b[0m agent_action,phy_action,action_ems \u001b[39m=\u001b[39m trainer\u001b[39m.\u001b[39;49mevaluate(data_v,eval_episodes,\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=20'>21</a>\u001b[0m                                      target_ret \u001b[39m*\u001b[39;49m \u001b[39m0.1\u001b[39;49m,\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=21'>22</a>\u001b[0m                                      target_cost \u001b[39m*\u001b[39;49m \u001b[39m1\u001b[39;49m)\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=23'>24</a>\u001b[0m cdt_actions\u001b[39m=\u001b[39magent_action\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X11sZmlsZQ%3D%3D?line=24'>25</a>\u001b[0m phy_actions\u001b[39m=\u001b[39mphy_action\n",
      "File \u001b[0;32m~/A-Sepsis-RL/Our-Model/CDT/osrl_cdt/algorithms/cdt.py:457\u001b[0m, in \u001b[0;36mCDTTrainer.evaluate\u001b[0;34m(self, val_df, num_rollouts, target_return, target_cost)\u001b[0m\n\u001b[1;32m    455\u001b[0m cdt_actions, phy_actions, actions_ems \u001b[39m=\u001b[39m [], [], []\n\u001b[1;32m    456\u001b[0m \u001b[39mfor\u001b[39;00m _ \u001b[39min\u001b[39;00m trange(num_rollouts, desc\u001b[39m=\u001b[39m\u001b[39m\"\u001b[39m\u001b[39mEvaluating...\u001b[39m\u001b[39m\"\u001b[39m, leave\u001b[39m=\u001b[39m\u001b[39mFalse\u001b[39;00m):\n\u001b[0;32m--> 457\u001b[0m     cdt_action,phy_action,action_ems \u001b[39m=\u001b[39m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49mrollout2(\u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49mmodel, val_df,\n\u001b[1;32m    458\u001b[0m                                               target_return, target_cost)\n\u001b[1;32m    459\u001b[0m     cdt_actions\u001b[39m.\u001b[39mappend(cdt_action)\n\u001b[1;32m    460\u001b[0m     phy_actions\u001b[39m.\u001b[39mappend(phy_action)\n",
      "File \u001b[0;32m~/anaconda3/envs/py38/lib/python3.8/site-packages/torch/utils/_contextlib.py:115\u001b[0m, in \u001b[0;36mcontext_decorator.<locals>.decorate_context\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    112\u001b[0m \u001b[39m@functools\u001b[39m\u001b[39m.\u001b[39mwraps(func)\n\u001b[1;32m    113\u001b[0m \u001b[39mdef\u001b[39;00m \u001b[39mdecorate_context\u001b[39m(\u001b[39m*\u001b[39margs, \u001b[39m*\u001b[39m\u001b[39m*\u001b[39mkwargs):\n\u001b[1;32m    114\u001b[0m     \u001b[39mwith\u001b[39;00m ctx_factory():\n\u001b[0;32m--> 115\u001b[0m         \u001b[39mreturn\u001b[39;00m func(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwargs)\n",
      "File \u001b[0;32m~/A-Sepsis-RL/Our-Model/CDT/osrl_cdt/algorithms/cdt.py:785\u001b[0m, in \u001b[0;36mCDTTrainer.rollout2\u001b[0;34m(self, model, val_df, target_return, target_cost)\u001b[0m\n\u001b[1;32m    781\u001b[0m \u001b[39m# first select history up to step, then select last seq_len states,\u001b[39;00m\n\u001b[1;32m    782\u001b[0m \u001b[39m# step + 1 as : operator is not inclusive, last action is dummy with zeros\u001b[39;00m\n\u001b[1;32m    783\u001b[0m \u001b[39m# (as model will predict last, actual last values are not important) # fix this noqa!!!\u001b[39;00m\n\u001b[1;32m    784\u001b[0m s \u001b[39m=\u001b[39m states[:, :step \u001b[39m+\u001b[39m \u001b[39m1\u001b[39m][:, \u001b[39m-\u001b[39mmodel\u001b[39m.\u001b[39mseq_len:]  \u001b[39m# noqa\u001b[39;00m\n\u001b[0;32m--> 785\u001b[0m a \u001b[39m=\u001b[39m actions[:, :step \u001b[39m+\u001b[39;49m \u001b[39m1\u001b[39;49m][:, \u001b[39m-\u001b[39;49mmodel\u001b[39m.\u001b[39;49mseq_len:]  \u001b[39m# noqa\u001b[39;00m\n\u001b[1;32m    786\u001b[0m r \u001b[39m=\u001b[39m returns[:, :step \u001b[39m+\u001b[39m \u001b[39m1\u001b[39m][:, \u001b[39m-\u001b[39mmodel\u001b[39m.\u001b[39mseq_len:]  \u001b[39m# noqa\u001b[39;00m\n\u001b[1;32m    787\u001b[0m c \u001b[39m=\u001b[39m costs[:, :step \u001b[39m+\u001b[39m \u001b[39m1\u001b[39m][:, \u001b[39m-\u001b[39mmodel\u001b[39m.\u001b[39mseq_len:]  \u001b[39m# noqa\u001b[39;00m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "iv_gap = []\n",
    "vaso_gap = []\n",
    "diff_gap = []\n",
    "x = []\n",
    "for r in range(15,40,1):\n",
    "        a,_,b,_,c,_,diff_df = get_gaps([r],[0])\n",
    "        x.append(r)\n",
    "        iv_gap.append(a)\n",
    "        vaso_gap.append(b)\n",
    "        diff_gap.append(c)\n",
    "\n",
    "plt.figure(figsize=(8,6))\n",
    "\n",
    "plt.plot(x,iv_gap,label='iv',marker='o')\n",
    "plt.plot(x,vaso_gap,label='vaso',marker='s')\n",
    "plt.plot(x,diff_gap,label='diff',marker='^')\n",
    "\n",
    "plt.title('Gaps')\n",
    "plt.xlabel('r')\n",
    "plt.ylabel('acc')\n",
    "\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.show()\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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</th>\n",
       "      <th>vaso</th>\n",
       "      <th>diff</th>\n",
       "      <th>r</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.5195</td>\n",
       "      <td>0.5490</td>\n",
       "      <td>0.5495</td>\n",
       "      <td>15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.5200</td>\n",
       "      <td>0.5375</td>\n",
       "      <td>0.5475</td>\n",
       "      <td>16</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.5195</td>\n",
       "      <td>0.5380</td>\n",
       "      <td>0.5480</td>\n",
       "      <td>17</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.5190</td>\n",
       "      <td>0.5380</td>\n",
       "      <td>0.5460</td>\n",
       "      <td>18</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.5175</td>\n",
       "      <td>0.5350</td>\n",
       "      <td>0.5440</td>\n",
       "      <td>19</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.5160</td>\n",
       "      <td>0.5330</td>\n",
       "      <td>0.5435</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>0.5155</td>\n",
       "      <td>0.5325</td>\n",
       "      <td>0.5425</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>0.5130</td>\n",
       "      <td>0.5270</td>\n",
       "      <td>0.5425</td>\n",
       "      <td>22</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>0.5115</td>\n",
       "      <td>0.5270</td>\n",
       "      <td>0.5420</td>\n",
       "      <td>23</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>0.5080</td>\n",
       "      <td>0.5310</td>\n",
       "      <td>0.5425</td>\n",
       "      <td>24</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>0.5090</td>\n",
       "      <td>0.5270</td>\n",
       "      <td>0.5415</td>\n",
       "      <td>25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>0.5065</td>\n",
       "      <td>0.5330</td>\n",
       "      <td>0.5425</td>\n",
       "      <td>26</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>0.5050</td>\n",
       "      <td>0.5340</td>\n",
       "      <td>0.5415</td>\n",
       "      <td>27</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>0.5020</td>\n",
       "      <td>0.5335</td>\n",
       "      <td>0.5410</td>\n",
       "      <td>28</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>0.5005</td>\n",
       "      <td>0.5300</td>\n",
       "      <td>0.5385</td>\n",
       "      <td>29</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>0.5000</td>\n",
       "      <td>0.5305</td>\n",
       "      <td>0.5385</td>\n",
       "      <td>30</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>0.4995</td>\n",
       "      <td>0.5310</td>\n",
       "      <td>0.5380</td>\n",
       "      <td>31</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>0.4990</td>\n",
       "      <td>0.5310</td>\n",
       "      <td>0.5380</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>0.4975</td>\n",
       "      <td>0.5305</td>\n",
       "      <td>0.5375</td>\n",
       "      <td>33</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>0.4975</td>\n",
       "      <td>0.5320</td>\n",
       "      <td>0.5370</td>\n",
       "      <td>34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>0.4980</td>\n",
       "      <td>0.5300</td>\n",
       "      <td>0.5360</td>\n",
       "      <td>35</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>0.4975</td>\n",
       "      <td>0.5295</td>\n",
       "      <td>0.5350</td>\n",
       "      <td>36</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>0.4980</td>\n",
       "      <td>0.5300</td>\n",
       "      <td>0.5350</td>\n",
       "      <td>37</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>0.4980</td>\n",
       "      <td>0.5300</td>\n",
       "      <td>0.5345</td>\n",
       "      <td>38</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>0.4975</td>\n",
       "      <td>0.5295</td>\n",
       "      <td>0.5340</td>\n",
       "      <td>39</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        iv    vaso    diff   r\n",
       "0   0.5195  0.5490  0.5495  15\n",
       "1   0.5200  0.5375  0.5475  16\n",
       "2   0.5195  0.5380  0.5480  17\n",
       "3   0.5190  0.5380  0.5460  18\n",
       "4   0.5175  0.5350  0.5440  19\n",
       "5   0.5160  0.5330  0.5435  20\n",
       "6   0.5155  0.5325  0.5425  21\n",
       "7   0.5130  0.5270  0.5425  22\n",
       "8   0.5115  0.5270  0.5420  23\n",
       "9   0.5080  0.5310  0.5425  24\n",
       "10  0.5090  0.5270  0.5415  25\n",
       "11  0.5065  0.5330  0.5425  26\n",
       "12  0.5050  0.5340  0.5415  27\n",
       "13  0.5020  0.5335  0.5410  28\n",
       "14  0.5005  0.5300  0.5385  29\n",
       "15  0.5000  0.5305  0.5385  30\n",
       "16  0.4995  0.5310  0.5380  31\n",
       "17  0.4990  0.5310  0.5380  32\n",
       "18  0.4975  0.5305  0.5375  33\n",
       "19  0.4975  0.5320  0.5370  34\n",
       "20  0.4980  0.5300  0.5360  35\n",
       "21  0.4975  0.5295  0.5350  36\n",
       "22  0.4980  0.5300  0.5350  37\n",
       "23  0.4980  0.5300  0.5345  38\n",
       "24  0.4975  0.5295  0.5340  39"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(columns=['iv','vaso','diff'],dtype=float)\n",
    "df['r'] = x\n",
    "df['iv'] = iv_gap\n",
    "df['vaso'] = vaso_gap\n",
    "df['diff'] = diff_gap\n",
    "df.head(n=30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bd77e26aba2a4eb5ad430939cb1dab38",
       "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": [
      "1000\n",
      "1000\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7a6f7c2fdc6a4478aee66aafa1b508ed",
       "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": [
      "1000\n",
      "1000\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8a37595cd017424b909899254d0ea1e4",
       "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": [
      "1000\n",
      "1000\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0fd9f92cb7e84e33adb7cd3e432627b0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Evaluating...:   0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[1;32m/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb 单元格 11\u001b[0m line \u001b[0;36m1\n\u001b[0;32m----> <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=0'>1</a>\u001b[0m ac_iv,ac_iv_std,ac_vaso,ac_vaso_std,ac_diff,ac_diff_std,diff \u001b[39m=\u001b[39m get_gaps([\u001b[39m36\u001b[39;49m],[\u001b[39m0\u001b[39;49m])\n",
      "\u001b[1;32m/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb 单元格 11\u001b[0m line \u001b[0;36m9\n\u001b[1;32m      <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=6'>7</a>\u001b[0m ac_diff \u001b[39m=\u001b[39m []\n\u001b[1;32m      <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=7'>8</a>\u001b[0m \u001b[39mfor\u001b[39;00m i \u001b[39min\u001b[39;00m seed:\n\u001b[0;32m----> <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=8'>9</a>\u001b[0m     val_df,cdt_actions,phy_actions,dieds \u001b[39m=\u001b[39m \u001b[39meval\u001b[39;49m(returns,costs,i)\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=9'>10</a>\u001b[0m     \u001b[39m# time = 0\u001b[39;00m\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=10'>11</a>\u001b[0m     \u001b[39m# cdt_actions = cdt_actions[time][0]\u001b[39;00m\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=11'>12</a>\u001b[0m     \u001b[39m# phy_actions = phy_actions[time][0]\u001b[39;00m\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=12'>13</a>\u001b[0m     \u001b[39m# dieds = dieds[time]\u001b[39;00m\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=13'>14</a>\u001b[0m     term \u001b[39m=\u001b[39m val_df[\u001b[39m'\u001b[39m\u001b[39mterminals\u001b[39m\u001b[39m'\u001b[39m]\n",
      "\u001b[1;32m/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb 单元格 11\u001b[0m line \u001b[0;36m2\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=17'>18</a>\u001b[0m \u001b[39mwhile\u001b[39;00m t:\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=18'>19</a>\u001b[0m     t,data_v \u001b[39m=\u001b[39m get_random1000(data_val,seed)\n\u001b[0;32m---> <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=19'>20</a>\u001b[0m agent_action,phy_action,action_ems \u001b[39m=\u001b[39m trainer\u001b[39m.\u001b[39;49mevaluate(data_v,eval_episodes,\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=20'>21</a>\u001b[0m                                      target_ret \u001b[39m*\u001b[39;49m \u001b[39m0.1\u001b[39;49m,\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=21'>22</a>\u001b[0m                                      target_cost \u001b[39m*\u001b[39;49m \u001b[39m1\u001b[39;49m)\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=23'>24</a>\u001b[0m cdt_actions\u001b[39m=\u001b[39magent_action\n\u001b[1;32m     <a href='vscode-notebook-cell:/home/fn/A-Sepsis-RL/Our-Model/show_cdt_rank.ipynb#X13sZmlsZQ%3D%3D?line=24'>25</a>\u001b[0m phy_actions\u001b[39m=\u001b[39mphy_action\n",
      "File \u001b[0;32m~/A-Sepsis-RL/Our-Model/CDT/osrl_cdt/algorithms/cdt.py:457\u001b[0m, in \u001b[0;36mCDTTrainer.evaluate\u001b[0;34m(self, val_df, num_rollouts, target_return, target_cost)\u001b[0m\n\u001b[1;32m    455\u001b[0m cdt_actions, phy_actions, actions_ems \u001b[39m=\u001b[39m [], [], []\n\u001b[1;32m    456\u001b[0m \u001b[39mfor\u001b[39;00m _ \u001b[39min\u001b[39;00m trange(num_rollouts, desc\u001b[39m=\u001b[39m\u001b[39m\"\u001b[39m\u001b[39mEvaluating...\u001b[39m\u001b[39m\"\u001b[39m, leave\u001b[39m=\u001b[39m\u001b[39mFalse\u001b[39;00m):\n\u001b[0;32m--> 457\u001b[0m     cdt_action,phy_action,action_ems \u001b[39m=\u001b[39m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49mrollout2(\u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49mmodel, val_df,\n\u001b[1;32m    458\u001b[0m                                               target_return, target_cost)\n\u001b[1;32m    459\u001b[0m     cdt_actions\u001b[39m.\u001b[39mappend(cdt_action)\n\u001b[1;32m    460\u001b[0m     phy_actions\u001b[39m.\u001b[39mappend(phy_action)\n",
      "File \u001b[0;32m~/anaconda3/envs/py38/lib/python3.8/site-packages/torch/utils/_contextlib.py:115\u001b[0m, in \u001b[0;36mcontext_decorator.<locals>.decorate_context\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    112\u001b[0m \u001b[39m@functools\u001b[39m\u001b[39m.\u001b[39mwraps(func)\n\u001b[1;32m    113\u001b[0m \u001b[39mdef\u001b[39;00m \u001b[39mdecorate_context\u001b[39m(\u001b[39m*\u001b[39margs, \u001b[39m*\u001b[39m\u001b[39m*\u001b[39mkwargs):\n\u001b[1;32m    114\u001b[0m     \u001b[39mwith\u001b[39;00m ctx_factory():\n\u001b[0;32m--> 115\u001b[0m         \u001b[39mreturn\u001b[39;00m func(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwargs)\n",
      "File \u001b[0;32m~/A-Sepsis-RL/Our-Model/CDT/osrl_cdt/algorithms/cdt.py:790\u001b[0m, in \u001b[0;36mCDTTrainer.rollout2\u001b[0;34m(self, model, val_df, target_return, target_cost)\u001b[0m\n\u001b[1;32m    787\u001b[0m c \u001b[39m=\u001b[39m costs[:, :step \u001b[39m+\u001b[39m \u001b[39m1\u001b[39m][:, \u001b[39m-\u001b[39mmodel\u001b[39m.\u001b[39mseq_len:]  \u001b[39m# noqa\u001b[39;00m\n\u001b[1;32m    788\u001b[0m t \u001b[39m=\u001b[39m time_steps[:, :step \u001b[39m+\u001b[39m \u001b[39m1\u001b[39m][:, \u001b[39m-\u001b[39mmodel\u001b[39m.\u001b[39mseq_len:]  \u001b[39m# noqa\u001b[39;00m\n\u001b[0;32m--> 790\u001b[0m acts, _, _ \u001b[39m=\u001b[39m model(s, a, r, c, t, \u001b[39mNone\u001b[39;49;00m, epi_cost)\n\u001b[1;32m    791\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39mstochastic:\n\u001b[1;32m    792\u001b[0m     acts \u001b[39m=\u001b[39m acts\u001b[39m.\u001b[39mmean\n",
      "File \u001b[0;32m~/anaconda3/envs/py38/lib/python3.8/site-packages/torch/nn/modules/module.py:1511\u001b[0m, in \u001b[0;36mModule._wrapped_call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1509\u001b[0m     \u001b[39mreturn\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_compiled_call_impl(\u001b[39m*\u001b[39margs, \u001b[39m*\u001b[39m\u001b[39m*\u001b[39mkwargs)  \u001b[39m# type: ignore[misc]\u001b[39;00m\n\u001b[1;32m   1510\u001b[0m \u001b[39melse\u001b[39;00m:\n\u001b[0;32m-> 1511\u001b[0m     \u001b[39mreturn\u001b[39;00m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_call_impl(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwargs)\n",
      "File \u001b[0;32m~/anaconda3/envs/py38/lib/python3.8/site-packages/torch/nn/modules/module.py:1520\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1515\u001b[0m \u001b[39m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1516\u001b[0m \u001b[39m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1517\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m (\u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_backward_hooks \u001b[39mor\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_backward_pre_hooks \u001b[39mor\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_forward_hooks \u001b[39mor\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_forward_pre_hooks\n\u001b[1;32m   1518\u001b[0m         \u001b[39mor\u001b[39;00m _global_backward_pre_hooks \u001b[39mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1519\u001b[0m         \u001b[39mor\u001b[39;00m _global_forward_hooks \u001b[39mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1520\u001b[0m     \u001b[39mreturn\u001b[39;00m forward_call(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwargs)\n\u001b[1;32m   1522\u001b[0m \u001b[39mtry\u001b[39;00m:\n\u001b[1;32m   1523\u001b[0m     result \u001b[39m=\u001b[39m \u001b[39mNone\u001b[39;00m\n",
      "File \u001b[0;32m~/A-Sepsis-RL/Our-Model/CDT/osrl_cdt/algorithms/cdt.py:221\u001b[0m, in \u001b[0;36mCDT.forward\u001b[0;34m(self, states, actions, returns_to_go, costs_to_go, time_steps, padding_mask, episode_cost)\u001b[0m\n\u001b[1;32m    217\u001b[0m         padding_mask \u001b[39m=\u001b[39m torch\u001b[39m.\u001b[39mcat([padding_mask[:, :\u001b[39m1\u001b[39m], padding_mask], dim\u001b[39m=\u001b[39m\u001b[39m1\u001b[39m)\n\u001b[1;32m    219\u001b[0m \u001b[39m# LayerNorm and Dropout (!!!) as in original implementation,\u001b[39;00m\n\u001b[1;32m    220\u001b[0m \u001b[39m# while minGPT & huggingface uses only embedding dropout\u001b[39;00m\n\u001b[0;32m--> 221\u001b[0m out \u001b[39m=\u001b[39m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49memb_norm(sequence)\n\u001b[1;32m    222\u001b[0m out \u001b[39m=\u001b[39m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39memb_drop(out)\n\u001b[1;32m    224\u001b[0m \u001b[39mfor\u001b[39;00m block \u001b[39min\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39mblocks:\n",
      "File \u001b[0;32m~/anaconda3/envs/py38/lib/python3.8/site-packages/torch/nn/modules/module.py:1511\u001b[0m, in \u001b[0;36mModule._wrapped_call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1509\u001b[0m     \u001b[39mreturn\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_compiled_call_impl(\u001b[39m*\u001b[39margs, \u001b[39m*\u001b[39m\u001b[39m*\u001b[39mkwargs)  \u001b[39m# type: ignore[misc]\u001b[39;00m\n\u001b[1;32m   1510\u001b[0m \u001b[39melse\u001b[39;00m:\n\u001b[0;32m-> 1511\u001b[0m     \u001b[39mreturn\u001b[39;00m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_call_impl(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwargs)\n",
      "File \u001b[0;32m~/anaconda3/envs/py38/lib/python3.8/site-packages/torch/nn/modules/module.py:1520\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1515\u001b[0m \u001b[39m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1516\u001b[0m \u001b[39m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1517\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m (\u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_backward_hooks \u001b[39mor\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_backward_pre_hooks \u001b[39mor\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_forward_hooks \u001b[39mor\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_forward_pre_hooks\n\u001b[1;32m   1518\u001b[0m         \u001b[39mor\u001b[39;00m _global_backward_pre_hooks \u001b[39mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1519\u001b[0m         \u001b[39mor\u001b[39;00m _global_forward_hooks \u001b[39mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1520\u001b[0m     \u001b[39mreturn\u001b[39;00m forward_call(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwargs)\n\u001b[1;32m   1522\u001b[0m \u001b[39mtry\u001b[39;00m:\n\u001b[1;32m   1523\u001b[0m     result \u001b[39m=\u001b[39m \u001b[39mNone\u001b[39;00m\n",
      "File \u001b[0;32m~/anaconda3/envs/py38/lib/python3.8/site-packages/torch/nn/modules/normalization.py:201\u001b[0m, in \u001b[0;36mLayerNorm.forward\u001b[0;34m(self, input)\u001b[0m\n\u001b[1;32m    200\u001b[0m \u001b[39mdef\u001b[39;00m \u001b[39mforward\u001b[39m(\u001b[39mself\u001b[39m, \u001b[39minput\u001b[39m: Tensor) \u001b[39m-\u001b[39m\u001b[39m>\u001b[39m Tensor:\n\u001b[0;32m--> 201\u001b[0m     \u001b[39mreturn\u001b[39;00m F\u001b[39m.\u001b[39;49mlayer_norm(\n\u001b[1;32m    202\u001b[0m         \u001b[39minput\u001b[39;49m, \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49mnormalized_shape, \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49mweight, \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49mbias, \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49meps)\n",
      "File \u001b[0;32m~/anaconda3/envs/py38/lib/python3.8/site-packages/torch/nn/functional.py:2546\u001b[0m, in \u001b[0;36mlayer_norm\u001b[0;34m(input, normalized_shape, weight, bias, eps)\u001b[0m\n\u001b[1;32m   2542\u001b[0m \u001b[39mif\u001b[39;00m has_torch_function_variadic(\u001b[39minput\u001b[39m, weight, bias):\n\u001b[1;32m   2543\u001b[0m     \u001b[39mreturn\u001b[39;00m handle_torch_function(\n\u001b[1;32m   2544\u001b[0m         layer_norm, (\u001b[39minput\u001b[39m, weight, bias), \u001b[39minput\u001b[39m, normalized_shape, weight\u001b[39m=\u001b[39mweight, bias\u001b[39m=\u001b[39mbias, eps\u001b[39m=\u001b[39meps\n\u001b[1;32m   2545\u001b[0m     )\n\u001b[0;32m-> 2546\u001b[0m \u001b[39mreturn\u001b[39;00m torch\u001b[39m.\u001b[39;49mlayer_norm(\u001b[39minput\u001b[39;49m, normalized_shape, weight, bias, eps, torch\u001b[39m.\u001b[39;49mbackends\u001b[39m.\u001b[39;49mcudnn\u001b[39m.\u001b[39;49menabled)\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "ac_iv,ac_iv_std,ac_vaso,ac_vaso_std,ac_diff,ac_diff_std,diff = get_gaps([39],[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.5515000000000001 0.004555216789572153 0.629 0.014594519519326438 0.5775 0.004974937185533105\n"
     ]
    }
   ],
   "source": [
    "print(ac_iv,ac_iv_std,ac_vaso,ac_vaso_std,ac_diff,ac_diff_std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import random\n",
    "def get_gapst(returns,costs):\n",
    "    seed = [0,10,20,30]\n",
    "    p_iv = []\n",
    "    p_vaso = []\n",
    "    p_diff = []\n",
    "    for i in seed:\n",
    "        val_df,cdt_actions,phy_actions,dieds = eval(returns,costs,i)\n",
    "\n",
    "        term = val_df['terminals']\n",
    "        iv_diff,vaso_diff,diff,die=get_iv_vaso(1000,cdt_actions,phy_actions,dieds,term)\n",
    "\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",
    "        topN_alive = []\n",
    "        lastN_dead = []\n",
    "        #print(\"seed:\",i,\"_CDT排序正确的比率\")\n",
    "        for j in range(len(l)):\n",
    "            df = diff_df.sort_values(l[j])\n",
    "            top,last = 0,0\n",
    "            num = 0\n",
    "            topn,lastn = 0,0\n",
    "            for t in df.index:\n",
    "                num += 1\n",
    "                if df.loc[t,'die']==0 and num<=500:\n",
    "                    top+=df.loc[t,l[j]]\n",
    "                    topn+=1\n",
    "                elif df.loc[t,'die']==1 and num>500:\n",
    "                    last+=df.loc[t,l[j]]\n",
    "                    lastn+=1\n",
    "            topN_alive.append(top/topn)\n",
    "            lastN_dead.append(last/lastn)\n",
    "            print(top,topn,last,lastn)\n",
    "        p_iv.append(topN_alive[0])\n",
    "        p_vaso.append(topN_alive[1])\n",
    "        p_diff.append(topN_alive[2])\n",
    "            #print(diff_df)\n",
    "    return p_iv,p_vaso,p_diff"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d65d73972ed54c709a567ce4d53be240",
       "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": [
      "1000\n",
      "1000\n",
      "1.840985386306277 288 43.96243741768865 288\n",
      "0.0 316 6708.241323970416 316\n",
      "1.0611474703270152 296 3376.006679998354 296\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3deb59a162b944a9afc466675cbe2c1e",
       "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": [
      "1000\n",
      "1000\n",
      "2.0179134509866508 292 46.0645200519061 292\n",
      "0.0 317 1332.2906079118775 317\n",
      "1.186234532927451 302 689.087145254708 302\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d2de1ecd6e9b466aa69bb0058ec2de37",
       "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": [
      "1000\n",
      "1000\n",
      "1.7772679430154705 284 75.1886325155634 284\n",
      "0.0 307 104.20559561196 307\n",
      "1.1050878872626266 298 89.58996379203114 298\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dcf9ea89a3c44555933a5c2e65e3a63e",
       "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": [
      "1000\n",
      "1000\n",
      "1.7818850678901534 281 44.29686320316388 281\n",
      "0.0 321 55.93126878382246 321\n",
      "1.0628798755085591 297 50.080715341855736 297\n"
     ]
    }
   ],
   "source": [
    "p_iv,p_vaso,p_diff = get_gapst([39],[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Piv: 0.006475546646737563 0.0002557480912273426\n",
      "Pvaso: 0.0 0.0\n",
      "Paction: 0.003699988830383677 0.00014139027296317932\n"
     ]
    }
   ],
   "source": [
    "print(\"Piv:\",np.mean(p_iv),np.std(p_iv))\n",
    "print(\"Pvaso:\",np.mean(p_vaso),np.std(p_vaso))\n",
    "print(\"Paction:\",np.mean(p_diff),np.std(p_diff))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "#path  = \"./My_model/cdt_cost0.pt\"\n",
    "#path =f'./Mymodel/cdt_c6.pt'\n",
    "path = \"./My_model/cdt3.pt\"\n",
    "noise_scale = None\n",
    "eval_episodes = 20\n",
    "best = False\n",
    "device = \"cpu\"\n",
    "threads = 4\n",
    "state_dim = 48\n",
    "action_dim = 2\n",
    "max_action = [1.0,1.0]\n",
    "    \n",
    "if device == \"cpu\":\n",
    "    torch.set_num_threads(threads)\n",
    "\n",
    "target_entropy = -2\n",
    "\n",
    "dataset_path_val = f'./data/sepsis_data/val_policy_data.pkl'\n",
    "with open(dataset_path_val,'rb') as f:\n",
    "        data_val = pickle.load(f)\n",
    "# model & optimizer & scheduler setup\n",
    "cdt_model = CDT(\n",
    "        state_dim=48,\n",
    "        action_dim=2,\n",
    "        max_action=[1,1],\n",
    "        embedding_dim=128,\n",
    "        seq_len=10,\n",
    "        episode_len=300,\n",
    "        num_layers=3,\n",
    "        num_heads=8,\n",
    "        attention_dropout=0.1,\n",
    "        residual_dropout=0.1,\n",
    "        embedding_dropout=0.1,\n",
    "        time_emb=True,\n",
    "        use_rew=True,\n",
    "        use_cost=True,\n",
    "        cost_transform=True,\n",
    "        add_cost_feat=False,\n",
    "        mul_cost_feat=False,\n",
    "        cat_cost_feat=False,\n",
    "        action_head_layers=1,\n",
    "        cost_prefix=False,\n",
    "        stochastic=True,\n",
    "        init_temperature=0.1,\n",
    "        target_entropy=target_entropy,\n",
    "    )\n",
    "cdt_model.load_state_dict(torch.load(path))\n",
    "cdt_model.to(device)\n",
    "\n",
    "trainer = CDTTrainer(cdt_model,\n",
    "                    #costnet,\n",
    "                    reward_scale=0.1,\n",
    "                    cost_scale=1,\n",
    "                    cost_reverse=False,\n",
    "                    device=device)\n",
    "\n",
    "target_ret = 24\n",
    "target_cost = 0\n",
    "eval_episodes = 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "差距和死亡率的关系"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b48dcc1c08ef49ee8dd21b62741a42fb",
       "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",
    "val_df1 = get_val_some_path(data_val,batch_size=5000,seed=seed)\n",
    "agent_action,phy_action,action_ems = trainer.evaluate(val_df1,eval_episodes,\n",
    "                                        target_ret * 0.1,\n",
    "                                        target_cost * 1)\n",
    "        \n",
    "cdt_actions.append(agent_action)\n",
    "phy_actions.append(phy_action)\n",
    "dieds.append(val_df1['dieds'])\n",
    "val_df.append(val_df1)\n",
    "terminals.append(val_df1['terminals'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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",
    "        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": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "cdt_actions = agent_action[0]\n",
    "phy_actions = phy_action[0]\n",
    "dieds = val_df1['dieds']\n",
    "term = val_df1['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'] = iv1\n",
    "df_all['vaso_cdt'] = vaso1\n",
    "df_all['iv_phy'] = iv2\n",
    "df_all['vaso_phy'] = vaso2\n",
    "df_all['die'] = val_df1['dieds']\n",
    "df_all['term'] = val_df1['terminals']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5.0 35.7140007019043\n"
     ]
    }
   ],
   "source": [
    "print(max(df_all['vaso_cdt']),max(df_all['vaso_phy']))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "DISTRIBUTION"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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LzU1VZLk7+8vSbLZbNq9e7dycnLMmMTERFmtVvMUdZvNpvXr19ttJzEx0e668fJYLBbzUWZlEwAAtRWnlwMAUAvFxMRo4MCBatGihU6ePKmEhAQlJSVpzZo1OnDggBISEjRo0CA1adJEu3bt0sSJE9WrVy917txZktS/f38FBwdr+PDhmj17trKysjR16lRFR0fLYrFIksaOHat33nlHL7zwgp544glt2LBBn376qVauXFmdXQcAoEah6AYAoBbKycnRiBEjdPToUXl6eqpz585as2aN7r77bh0+fFjr1q3Tm2++qdOnTyswMFCRkZGaOnWqub6Li4tWrFihcePGyWazqUGDBho5cqTdc71btWqllStXauLEiZo3b56aN2+uv//97zwuDACA81B0AwBQC7333nuXbAsMDNSmTZuuuI2goCCtWrXqsjF9+vTRzp07K5wfAAB1BUU3LtLyRfvTAg/NiqimTAAAAADg+saN1AAAAAAAcBCKbgAAAAAAHISiGwAAAAAAB6HoBgAAAADAQSi6AQAAAABwEIpuAAAAAAAchKIbAAAAAAAHoegGAAAAAMBBKLoBAAAAAHAQim4AAAAAAByEohsAAAAAAAeh6AYAAAAAwEEougEAAAAAcBCKbgAAAAAAHISiGwAAAAAAB6HoBgAAAADAQSi6AQAAAABwEIpuAAAAAAAchKIbAAAAAAAHqfSiOzY2VrfddpsaNWokHx8fDRkyROnp6XYxffr0kZOTk900duxYu5jMzExFRETIw8NDPj4+mjx5soqLiys7XQAAAAAAHMa1sje4adMmRUdH67bbblNxcbH+8Ic/qH///tq7d68aNGhgxo0ePVozZ8405z08PMy/S0pKFBERIT8/P23dulVHjx7ViBEjVK9ePb366quVnTIAAAAAAA5R6UX36tWr7ebj4uLk4+OjlJQU9erVy1zu4eEhPz+/crexdu1a7d27V+vWrZOvr6+6du2qV155RVOmTNH06dPl5uZW2WkDAAAAAFDpHH5Nd15eniTJ29vbbnl8fLyaNm2qjh07KiYmRmfOnDHbkpOT1alTJ/n6+prLwsPDlZ+fr7S0NEenDAAAAABApaj0I93nKy0t1YQJE3TnnXeqY8eO5vJHHnlEQUFBCggI0K5duzRlyhSlp6frs88+kyRlZWXZFdySzPmsrKxyX6ugoEAFBQXm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ZNu3b9egQYPUuHFjNWjQQJ07d9a8efMkSR988IGcnJy0c+fOi7b36quvysXFRf/73/+uui+BgYHq1auX/vWvf5X7byMhIUGtW7dWaGjoVW8TAGozxmHG4Wsdh93d3fXAAw9o/fr1ysnJuag9ISFBjRo10n333acTJ07o97//vTp16qSGDRvKarVq4MCB+u677y5a7+2331aHDh3k4eGhxo0b69Zbb1VCQoJdzM6dOzVw4EBZrVY1bNhQ/fr107Zt2y67f1D3UHQD/9+BAwck6aLTjp555hl99913evnllzVu3DgtX75c48ePN9uHDx+u48ePa82aNXbrZWVlacOGDXr00UclSWlpabrnnntUUFCgmTNn6vXXX9d9992nr7/++rJ57dq1S6GhodqwYYNGjx6tefPmaciQIVq+fPll14uLi1PDhg01adIkzZs3TyEhIZo2bZpefPHFi2J/+eUXDRgwQF26dNHrr7+udu3aacqUKfryyy8v+xqRkZFaunSpHn/8cS1YsEDPPvusTp48qczMzMuudynnvweGYei+++7T3LlzNWDAAL3xxhtq27atJk+erEmTJlV424mJierVq5f27t2r5557Tq+//rr69u2rFStWSPr11353d3fFx8dftG58fLz69OmjG264oUKvGRUVVe6/jd27d2vPnj384g4A52EcZhz+LeNwVFSUiouL9emnn9otP3HihNasWaP7779f7u7uOnjwoD7//HPdc889euONNzR58mTt3r1bvXv31pEjR8z1/va3v+nZZ59VcHCw3nzzTc2YMUNdu3bV9u3bzZi0tDT17NlT3333nV544QW99NJLysjIUJ8+feziABlAHfPBBx8Ykox169YZx44dMw4fPmwsXrzYaNKkieHu7m789NNPdnFhYWFGaWmpuf7EiRMNFxcXIzc31zAMwygpKTGaN29uPPzww3av88YbbxhOTk7GwYMHDcMwjLlz5xqSjGPHjl0yt4yMDEOS8cEHH5jLevXqZTRq1Mj48ccf7WLPz6ks14yMDHPZmTNnLtr+U089ZXh4eBjnzp0zl/Xu3duQZPzjH/8wlxUUFBh+fn5GZGTkJXP95ZdfDEnGnDlzLhlzKS+//LIhyUhPTzeOHTtmZGRkGH/9618Ni8Vi+Pr6GqdPnzY+//xzQ5Lxpz/9yW7dBx980HBycjL2799vLgsKCjJGjhxpzm/cuNGQZGzcuNEwDMMoLi42WrVqZQQFBRm//PKL3fbO34/Dhg0zAgICjJKSEnPZf/7zn4vek/KUvQfffvutuezEiROGxWIxhg0bZhf74osvmv0HgLqGcZhx+HyVNQ4XFxcb/v7+hs1ms1u+aNEiQ5KxZs0awzAM49y5c3bbN4xf33eLxWLMnDnTXDZ48GCjQ4cOl33NIUOGGG5ubsaBAwfMZUeOHDEaNWpk9OrV67Lrom7hSDfqrLCwMDVr1kyBgYEaOnSoGjZsqKVLl170K+qYMWPsbibSs2dPlZSU6Mcff5T063VLUVFR+uKLL+zumhkfH6877rhDrVq1kiR5eXlJ+vV0s9LS0qvK8dixY9q8ebOeeOIJtWjRwq7tSjc4cXd3N/8+efKkfv75Z/Xs2VNnzpzR999/bxfbsGFD80iAJLm5uen222/XwYMHL7t9Nzc3JSUl6Zdffrmq/lyobdu2atasmVq1aqWnnnpKbdq00cqVK+Xh4aFVq1bJxcVFzz77rN06zz//vAzDuOKv/+fbuXOnMjIyNGHCBPN9KHP+fhwxYoSOHDmijRs3msvi4+Pl7u6uyMjICvevcePGGjRokL744gudPn1akmQYhhYvXqxbb71VN998c4W3CQC1BePw/2Ec/tVvGYddXFw0dOhQJScn251en5CQIF9fX/Xr10+SZLFY5Oz8awlUUlKi48ePm5ca/Oc//zHX8/Ly0k8//aRvv/223NcrKSnR2rVrNWTIEN14443mcn9/fz3yyCP66quvrss7wcMxKLpRZ82fP1+JiYnauHGj9u7dq4MHDyo8PPyiuAsH2caNG0uS3QA3YsQInT17VkuXLpUkpaenKyUlRcOHDzdjHn74Yd1555168skn5evrq6FDh+rTTz+97MBfNth27Nixwv1LS0vT/fffL09PT1mtVjVr1swc0PPy8uximzdvftGXh8aNG192ELdYLPrLX/6iL7/8Ur6+vurVq5dmz56trKysq87x3//+txITE5WUlKT9+/drz549CgkJkST9+OOPCggIUKNGjezWad++vdl+tcpOl7vSfrz77rvl7+9vntpWWlqqjz/+WIMHD74oj6sVFRWl06dPa9myZZKkrVu36tChQ5xaDqDOYxz+P4zDv/qt43DZ2Fp23fVPP/2kLVu2aOjQoeaN7kpLSzV37lzddNNNslgsatq0qZo1a6Zdu3bZvS9TpkxRw4YNdfvtt+umm25SdHS03aUIx44d05kzZ+zuGVCmffv2Ki0t1eHDh6+YM+oGim7UWbfffrvCwsLUp08ftW/f3vzV80KXuhupcd5NRIKDgxUSEqKPPvpIkvTRRx/Jzc1NDz30kBnj7u6uzZs3a926dRo+fLh27dqlhx9+WHffffdFN1X5rXJzc9W7d2999913mjlzppYvX67ExET95S9/kaSLvmBcTR/LM2HCBP33v/9VbGys6tevr5deeknt27cv9yYo5enVq5fCwsLUu3dvtW7d+qrWcSQXFxc98sgj+ve//61z585p48aNOnLkiN3Rh4q655575OnpaX4BSEhIMH+NB4C6jHG4Yn0sD+OwvZCQELVr104ff/yxpPKfFPLqq69q0qRJ6tWrlz766COtWbNGiYmJ6tChg9370r59e6Wnp2vx4sXq0aOH/v3vf6tHjx56+eWXK7fTqBMouoFKMmLECG3YsEFHjx5VQkKCIiIizF/jyzg7O6tfv3564403tHfvXvN5mOefRnW+stOV9uzZU6FckpKSdPz4ccXFxem5557TPffco7CwsIvyqQytW7fW888/r7Vr12rPnj0qLCzU66+//pu3GxQUpCNHjtidKijJPCUvKCioQjlKV7cfR4wYofz8fC1fvlzx8fFq1qxZuUderpbFYtGDDz6otWvXKjs7W0uWLNFdd90lPz+/a94mAOBijMOMw9KvR7v37NmjXbt2KSEhQTfddJNuu+02s/1f//qX+vbtq/fee09Dhw5V//79FRYWptzc3Iu21aBBAz388MP64IMPlJmZqYiICP35z3/WuXPn1KxZM3l4eCg9Pf2i9b7//ns5OzsrMDDwqvNG7UbRDVSSYcOGycnJSc8995wOHjx40a+yJ06cuGidrl27Svr1cSjladasmXr16qX333//ojuRXu7X77JfzM+PKSws1IIFC66qL1fjzJkzOnfunN2y1q1bq1GjRpfsT0UMGjRIJSUleuedd+yWz507V05OTho4cOBVb6tbt25q1aqV3nzzzYsG1Qv3Y+fOndW5c2f9/e9/17///W8NHTpUrq6u19wP6dcvAEVFRXrqqad07NgxTi0HAAdgHGYclv7vFPNp06YpNTX1ojHXxcXlotdcsmTJRY8jO378uN28m5ubgoODZRiGioqK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wADNnj1bsbGxWrZsmSoqKrR48WIFBQWpU6dOys/P15w5czyKcwAALlac6QYA4CK2efNmRUVFqV27dhozZoy+//57qy8nJ0cRERFWwS1JSUlJ8vf3V25urhXTq1cvBQUFWTHJyckqKCjQDz/8UOsyy8vL5Xa7PRoAAI0VRTcAABepfv366bXXXlN2draeeeYZbdmyRf3799eJEyckSS6XS1FRUR7vCQwMVGRkpFwulxUTHR3tEVPzuibmZNOnT1d4eLjV4uLivD00AAB8Bl8vBwDgIjVkyBDr5y5duqhr165q27atNm/erD59+ti23IyMDI0fP9567Xa7KbwBAI0WZ7oBAIAkqU2bNmrVqpX2798vSXI4HCopKfGIqaqq0uHDh63rwB0Oh4qLiz1ial6f7lrx4OBghYWFeTQAABorim4AACBJ+vrrr/X9998rJiZGkuR0OlVaWqq8vDwrZuPGjaqurlZiYqIVs3XrVlVWVloxWVlZateunVq0aFG/AwAAwAdRdAMA0EgdPXpU+fn5ys/PlyQVFhYqPz9fRUVFOnr0qCZMmKCPP/5YX331lbKzszVw4EBdccUVSk5OliR16NBB/fr108iRI/XJJ5/oo48+Unp6uoYMGaLY2FhJ0r333qugoCCNGDFCu3fv1sqVK/X88897fH0cAICLGUU3AACN1KeffqprrrlG11xzjSRp/PjxuuaaazR58mQFBARox44duuOOO3TVVVdpxIgR6t69uz744AMFBwdb81i2bJnat2+vPn36aMCAAbrppps8nsEdHh6u9evXq7CwUN27d9cjjzyiyZMn87gwAAD+FzdSAwCgkerdu7eMMaftX7du3VnnERkZqeXLl58xpmvXrvrggw/qnB8AABcDznQDAAAAAGATim4AAAAAAGxC0Q0AAAAAgE0ougEAAAAAsAlFNwAAAAAANqHoBgAAAADAJhTdAAAAAADYhKIbAAAAAACbUHQDAAAAAGATim4AAAAAAGxC0Q0AAAAAgE0ougEAAAAAsAlFNwAAAAAANqHoBgAAAADAJhTdAAAAAADYhKIbAAAAAACbUHQDAAAAAGATim4AAAAAAGxC0Q0AAAAAgE1sL7pnzJghPz8/jR071pp2/PhxpaWlqWXLlrrkkks0ePBgFRcXe7yvqKhIKSkpatq0qaKiojRhwgRVVVXZnS4AAAAAAF5j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",
      "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",
    "axs[0, 0].hist(df_all['iv_cdt']*2000, 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']*2000, 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",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "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": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "alive vaso>0.75: 0.0\n",
      "dead iv>1000: 0.006693760459000717\n"
     ]
    }
   ],
   "source": [
    "# alive patients vaso and iv difference between cdt and physician\n",
    "print(\"alive vaso>0.75:\",len(alive_df[alive_df['vaso_cdt']-alive_df['vaso_phy']>0.5])/len(alive_df))\n",
    "print(\"dead iv>1000:\",len(alive_df[alive_df['iv_cdt']*2000-alive_df['iv_phy']*2000>750])/len(alive_df))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dead vaso>0.75: 0.0\n",
      "dead iv>1000: 0.0208078335373317\n"
     ]
    }
   ],
   "source": [
    "# die patients vaso and iv difference between cdt and physician\n",
    "print(\"dead vaso>0.75:\",len(die_df[die_df['vaso_cdt']-die_df['vaso_phy']>0.5])/len(die_df))\n",
    "print(\"dead iv>1000:\",len(die_df[die_df['iv_cdt']*2000-die_df['iv_phy']*2000>750])/len(die_df))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "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": 19,
   "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": 20,
   "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": 21,
   "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": 22,
   "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.6\n",
    "    while i <= 0.8:\n",
    "        count =df_diff.loc[(df_diff['vaso_diff']>i-0.1) & (df_diff['vaso_diff']<i+0.1)] # 0.15\n",
    "        try:\n",
    "            res = sum(count['mort'])/float(len(count)) \n",
    "            if len(count) >=5: # 5\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.2\n",
    "    return bin_medians_vaso, mort_vaso, mort_std_vaso # 药量，死亡率，死亡的标准误差"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_diff_DDPG = pd.read_csv('../DDPG/df_diff_DDPG.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "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']*2000\n",
    "_agent['vaso']= df_all['vaso_cdt']\n",
    "\n",
    "_phy['iv']= df_all['iv_phy']*2000\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",
    "bin_med_iv_DDPG, mort_iv_DDPG, mort_std_iv_DDPG = make_iv_plot_data(df_diff_DDPG)\n",
    "bin_med_vaso_DDPG, mort_vaso_DDPG, mort_std_vaso_DDPG = make_vaso_plot_data(df_diff_DDPG)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.88, -0.03, 'IV DIFF')"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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5enpqd5//33HMY39mW4M9f1cusL69etVXFyc6t69u3r44Ycd2x944AEVGxurVqxYoTZs2KAuvvhiNXDgQMf+2rzHmtqMGTNUcHCw+u6779ShQ4fUokWLlI+Pj3rzzTcdx7z88svK399fff3112rr1q3quuuuU+3atVOlpaWOYxryM7MlcnUO05A4qjRGLtOQWBqS11RxdX7TkFgaO9epbxxVGivnaUgsjZ3/1DcOd82DWlpeUxstLfepjeaUH9VGc86hastdci0pStXRzp07FaD++OMPx7bvv/9e6XQ6deLEiXM+rn///urpp592WftKKbV582YVHR2tUlNT653INaT9033++efKw8NDVVZWnve4fv36qSlTpjju22w2FRUVpWbOnHnW42+++WY1atSoatv69++v7r///lrH1pD2z2S1WpWvr6+aN2+e09q3Wq1q4MCB6t///reaOHFigxK0urb/7rvvqvj4eFVRUVHvNhvS/pQpU9Tll19ebdsjjzyiLrnkkkaJxxkyMzMVoH7++WfHtoKCAgWo5cuXK6WUWrp0qdLr9SotLc1xzLvvvqv8/PxUeXm5Ukqpxx9/XHXp0qXac48bN04NHz7cCWdxytKlS1ViYqJKTk6ukZjNnj1bBQYGOmJWSqknnnhCderUyXG/sT/TjaGh1wVnKSwsVB07dlTLly9XQ4YMcSRUeXl5ymQyqUWLFjmO3bVrlwLU2rVrlVK1e481tVGjRqm777672rYxY8ao2267TSmllN1uVxEREeqVV15x7M/Ly1Nms1l99tlnSqnG+5nVUrg6h2loHEo1Ti7TWLGcrrZ5TRVX5zcNieVMDc11GhJHY+Y8DYmlsfOf+sbhjnlQS8traqMl5j610Vzyo9po7jlUbblLriXD9+po7dq1BAQE0LdvX8e2YcOGodfr+f3338/6mIyMDH7//XfCwsIYOHAg4eHhDBkyhF9++cUp7QOUlJRw66238s477xAREVHndhva/pny8/Px8/PDaDSe85iKigo2btzIsGHDHNv0ej3Dhg1j7dq154zv9OMBhg8ffs7jz6c+7Z+ppKSEyspKgoKCnNb+888/T1hYGJMmTapzmw1t/9tvv2XAgAFMmTKF8PBwunbtyksvvYTNZnNK+wMHDmTjxo2OrsIHDx5k6dKlXH311XVu31WCg4Pp1KkTn3zyCcXFxVitVt5//33CwsLo06cPoL3Pu3XrRnh4uONxw4cPp6CggOTkZMcxjfVZqK/09HTuvfde/vOf/+Dl5VVj/9q1a7n00kvx8PCoFuOePXvIzc11HOPq8zhdY1wXnGXKlCmMGjWqxuu3ceNGKisrq21PTEykTZs2jnOozXusqQ0cOJAVK1awd+9eALZu3covv/zCyJEjATh06BBpaWnVzsPf35/+/ftXO4/G+JnVUrg6h2lIHNB4uUxjxHKm2uQ1VVyd3zQ0ljM1JNdpaByNlfM0NJbGzH8aEoc75kEtKa+pjZaY+9RGc8qPaqO551C15S651oV/copq0tLSCAsLq7bNaDQSFBREWlraWR9z8OBBAJ577jleffVVevbsySeffMIVV1zBjh076NixY5O2DzBt2jQGDhzI9ddfX+u2GrP902VlZfHCCy9w3333XfA4m81W7QMNEB4ezu7du88Z39mOr21sDW3/TE888QRRUVE1LmhN1f4vv/zCRx99VGPsen3Up/2DBw+ycuVKbrvtNpYuXcr+/fuZPHkylZWVPPvss03e/q233kpWVhaDBg1CKYXVauWBBx7gr3/9a53adiWdTsdPP/3E6NGj8fX1Ra/XExYWxrJlywgMDATO/T6v2ne+YwoKCigtLcXT07NJz0MpxZ133skDDzxA3759OXz4cI1j0tLSaNeuXY0Yq/YFBgY26me6MTTGdcEZFixYwKZNm/jjjz9q7EtLS8PDw4OAgIBq209/XWvzHmtqTz75JAUFBSQmJmIwGLDZbMyYMYPbbrutWhzne380xs+slsTVOUxD4oDGy2UaI5bT1TavOf14V+Y3DY3lTA3JdRoSR2PmPA2NpTHzn4bE4Y55UEvJa2qjpeY+tdFc8qPaaAk5VG25S64lPaVOevLJJ9HpdOe91fcDZbfbAbj//vu566676NWrF2+88QadOnVizpw5Td7+t99+y8qVK5k1a9Y5j2nK9k9XUFDAqFGjSEpK4rnnnmvw87mzl19+mQULFvDVV19hsViavL3CwkImTJjAhx9+SEhISJO3dzZ2u52wsDA++OAD+vTpw7hx43jqqad47733nNL+6tWreemll5g9ezabNm1i8eLFLFmyhBdeeMEp7Z9PbT9jSimmTJlCWFgYa9asYf369YwePZprr72W1NRUV59Grc/jrbfeorCwkOnTp7s65Fbn2LFjPPzww8yfP98p156m8vnnnzN//nw+/fRTNm3axLx583j11VeZN2+eq0NzO67OYZwRR21yGWfFcrrWlNecjbNznSrukPOcztX5TxVn5kEtJa+pDcl9Wo+WkkPVlrvkWtJT6qRHH32UO++887zHxMfHExERQUZGRrXtVquVnJycc3Ylj4yMBCApKana9s6dO3P06NEmb3/lypUcOHCgRkV37NixDB48mNWrVzdp+1UKCwsZMWIEvr6+fPXVV5hMpvMeHxISgsFgqLGaQXp6+jnbioiIqNPxjd1+lVdffZWXX36Zn376ie7du9e57fq0f+DAAQ4fPsy1117r2Fb1y4TRaGTPnj20b9++ydoH7b1uMpkwGAyObZ07dyYtLY2KiopqXZWbov2//e1vTJgwgXvuuQeAbt26UVxczH333cdTTz2FXu+6OnxtP2MrV67ku+++Izc3Fz8/PwBmz57N8uXLmTdvHk8++SQRERE1VjOpep2qXptzfRb8/Pwa9NfEupzH2rVrMZvN1fb17duX2267jXnz5p0zxtqcR2MN3amrhlwXnGXjxo1kZGTQu3dvxzabzcbPP//M22+/zQ8//EBFRQV5eXnVfi6cfg61eY81tccee4wnn3ySW265BdA+z0eOHGHmzJlMnDjREUd6errj52zV/Z49ezpire/PrObE1TmMM+KoTS7jrFiq1DWvqeLq/KahsVRpjFynvnE0ds7TkFigcfOfhsThzDyopeQ1tdHac5/aaA75UW20lByqttwm16r/tFitU9VEXhs2bHBs++GHH847kZfdbldRUVE1Jgnt2bNnnWfhr0/7qampavv27dVugHrzzTfVwYMHm7x9pbSVJi6++GI1ZMgQVVxcXOv2+vXrpx588EHHfZvNpqKjo887Eeg111xTbduAAQMaNNF5XdpXSql//OMfys/PzzHZXUPUpf3S0tIa3+frr79eXX755Wr79u31mlivruc/ffp01bZtW2Wz2RzbZs2apSIjI+vcdn3a7927t3r88cerbfv000+Vp6enslqt9YrB2b799lul1+tVYWFhte0JCQlqxowZSqlTEyievprJ+++/r/z8/ByrYT3++OOqa9eu1Z5j/PjxTpsQ9MiRI9Xeiz/88IMC1BdffKGOHTumlDo12efpE8NOnz69xmSfjfmZbgz1uS44U0FBQY1rQd++fdXtt9+u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",
      "text/plain": [
       "<Figure size 1200x300 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "f, (ax3,ax4,ax1,ax2) = plt.subplots(1, 4, sharex='col', sharey='row', figsize = (12,3))\n",
    "ax1.plot(bin_med_vaso_CDT, sliding_mean(mort_vaso_CDT), color='g')\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='green',alpha=0.2)\n",
    "ax1.set_title('CDT+TICRL')\n",
    "x_r = [i/10.0 for i in range(-6,10,2)]\n",
    "y_r = [i/20.0 for i in range(0,20,1)]\n",
    "ax1.set_xticks(x_r)\n",
    "ax1.grid()\n",
    "\n",
    "ax2.plot(bin_med_iv_CDT, sliding_mean(mort_iv_CDT), color='g')\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='green',alpha=0.2)\n",
    "ax2.set_title('CDT+TICRL')\n",
    "x_iv = [i for i in range(-800,900,400)]\n",
    "ax2.set_xticks(x_iv)\n",
    "ax2.grid()\n",
    "\n",
    "ax3.plot(bin_med_vaso_DDPG, sliding_mean(mort_vaso_DDPG), color='r')\n",
    "ax3.fill_between(bin_med_vaso_DDPG, sliding_mean(mort_vaso_DDPG) - 1*mort_std_vaso_DDPG,  \n",
    "                 sliding_mean(mort_vaso_DDPG) + 1*mort_std_vaso_DDPG, color='tomato')\n",
    "ax3.set_title('DDPG')\n",
    "x_r = [i/10.0 for i in range(-6,10,2)]\n",
    "ax3.set_xticks(x_r)\n",
    "ax3.set_yticks(y_r)\n",
    "ax3.set_ylabel('Mortality')\n",
    "ax3.grid()\n",
    "\n",
    "ax4.plot(bin_med_iv_DDPG, sliding_mean(mort_iv_DDPG), color='r')\n",
    "ax4.fill_between(bin_med_iv_DDPG, sliding_mean(mort_iv_DDPG) - 1*mort_std_iv_DDPG,  \n",
    "                 sliding_mean(mort_iv_DDPG) + 1*mort_std_iv_DDPG, color='tomato')\n",
    "ax4.set_title('DDPG')\n",
    "x_iv = [i for i in range(-800,900,400)]\n",
    "ax4.set_xticks(x_iv)\n",
    "ax4.grid()\n",
    "\n",
    "plt.tight_layout()\n",
    "f.text(0.15, -0.03, 'VASO DIFF', ha='center', fontsize=10)\n",
    "f.text(0.395, -0.03, 'IV DIFF', ha='center', fontsize=10)\n",
    "f.text(0.63, -0.03, 'VASO DIFF', ha='center', fontsize=10)\n",
    "f.text(0.88, -0.03, 'IV DIFF', ha='center', fontsize=10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "label = \"CDT+CT\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "# bin_med_iv_CDT_nocost, mort_iv_CDT_nocost, mort_std_iv_CDT_nocost = make_iv_plot_data(df_diff_CDT_nocost)\n",
    "# bin_med_vaso_CDT_nocost, mort_vaso_CDT_nocost, mort_std_vaso_CDT_nocost = make_vaso_plot_data(df_diff_CDT_nocost)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "# bin_med_iv_CDT_customcost, mort_iv_CDT_customcost, mort_std_iv_CDT_customcost = make_iv_plot_data(df_diff_CDT_nocost)\n",
    "# bin_med_vaso_CDT_customcost, mort_vaso_CDT_customcost, mort_std_vaso_CDT_customcost = make_vaso_plot_data(df_diff_CDT_nocost)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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t248+eSTHDkglVKKxx57jNjYWAICAhg+fDjbt2+vd56TyRvanRLNdtFFF6k+ffqo5cuXq2+//ValpqaqcePGnfCY77//XjmdTjVt2jS1YcMGtWXLFvXee++p6urqdo2rzgsvvKBGjRqlAPXRRx+1WEzNiWv9+vXqiiuuUJ9++qnasWOHWrRokUpLS1Njx449qTjmzp2rLBaLevPNN9XGjRvVzTffrEJCQpTL5Trm/t99950yGo3queeeU5s2bVKPPPKIMpvNav369ScVx8nGdfXVV6uXX35ZrV69Wm3evFldd911Kjg4WO3fv79d46qze/duFR8fr4YOHaouv/zyFo2pOXG53W7Vv39/NXr0aLV06VK1e/dutWTJErVmzZp2jevtt99WVqtVvf3222r37t3qiy++ULGxseqee+5p0biaKy0tTY0ePVqtXbtWbdu2Td1+++3KbrernJwcpZRSHo9HZWVlqeHDh6vVq1erBQsWqIiICDVlyhT/OXbt2qXsdruaNGmS2rRpk3rppZeU0WhUCxcubK/L+kV33nmnvyxcvXq1f31JSYmKjo5W48ePVxs2bFDvvvuuCggIUH/729/8+7RVmdHSmvte76hWrFihkpKSVO/evdVdd93lX3/bbbephIQEtWjRIvXTTz+ps846Sw0ZMsS/vTGv6Y7i6aefVuHh4eqzzz5Tu3fvVvPmzVMOh0O9+OKL/n2mT5+ugoOD1ccff6zWrl2rLrvsMpWcnKyqqqr8+5xM3tDeJJFtpk2bNilA/fjjj/51n3/+udI0TR04cOC4xw0aNEg98sgjHS4upZRavXq1io+PVzk5OS2eyJ5MXEd6//33lcViUbW1tc2OZeDAgWrixIn++16vV8XFxalp06Ydc/8rr7xSXXzxxfXWDRo0SN16663NjqEl4jqax+NRQUFBas6cOe0el8fjUUOGDFGvv/66mjBhQqsksk2N669//atKSUlRNTU1LR7LycQ1ceJEdf7559dbN2nSJPWrX/2qVeNsjPz8fAWob775xr+utLRUAerLL79USim1YMECZTAYVG5urn+fv/71r8rpdCq3262UUuqBBx5QPXv2rHfuq666So0cObINrqLpFixYoDIyMtTGjRsbJLKvvPKKCg0N9V+bUko9+OCDqnv37v77bVVmtLSTLYM6krKyMpWWlqa+/PJLNWzYMH8iW1xcrMxms5o3b55/382bNytALVu2TCnVuNd0R3HxxRerG264od66K664Qo0fP14ppZTP51MxMTHq+eef928vLi5WVqtVvfvuu0qplvt8bi/StKCZli1bRkhICP379/evGz58OAaDgR9++OGYx+Tl5fHDDz8QFRXFkCFDiI6OZtiwYSxdurRd4wKorKzk6quv5uWXXyYmJqbF4jnZuI5WUlKC0+nEZGrepHQ1NTWsXLmS4cOH+9cZDAaGDx/OsmXLjhv7kfsDjBw58rj7t1VcR6usrKS2tpawsLB2j+tPf/oTUVFR3HjjjS0Wy8nG9emnnzJ48GAmTpxIdHQ0WVlZPPPMM3i93naNa8iQIaxcudL/E+6uXbtYsGABo0ePbrG4mis8PJzu3bvzj3/8g4qKCjweD3/729+IiorizDPPBPT3R69everNnjhy5EhKS0vZuHGjf5/Wfg+1FJfLxc0338w///lP7HZ7g+3Lli3jnHPOwWKx+NeNHDmSrVu3UlRU5N+ns1xvnZYogzqSiRMncvHFFzf4P6xcuZLa2tp66zMyMujatav/Ohvzmu4ohgwZwqJFi9i2bRsAa9euZenSpYwaNQqA3bt3k5ubW+96g4ODGTRoUL3rbYnP5/bSrlPUdma5ublERUXVW2cymQgLCyM3N/eYx+zatQuAqVOnMmPGDPr27cs//vEPLrjgAjZs2EBaWlq7xAVwzz33MGTIEC6//PKTjqEl4zrSwYMHefLJJ7nllluaHcfBgwfxer0NpiyOjo5my5YtxzwmNzf3mPs3Nu7WiutoDz74IHFxcQ0K7raOa+nSpbzxxhsN2hW2pObEtWvXLr7++mvGjx/PggUL2LFjB7fffju1tbU8/vjj7RbX1VdfzcGDBzn77LNRSuHxeLjtttt46KGHWiSmk6FpGl999RVjxowhKCgIg8FAVFQUCxcuJDQ0FDj++6Nu24n2KS0tpaqqioCAgDa4ml+mlOK6667jtttuo3///uzZs6fBPrm5uSQnJ9dbd+T1hoaGtkmZ0dJaogzqKObOncuqVav48ccfG2zLzc3FYrEQEhJSb/2R/5/GvKY7ismTJ1NaWkpGRgZGoxGv18vTTz/N+PHjgcPxnuj12BKfz+1JamSPMnnyZDRNO+HS3De1z+cD4NZbb+X666+nX79+zJw5k+7du/Pmm2+2W1yffvopX3/9NbNmzWrysa0Z15FKS0u5+OKL6dGjB1OnTj3p851qpk+fzty5c/noo4+w2WztFkdZWRnXXHMNr732GhEREe0Wx7H4fD6ioqL4+9//zplnnslVV13Fww8/zKuvvtqucS1ZsoRnnnmGV155hVWrVvHhhx8yf/58nnzyyVZ7zMa+b5VSTJw4kaioKL799ltWrFjBmDFjuPTSS8nJyWm1+FpaY6/3pZdeoqysjClTprR3yKKZ9u3bx1133cXbb7/drmVhW3n//fd5++23eeedd1i1ahVz5sxhxowZzJkzp71DazNSI3uUe++9l+uuu+6E+6SkpBATE0NeXl699R6Ph8LCwuP+NB8bGwtAjx496q3PzMxk79697RbX119/zc6dOxt8Qx07dixDhw5lyZIl7RJXnbKyMi666CKCgoL46KOPMJvNJ9z/RCIiIjAajQ16qLpcruPGERMT06T92yquOjNmzGD69Ol89dVX9O7du8Viak5cO3fuZM+ePVx66aX+dXVf4EwmE1u3bqVbt25tHhfo7z+z2YzRaPSvy8zMJDc3l5qamno/FbdlXI8++ijXXHMNN910EwC9evWioqKCW265hYcffhiDoeXrGxr7vv3666/57LPPKCoqwul0AvDKK6/w5ZdfMmfOHCZPnkxMTEyDnu111193zcd7DzmdzjapjW3K9S5btgyr1VpvW//+/Rk/fjxz5sw57rXAL19vazTbaiknUwZ1JCtXriQvL48zzjjDv87r9fLNN9/wl7/8hS+++IKamhqKi4vrfeYdeZ2NeU13FPfffz+TJ0/md7/7HaCXHz///DPTpk1jwoQJ/nhdLpc/B6m737dvX4CT+nzuENq5jW6nVdc4+qeffvKv++KLL07YONrn86m4uLgGnb369u3bYr0hmxNXTk6OWr9+fb0FUC+++KLatWtXu8WllN5D+KyzzlLDhg1TFRUVLRLLwIED1R133OG/7/V6VXx8/Ak7e11yySX11g0ePLhVOns1JS6llHr22WeV0+n0d1JoDU2Jq6qqqsFr6fLLL1fnn3++Wr9+fYt2lGjq8zVlyhSVmJiovF6vf92sWbNUbGxsi8XUnLjOOOMM9cADD9Rb984776iAgADl8XhaNLam+vTTT5XBYFBlZWX11qenp6unn35aKXW4Y8yRPdv/9re/KafT6R+N5YEHHlBZWVn1zjFu3LgO19nr559/rvfa/eKLLxSgPvjgA7Vv3z6l1OHOXkd2GpwyZUqDzl5tUWa0tOaUQR1NaWlpgzKof//+6ve//71av369v7PXBx984D9my5Ytx+zsdaLXdEcRFhamXnnllXrrnnnmGZWWlqaUOtzZa8aMGf7tJSUlx+zs1dTP545CEtmTcNFFF6l+/fqpH374QS1dulSlpaXVG65i//79qnv37uqHH37wr5s5c6ZyOp1q3rx5avv27eqRRx5RNptN7dixo13jOhqtNPxWU+IqKSlRgwYNUr169VI7duxQOTk5/uVkPuDnzp2rrFarmj17ttq0aZO65ZZbVEhIiL+H6jXXXKMmT57s3/+7775TJpNJzZgxQ23evFk9/vjjrTb8VlPimj59urJYLOqDDz6o99wcnXS0dVxHa61RC5oa1969e1VQUJC644471NatW9Vnn32moqKi1FNPPdWucT3++OMqKChIvfvuu2rXrl3qv//9r+rWrZu68sorWzSu5sjPz1fh4eHqiiuuUGvWrFFbt25V9913nzKbzf5hy+qGKrrwwgvVmjVr1MKFC1VkZOQxh9+6//771ebNm9XLL7/c4YffUkofQo6jRi0oLi5W0dHR6pprrlEbNmxQc+fOVXa7vcHwW21RZrS0X3rtdlZHjlqglD78VteuXdXXX3+tfvrpJzV48GA1ePBg//bGvKY7igkTJqj4+Hj/8FsffvihioiIqPflePr06SokJER98sknat26deryyy8/5vBbJ/p87sgkkT0JBQUFaty4ccrhcCin06muv/76eklEXSG4ePHiesdNmzZNdenSRdntdjV48GD17bffdoi4jtQaiWxT41q8eLECjrns3r37pGJ56aWXVNeuXZXFYlEDBw5Uy5cv928bNmyYmjBhQr3933//fZWenq4sFovq2bOnmj9//kk9fkvElZiYeMzn5vHHH2/XuI7WWolsc+L6/vvv1aBBg5TValUpKSnq6aefbpVaz6bEVVtbq6ZOnaq6deumbDabSkhIULfffrsqKipq8bia48cff1QXXnihCgsLU0FBQeqss85SCxYsqLfPnj171KhRo1RAQICKiIhQ9957b4Mh8hYvXqz69u2rLBaLSklJUW+99VYbXkXzHCuRVUqptWvXqrPPPltZrVYVHx+vpk+f3uDYtiozWtqJXrud1dGJbFVVlbr99ttVaGiostvt6te//rV/XOQ6jXlNdwSlpaXqrrvuUl27dlU2m02lpKSohx9+uN6vXz6fTz366KMqOjpaWa1WdcEFF6itW7fWO88vfT53ZJpSR0z/IIQQQgghRCchoxYIIYQQQohOSRJZIYQQQgjRKUkiK4QQQgghOiVJZIUQQgghRKckiawQQgghhOiUJJEVQgghhBCdkiSyQgghhBCiU5JEVgghhBBCdEqSyAohhBBCiE5JElkhhBBCCNEpSSIrhBBCCCE6JUlkhRBCCCFEpySJrBBCCCGE6JQkkRVCCCGEEJ2SJLJCCCGEEKJTkkRWCCGEEEJ0SpLIig7v0ksv5aKLLjrmtm+//RZN01i3bp1/3a233orRaGTevHkN9q+srGTKlCl069YNm81GZGQkw4YN45NPPqm338aNG7nyyiuJjIzEarWSnp7OY489RmVl5QljnTp1KpqmoWkaJpOJiIgIzjnnHGbNmoXb7a6377nnnsvdd99d737dsUcuHo+nUduFEKef6667jjFjxgBNLyuPdGT5YrVaiY+P59JLL+XDDz9ssK+maXz88cf17h+9nH322Y3eLsTJkERWdHg33ngjX375Jfv372+w7a233qJ///707t0b0BPVuXPn8sADD/Dmm2822P+2227jww8/5KWXXmLLli0sXLiQ3/zmNxQUFPj3Wb58OYMGDaKmpob58+ezbds2nn76aWbPns2IESOoqak5Ybw9e/YkJyeHvXv3snjxYn77298ybdo0hgwZQllZ2QmPvfnmm8nJyam3mEymRm8XQpy+mlJWHktd+bJz507+/e9/06NHD373u99xyy23/OJjv/XWW/XKpU8//bRJ24VoLvkEFB3eJZdcQmRkJLNnz+aRRx7xry8vL2fevHk8//zz/nXz5s2jR48eTJ48mbi4OPbt20dCQoJ/+6effsqLL77I6NGjAUhKSuLMM8/0b1dKceONN5KZmcmHH36IwaB/10tMTCQ9PZ1+/foxc+ZMHnzwwePGazKZiImJASAuLo5evXoxYsQI+vTpw7PPPstTTz113GPtdrv/2OZsF0KcvppSVh7LkeVLly5dOOuss8jIyOCGG27gyiuvZPjw4cc9NiQk5IRl0y9tF6K5pEZWdHgmk4lrr72W2bNno5Tyr583bx5er5dx48b5173xxhv8/ve/Jzg4mFGjRjF79ux654qJiWHBggXHrRlds2YNmzZtYtKkSf4ktk6fPn0YPnw47777bpOvISMjg1GjRh3zZzohhGgJTSkrG2vChAmEhoZK2SU6LElkRadwww03sHPnTv73v//517311luMHTuW4OBgALZv387y5cu56qqrAPj973/PW2+9Va9A//vf/873339PeHg4AwYM4J577uG7777zb9+2bRsAmZmZx4wjMzPTv09TZWRksGfPnhPu88orr+BwOPzLvffe26TtQojTW2PKyqYwGAykp6f/Ytk1bty4emXTkW1oG7NdiOaSRFZ0ChkZGQwZMsTf7nXHjh18++233Hjjjf593nzzTUaOHElERAQAo0ePpqSkhK+//tq/zznnnMOuXbtYtGgRv/nNb9i4cSNDhw7lySefrPd4Rya/LUUphaZpJ9xn/PjxrFmzxr9MmTKlSduFEKe3xpSVTdWYsmvmzJn1yqYRI0Y0absQzSWJrOg0brzxRv79739TVlbGW2+9Rbdu3Rg2bBgAXq+XOXPmMH/+fEwmEyaTCbvdTmFhYYNOX2azmaFDh/Lggw/y3//+lz/96U88+eST1NTUkJ6eDsDmzZuPGcPmzZv9+zTV5s2bSU5OPuE+wcHBpKam+pe6pLyx24UQ4kRlZVN5vV62b9/+i2VXTExMvbIpMDCwSduFaC5JZEWnceWVV2IwGHjnnXf4xz/+wQ033OCvJahr97p69ep63/rfffddPvzwQ4qLi4973h49euDxeKiurqZv375kZGQwc+ZMfD5fvf3Wrl3LV1991ax2ZnUjJIwdO7bJxwohRFOcqKxsqjlz5lBUVCRll+iwZNQC0Wk4HA6uuuoqpkyZQmlpKdddd51/2xtvvMHFF19Mnz596h3To0cP7rnnHt5++20mTpzIueeey7hx4+jfvz/h4eFs2rSJhx56iPPOOw+n0+k/14gRIxg7dixTpkwhJiaGH374gXvvvZfBgwfXG/v1WDweD7m5ufh8PgoKCliyZAlPPfUUffv25f7772/pp0UIIeo5UVl5IpWVleTm5uLxeNi/fz8fffQRM2fO5A9/+APnnXde6wYtRDNJjazoVG688UaKiooYOXIkcXFxALhcLubPn3/MGgODwcCvf/1r3njjDQBGjhzJnDlzuPDCC8nMzOSPf/wjI0eO5P333/cfM2TIEJYvX47RaGTUqFGkpqYyZcoUJkyYwJdffonVaj1hjBs3biQ2NpauXbty7rnn8v777zNlyhS+/fZbHA5HCz4bQghxbMcqK3/Ja6+9RmxsLN26deOKK65g06ZNvPfee7zyyiutHK0Qzaep1ujVIoQQQgghRCuTGlkhhBBCCNEpSSIrhBBCCCE6JUlkhRBCCCFEpySJrBBCCCGE6JQkkRVCCCGEEJ2SJLJCCCGEEKJTkkRWCCGEEEJ0SpLICiGEEEKITkkSWSGEEEII0SlJIiuEEEIIITolSWSFEEIIIUSn9P+V6MymD+wCwAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 700x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "f, (ax3,ax4) = plt.subplots(1, 2, sharex='col', sharey='row', figsize = (7,3))\n",
    "ax3.plot(bin_med_vaso_CDT, sliding_mean(mort_vaso_CDT), color='g',label=label)\n",
    "ax3.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='green',alpha=0.2)\n",
    "\n",
    "ax4.plot(bin_med_iv_CDT, sliding_mean(mort_iv_CDT), color='g',label=label)\n",
    "ax4.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='green',alpha=0.2)\n",
    "\n",
    "ax3.plot(bin_med_vaso_DDPG, sliding_mean(mort_vaso_DDPG), color='r',label='DDPG')\n",
    "ax3.fill_between(bin_med_vaso_DDPG, sliding_mean(mort_vaso_DDPG) - 1*mort_std_vaso_DDPG,  \n",
    "                 sliding_mean(mort_vaso_DDPG) + 1*mort_std_vaso_DDPG, color='tomato')\n",
    "x_r = [i/10.0 for i in range(-6,10,2)]\n",
    "ax3.set_xticks(x_r)\n",
    "ax3.set_yticks(y_r)\n",
    "ax3.set_ylabel('Mortality')\n",
    "ax3.grid()\n",
    "\n",
    "ax4.plot(bin_med_iv_DDPG, sliding_mean(mort_iv_DDPG), color='r',label='DDPG')\n",
    "ax4.fill_between(bin_med_iv_DDPG, sliding_mean(mort_iv_DDPG) - 1*mort_std_iv_DDPG,  \n",
    "                 sliding_mean(mort_iv_DDPG) + 1*mort_std_iv_DDPG, color='tomato')\n",
    "x_iv = [i for i in range(-800,900,400)]\n",
    "ax4.set_xticks(x_iv)\n",
    "ax4.grid()\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "f.text(0.3, -0.03, 'VASO DIFF', ha='center', fontsize=10)\n",
    "f.text(0.75, -0.03, 'IV DIFF', ha='center', fontsize=10)\n",
    "plt.savefig('diff.pdf',format='pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "600 -800\n",
      "5.551115123125783e-17 -0.6\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": 31,
   "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": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.09164782 1184.2767000198364\n"
     ]
    }
   ],
   "source": [
    "print(max(delta_vaso),max(delta_iv)*2000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0\n",
      "0.005681818181818182\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))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "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>0.189937</td>\n",
       "      <td>0.037616</td>\n",
       "      <td>0.093275</td>\n",
       "      <td>0.988</td>\n",
       "      <td>1.0</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.107156</td>\n",
       "      <td>0.013423</td>\n",
       "      <td>0.187500</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.301409</td>\n",
       "      <td>0.008038</td>\n",
       "      <td>0.853093</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.327831</td>\n",
       "      <td>0.042669</td>\n",
       "      <td>0.140000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.208234</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.112500</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     iv_cdt  vaso_cdt    iv_phy  vaso_phy  die   term\n",
       "0  0.189937  0.037616  0.093275     0.988  1.0  False\n",
       "1  0.107156  0.013423  0.187500     0.000  0.0  False\n",
       "2  0.301409  0.008038  0.853093     0.000  1.0  False\n",
       "3  0.327831  0.042669  0.140000     0.000  0.0  False\n",
       "4  0.208234  0.000000  0.112500     0.000  0.0  False"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_all.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_all['iv_cdt']*=2000\n",
    "df_all['vaso_cdt']*=2000"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Too high and sudden change"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f8673d6357554548beb8b33e9af8824e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Evaluating...:   0%|          | 0/1 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "cdt_actions = []\n",
    "phy_actions = []\n",
    "dieds = []\n",
    "val_df = []\n",
    "terminals = []\n",
    "\n",
    "val_df1 = get_val_some_path(data_val,batch_size=5000,seed=seed) #\n",
    "agent_action,phy_action,action_ems = trainer.evaluate(val_df1,eval_episodes,\n",
    "                                        target_ret * 0.1,\n",
    "                                        0)\n",
    "        \n",
    "cdt_actions.append(agent_action)\n",
    "phy_actions.append(phy_action)\n",
    "dieds.append(val_df1['dieds'])\n",
    "val_df.append(val_df1)\n",
    "terminals.append(val_df1['terminals'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "cdt_actions = agent_action[0]\n",
    "phy_actions = phy_action[0]\n",
    "dieds = val_df1['dieds']\n",
    "term = val_df1['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'] = iv1\n",
    "df_all['vaso_cdt'] = vaso1\n",
    "df_all['iv_phy'] = iv2\n",
    "df_all['vaso_phy'] = vaso2\n",
    "df_all['die'] = val_df1['dieds']\n",
    "df_all['term'] = val_df1['terminals']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_all['iv_cdt']*=2000\n",
    "df_all['iv_phy']*=2000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1408.238037109375 0.10516474395990372\n"
     ]
    }
   ],
   "source": [
    "print(max(df_all['iv_cdt']),max(df_all['vaso_cdt']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "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>379.873596</td>\n",
       "      <td>0.037616</td>\n",
       "      <td>186.550036</td>\n",
       "      <td>0.988</td>\n",
       "      <td>1.0</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>214.311447</td>\n",
       "      <td>0.013423</td>\n",
       "      <td>375.000000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>602.818970</td>\n",
       "      <td>0.008038</td>\n",
       "      <td>1706.185818</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>655.662354</td>\n",
       "      <td>0.042669</td>\n",
       "      <td>280.000001</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>416.467651</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>224.999994</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       iv_cdt  vaso_cdt       iv_phy  vaso_phy  die   term\n",
       "0  379.873596  0.037616   186.550036     0.988  1.0  False\n",
       "1  214.311447  0.013423   375.000000     0.000  0.0  False\n",
       "2  602.818970  0.008038  1706.185818     0.000  1.0  False\n",
       "3  655.662354  0.042669   280.000001     0.000  0.0  False\n",
       "4  416.467651  0.000000   224.999994     0.000  0.0  False"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_all.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "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  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",
    "\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",
    "    print(\"max_too_high_iv:\",max(b))\n",
    "    print(\"max_too_high_vaso:\",max(a))\n",
    "    print(\"max_change_iv:\",max(delta_iv))\n",
    "    print(\"max_change_vaso:\",max(delta_vaso))\n",
    "    \n",
    "\n",
    "    return delta_iv,delta_vaso,a,b"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "change_vaso> 0.75 : 0.0\n",
      "change_iv> 2000 : 0.0\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.0\n",
      "too high iv>: 2000 : 0.0\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "max_too_high_iv: 1408.238\n",
      "max_too_high_vaso: 0.105164744\n",
      "max_change_iv: 1184.2767\n",
      "max_change_vaso: 0.10372437\n",
      "change_vaso> 0.75 : 0.0\n",
      "change_iv> 2000 : 0.0\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.0\n",
      "too high iv>: 2000 : 0.0\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "max_too_high_iv: 1408.238\n",
      "max_too_high_vaso: 0.105164744\n",
      "max_change_iv: 1184.2767\n",
      "max_change_vaso: 0.10372437\n",
      "change_vaso> 0.5 : 0.0\n",
      "change_iv> 2500 : 0.0\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.5 : 0.0\n",
      "too high iv>: 2000 : 0.0\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "max_too_high_iv: 1408.238\n",
      "max_too_high_vaso: 0.105164744\n",
      "max_change_iv: 1184.2767\n",
      "max_change_vaso: 0.10372437\n",
      "change_vaso> 0.5 : 0.0\n",
      "change_iv> 2500 : 0.0\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.5 : 0.0\n",
      "too high iv>: 2000 : 0.0\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "max_too_high_iv: 1408.238\n",
      "max_too_high_vaso: 0.105164744\n",
      "max_change_iv: 1184.2767\n",
      "max_change_vaso: 0.10372437\n"
     ]
    }
   ],
   "source": [
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_cdt','iv_cdt',0,0.75,2000,2000,0.75)\n",
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_cdt','iv_cdt',1,0.75,2000,2000,0.75)\n",
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_cdt','iv_cdt',0,0.5,2500,2000,0.5)\n",
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_cdt','iv_cdt',1,0.5,2500,2000,0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "# sudden change\n",
    "\n",
    "def sudden_change_and_too_high_phy(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  i == 0 and df.loc[i,'die']==1:\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",
    "\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",
    "\n",
    "    print(\"too high vaso>:\",too_high_vaso,\":\",sum(value > too_high_vaso for value in a)/len(a))\n",
    "\n",
    "    print(\"max_too_high_vaso:\",max(a))\n",
    "\n",
    "    print(\"max_change_vaso:\",max(delta_vaso))\n",
    "    \n",
    "\n",
    "    return delta_iv,delta_vaso,a,b"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "change_vaso> 0.9 : 0.11764705882352941\n",
      "change_iv> 2000 : 0.09697933227344992\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.02265446224256293\n",
      "too high iv>: 2000 : 0.019221967963386728\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "max_too_high_iv: 7552.639961242676\n",
      "max_too_high_vaso: 35.7140007019043\n",
      "max_change_iv: 7552.639961242676\n",
      "max_change_vaso: 35.7140007019043\n",
      "change_vaso> 0.9 : 0.11764705882352941\n",
      "change_iv> 2000 : 0.09697933227344992\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.75 : 0.02265446224256293\n",
      "too high iv>: 2000 : 0.019221967963386728\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "max_too_high_iv: 7552.639961242676\n",
      "max_too_high_vaso: 35.7140007019043\n",
      "max_change_iv: 7552.639961242676\n",
      "max_change_vaso: 35.7140007019043\n",
      "change_vaso> 0.75 : 0.13354531001589826\n",
      "change_iv> 2500 : 0.06041335453100159\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.9 : 0.019450800915331808\n",
      "too high iv>: 2000 : 0.019221967963386728\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "max_too_high_iv: 7552.639961242676\n",
      "max_too_high_vaso: 35.7140007019043\n",
      "max_change_iv: 7552.639961242676\n",
      "max_change_vaso: 35.7140007019043\n",
      "change_vaso> 0.75 : 0.13354531001589826\n",
      "change_iv> 2500 : 0.06041335453100159\n",
      "----------------------------------------------------------------------\n",
      "too high vaso>: 0.9 : 0.019450800915331808\n",
      "too high iv>: 2000 : 0.019221967963386728\n",
      "-****----****----****----****----****----****----****----****----****----****---\n",
      "max_too_high_iv: 7552.639961242676\n",
      "max_too_high_vaso: 35.7140007019043\n",
      "max_change_iv: 7552.639961242676\n",
      "max_change_vaso: 35.7140007019043\n"
     ]
    }
   ],
   "source": [
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_phy','iv_phy',1,0.9,2000,2000,0.75)\n",
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_phy','iv_phy',0,0.9,2000,2000,0.75)\n",
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_phy','iv_phy',1,0.75,2500,2000,0.9)\n",
    "delta_iv,delta_vaso,a,b = sudden_change_and_too_high(df_all,'vaso_phy','iv_phy',0,0.75,2500,2000,0.9)\n"
   ]
  }
 ],
 "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
}
