{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Transition Tuples for Covid + Patients"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "* What are the units for o2 saturation?\n",
    "* Can we have more finegrained actions? "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "from sklearn import preprocessing\n",
    "import pickle\n",
    "import os\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "pth = \"/tigress/BEE/penn-covidsub/wip-state_rep_all_feat_24H.csv\"\n",
    "#pth = '/tigress/BEE/penn-covidsub/COVID - boosting_24H.csv'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/amandyam/.conda/envs/research/lib/python3.6/site-packages/seaborn/distributions.py:2551: FutureWarning: `distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='O2 SAT MEASURED', ylabel='Density'>"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "respiratory_rate_cols = ['MEASURED O2 SAT VEN', 'MEASURED O2 SAT ART', 'C O2 SAT MEASURED', 'C O2 SAT',\n",
    "                        'O2 SAT MEASURED']\n",
    "data = pd.read_csv(pth)\n",
    "o2 = data[respiratory_rate_cols]\n",
    "sns.distplot(o2['O2 SAT MEASURED'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/amandyam/.conda/envs/research/lib/python3.6/site-packages/seaborn/distributions.py:2551: FutureWarning: `distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:ylabel='Density'>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.distplot(o2[o2['O2 SAT MEASURED'] < 100])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "allFrames = pd.read_csv(pth)\n",
    "state_feats = ['ALBUMIN', 'ANION GAP',\n",
    "       'BASE EXCESS', 'BICARBONATE', 'BILIRUBIN', 'CALCIUM',\n",
    "       'CARBOXYHEMOGLOBIN', 'CHLORIDE', 'CREATININE', 'HEMATOCRIT',\n",
    "       'HEMOGLOBIN', 'INSPIRED OXYGEN', 'INTERNATIONAL NORMALIZED RATIO',\n",
    "       'LACTATE', 'METHEMOGLOBIN', 'PARTIAL THROMBOPLASTIN TIME', 'PCO2', 'PH',\n",
    "       'PLATELETS', 'PO2', 'POTASSIUM', 'SODIUM', 'UREA NITROGEN',\n",
    "       'URINE OUTPUT', 'WHITE BLOOD CELLS', 'FIO2', 'PEEP', 'OXYGEN (L)',\n",
    "       'Respiratory Aids', 'Nonsteroidal Anti-inflammatory Agents (NSAIDs)',\n",
    "       'Corticosteroids - Topical', 'Mineralocorticoids',\n",
    "       'Glucocorticosteroids', 'Influenza Agents', 'Antiretrovirals',\n",
    "       'is_deceased_next_t']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "allFrames"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def state_transformer(frames, states=None, feats=state_feats, transformer='tuples/transformer.pkl'):\n",
    "   \n",
    "    print('#:', len(feats))\n",
    "    if states is None:\n",
    "        states = np.vstack([np.array(frames.loc[i, feats]).astype(float) for i in range(len(frames))])\n",
    "    if False: #os.path.isfile(transformer):\n",
    "        scaler = pickle.load(open(transformer, 'rb'))\n",
    "    else:\n",
    "        scaler = preprocessing.StandardScaler().fit(states)\n",
    "        pickle.dump(scaler, open('tuples/transformer.pkl', 'wb'))\n",
    "    transformed_states = scaler.transform(states)\n",
    "    return transformed_states\n",
    "\n",
    "def state_invtransformer(tstates, transformer='tuples/transformer.pkl'):\n",
    "    \n",
    "    scaler = pickle.load(open(transformer, 'rb'))\n",
    "    states = scaler.inverse_transform(tstates)\n",
    "    \n",
    "    return states\n",
    "\n",
    "def transform(state, transformer='tuples/transformer.pkl'):\n",
    "    if os.path.isfile(transformer):\n",
    "        scaler = pickle.load(open(transformer, 'rb'))\n",
    "        return scaler.transform([state])[0]\n",
    "    else:\n",
    "        return state\n",
    "    return \n",
    "\n",
    "def discretize(a, el='Respiratory Aids'):\n",
    "    \n",
    "    print(\"A \", a )\n",
    "    if el=='Respiratory Aids':\n",
    "        adict = {'none': 0, 'vent': 0}\n",
    "        \n",
    "        # What is ivd, ivh?\n",
    "        aid = a[0]\n",
    "        \n",
    "        if aid:\n",
    "            adict['vent'] = 1        \n",
    "        \n",
    "    da = list(adict.values())\n",
    "    if sum(da) == 0: da[0] = 1\n",
    "\n",
    "    return da\n",
    "\n",
    "def reward(s, a, ns, w=np.array([1, 1])/5., el='Respiratory Aid'):\n",
    "    \n",
    "    rdict = {'cost-vent': 0, 'low-o2sat': 0}\n",
    "    \n",
    "    if a[0] > 0 : rdict['cost-iv'] -= 1 \n",
    "    if a[1] > 0 : rdict['cost-po'] -= 1\n",
    "    \n",
    "    if el=='Respiratory Aid': rdict['cost-vent'], rdict['low-02sat'] = sigmoid(ns[0], el=el)\n",
    "    if el=='Mg': rdict['high'], rdict['low'] = sigmoid(ns[1], el=el)\n",
    "    if el=='P': rdict['high'], rdict['low'] = sigmoid(ns[2], el=el)\n",
    "    \n",
    "    phi = np.array(list(rdict.values()))\n",
    "    r = np.dot(phi, w)\n",
    "    \n",
    "    return phi, r\n",
    "\n",
    "def sigmoid(x, el='K'):\n",
    "    \n",
    "    minmax = {'K': [3.5, 4.5], 'Mg': [1.5, 2.5], 'P': [2.5, 4.5]}\n",
    "    lmin, lmax = minmax[el]\n",
    "    \n",
    "    if x < lmin:\n",
    "        z = 1/(1 + np.exp(-3.5*(x-(lmin-1)))) - 1\n",
    "        return (0, z)\n",
    "    elif x > lmax: \n",
    "        z = - 1/(1 + np.exp(-3.5*(x-(lmax+1))))\n",
    "        return (z, 0)\n",
    "    else:\n",
    "        z = 0\n",
    "        return (z, z)\n",
    "    \n",
    "def generate_samples(vnum, trainFrames, el='Respiratory Aids'):\n",
    "\n",
    "    frame = trainFrames[trainFrames.pat_id==vnum]\n",
    "    all_st = []\n",
    "    all_nst = []\n",
    "    all_a = []\n",
    "    all_phi = []\n",
    "    all_r = []\n",
    "\n",
    "    for i in frame.index[:-1]:\n",
    "        \n",
    "        s = list(frame.loc[i, state_feats])\n",
    "        st = transform(s)\n",
    "        all_st.append(st)\n",
    "        if el=='Respiratory Aids':\n",
    "            a = list(frame.loc[i+1, ['Respiratory Aids']])\n",
    "        da = discretize(a, el=el)\n",
    "        all_a.append(da)\n",
    "        ns = list(frame.loc[i+1, state_feats])\n",
    "        nst = transform(ns)\n",
    "        all_nst.append(nst)\n",
    "        phi, r = reward(s, a, ns, el=el) \n",
    "        all_phi.append(phi)\n",
    "        all_r.append(r)\n",
    "        #print('s:', s, '\\n\\na:', a, '\\n\\nns', ns, '\\n\\nr', phi, r)\n",
    "        \n",
    "    return (all_st, all_a, all_nst, all_phi, all_r)\n",
    "\n",
    "def combine(ent):\n",
    "    return np.concatenate(np.array(ent))\n",
    "\n",
    "def get_tuples(frames, filename='tuples.pkl', el='Respiratory Aids'):\n",
    "    \n",
    "    transition_tuples = {'s': [], 'a': [], 'ns': [], 'phi': [], 'r': [], 'vnum': []}\n",
    "    \n",
    "    if el=='Respiratory Aids':\n",
    "        visits = frames[(frames['Respiratory Aids']!=0)].pat_id.unique()\n",
    "        \n",
    "    for vnum in visits:\n",
    "        if len(frames[frames.pat_id==vnum]) > 1:\n",
    "            s, a, ns, phi, r = generate_samples(vnum, frames, el)\n",
    "            transition_tuples['s'].append(np.array(s))\n",
    "            transition_tuples['a'].append(np.array(a))\n",
    "            transition_tuples['ns'].append(ns)\n",
    "            transition_tuples['phi'].append(phi)\n",
    "            transition_tuples['r'].append(r)\n",
    "            transition_tuples['vnum'].append(np.repeat(vnum, len(r)))\n",
    "\n",
    "    for k in transition_tuples.keys():\n",
    "        transition_tuples[k] = combine(transition_tuples[k])\n",
    "    \n",
    "    print(str(transition_tuples))\n",
    "    pickle.dump(transition_tuples, open(cf.outputdir + filename, 'wb'))\n",
    "    \n",
    "    return transition_tuples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print('Total number of processed adms =', len(allFrames.pat_id.unique()),'; number of transitions =', len(allFrames))    \n",
    "allFrames = allFrames.sort_values(by=['pat_id', 'order_time'])\n",
    "bp = np.sort(allFrames.pat_id.unique())[75]\n",
    "trainFrames = allFrames[allFrames['pat_id'] < bp].reset_index()\n",
    "testFrames = allFrames[allFrames['pat_id'] >= bp].reset_index()\n",
    "trainFrames.to_csv('tuples/trainFrames.csv', index=False)\n",
    "testFrames.to_csv('tuples/testFrames.csv', index=False)\n",
    "print('Transformer')\n",
    "ts = state_transformer(trainFrames)\n",
    "visits = allFrames.pat_id.unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print('Training set:')\n",
    "print('Total number of processed adms =',len(trainFrames.pat_id.unique()),'; number of transitions =',len(trainFrames))\n",
    "print ('Respiratory Aids Cohort')\n",
    "print('Number given respiratory aids =', len(allFrames[allFrames[\"Respiratory Aids\"] != 0].pat_id.unique()))\n",
    "print('Get tuples')\n",
    "get_tuples(trainFrames, filename='train_resp_tuples.pkl', el='Respiratory Aids')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "research [~/.conda/envs/research/]",
   "language": "python",
   "name": "conda_research"
  },
  "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.6.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
