{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8afd2620-fc10-46e5-ab12-dc68276e14dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import io\n",
    "import sys\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from copy import deepcopy\n",
    "from itertools import product\n",
    "from matplotlib import pyplot as plt\n",
    "from scipy.optimize import minimize\n",
    "import matplotlib.colors as mcolors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "523d5105-4131-41a1-be65-21471b67af4d",
   "metadata": {},
   "outputs": [],
   "source": [
    "home_dir = '/Users/trungpq/Workspace/clabsi/'"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9f4926e8-7e05-4e25-845b-6093a9174055",
   "metadata": {},
   "source": [
    "## Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "93d766e8-aef8-4370-9b7e-9872883c0575",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv(home_dir + \"processed_data/clean_PatientData_20230315.csv\")\n",
    "col_names = ['EPIC', 'CRISP', 'NHSN_CLABSI', 'Peds', 'Chemotherapy', 'OPAT', 'TPN', 'OtherTherapy', 'Port', 'PICC', 'TunneledCVC']\n",
    "df = df.loc[:, col_names]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "778b5e0a-2198-4472-b7fa-c60f81f46df0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# composite proxy\n",
    "df['EPIC_or_CRISP'] = ((df['EPIC'] + df['CRISP']) > 0).astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "90111043-263b-4042-8255-35e00a51454e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# ZAR graph: R <- C -> X(1) -> X <- R -> W\n",
    "X = 'NHSN_CLABSI'          # Observed proxy of the zero-inflated variable\n",
    "# W = 'EPIC_or_CRISP'        # Inflation indicator's proxy\n",
    "W = 'EPIC'\n",
    "C = ['Peds', 'Chemotherapy', 'OPAT', 'TPN', 'OtherTherapy', 'Port', 'PICC', 'TunneledCVC']    # Observed covariates\n",
    "\n",
    "# File name to save result\n",
    "file_name = (\n",
    "    'PatientData_20230315'\n",
    "    + '-W_' + ''.join([x[0] for x in W.split('_')])\n",
    "    + '-X_' + X[:2]\n",
    "    + '-C_' + '_'.join([str(x[0:2]) for x in C])\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "054a45ee-1955-45c2-a486-d15cd8e73290",
   "metadata": {},
   "outputs": [],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0ac312e2-fa7b-4679-884d-807ea89cc2bd",
   "metadata": {},
   "source": [
    "## Empirical distribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "35e6bea9-cedd-40eb-a249-e83cc2c196ec",
   "metadata": {},
   "outputs": [],
   "source": [
    "def fix_div_by_zero(p):\n",
    "    p = p + 1E-20\n",
    "    p = p / np.sum(p)\n",
    "    return p"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "64166023-1946-4261-a891-7985a2b27d40",
   "metadata": {},
   "outputs": [],
   "source": [
    "# find the joint distribution\n",
    "df[\"prob\"] = 1\n",
    "\n",
    "# empirical value of p(W,X,C) for (W,X,C) in the support\n",
    "p_WXC = df.loc[:, [W, X] + C + ['prob']].groupby([W, X] + C).count()\n",
    "p_WXC = p_WXC / p_WXC.sum()\n",
    "p_WXC_idx = pd.Series(p_WXC.index.values)\n",
    "p_WXC_val = p_WXC.values.flatten()\n",
    "\n",
    "# Array of vector values for (W,X,C)\n",
    "WXC_vals = pd.Series(product(*[[0, 1] for i in range(len([W, X] + C))]))\n",
    "# Array of vector values for (X,C)\n",
    "XC_vals = pd.Series(product(*[[0, 1] for i in range(len([X] + C))]))\n",
    "C_vals = pd.Series(product(*[[0, 1] for i in range(len(C))]))\n",
    "\n",
    "# empirical distribution\n",
    "p_WXC_emp = pd.Series(np.zeros(len(WXC_vals)))\n",
    "# (wxc) in the support\n",
    "mask = WXC_vals.isin(p_WXC_idx)\n",
    "# assign value for p(wxc) with (wxc) in the support\n",
    "p_WXC_emp[mask] = WXC_vals[mask].apply(lambda x: p_WXC_val[p_WXC_idx == x][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cf7ee080-4dbd-4765-b4e7-b4660d22d6e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "p_WXC_emp = p_WXC_emp.to_numpy().reshape(2, -1)\n",
    "p_XC_emp = p_WXC_emp.sum(axis=0)\n",
    "p_XC_emp = fix_div_by_zero(p_XC_emp)\n",
    "# conditional distribution p(W=0 | X, C)\n",
    "p_W_XC_emp = np.einsum('wi,i->wi', p_WXC_emp, 1/p_XC_emp).reshape(2, 2, -1)\n",
    "\n",
    "p_WXC_emp = pd.Series(p_WXC_emp.flatten())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c9984d5a-3ccf-4d4f-a7cf-706a6e576159",
   "metadata": {},
   "source": [
    "## Checking marginal constraints"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "80889ebe-757d-4e13-9d9c-c0a2d4263ac8",
   "metadata": {},
   "source": [
    "### Check: $p(w_0|x_1, c) = p(w_0|x_1)$ for all c"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0e8a3a34-816c-45db-91ab-d29b13b27a06",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Is p(w0|x1,c) = p(w0|x1) for all c?\n",
    "p_w0_x1C_map = pd.Series(p_W_XC_emp[0,1,:])\n",
    "p_w0_x1C_map.describe()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f3ed22bf-a4b1-4091-9dba-88bfe80d87b8",
   "metadata": {},
   "source": [
    "### Check: $OR(c)$ for all c"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7fd5757d-aede-41f9-87a1-49f4cf71c676",
   "metadata": {},
   "outputs": [],
   "source": [
    "def odd_ratio(p,c=0):\n",
    "    \"\"\"\n",
    "    Input:\n",
    "        If c=None, p is 2x2x1 matrix with p[i,j,0] = p(a=i|b=j).\n",
    "        If c is cardinal, p is 2x2xcard_c matrix with p[i,j,k] = p(a=i|b=j,c=k).\n",
    "    Output: Odd-ratio p(a=1|b=1,c) / p(a=0|b=1,c) * p(a=0|b=0,c) / p(a=1|b=0,c)\n",
    "    \"\"\"\n",
    "    c = 0 if p.shape[2] == 1 else c\n",
    "    return p[1,1,c]/p[0,1,c] * p[0,0,c]/p[1,0,c]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a37ddfb0-5f4b-492a-9782-12b02acfca86",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Is OR(c) > 1 for all c or OR(c) < 1 for all c?\n",
    "ORs = []\n",
    "for c, c_val in enumerate(C_vals):\n",
    "    ORs.append(\n",
    "        odd_ratio(p_W_XC_emp, c)\n",
    "    )\n",
    "ORs = np.asarray(ORs);\n",
    "print(f\"Does marginal constraint OR>1 or OR<1 for all c hold?: {(ORs > 1).all() or (ORs < 1).all()}.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "78cb11ae-a160-48cb-b157-f8d4dbfc12f9",
   "metadata": {},
   "source": [
    "Since max = 0.4, min = 0.0, the empirical distribution does not satisfy the marginal constraint of ZI MAR model. Therefore, we resort to finding the MLE of the observed law $p(W,X,C)$ inside the model."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "310bcf70-6fca-49df-8491-ea31c05e8eee",
   "metadata": {},
   "source": [
    "## ZI MAR: full model EM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "32d2b5fe-7f21-448c-9ff0-58cf51799a12",
   "metadata": {},
   "outputs": [],
   "source": [
    "import jax.numpy as jnp\n",
    "from jax import jit, grad, jacrev, jacfwd\n",
    "from jax import random\n",
    "\n",
    "from jax import config\n",
    "\n",
    "config.update(\"jax_enable_x64\", True)\n",
    "\n",
    "CARD_C = int(len(WXC_vals) / 4)    # binary W,X\n",
    "\n",
    "def logisreg(params):\n",
    "    return 1 / (1 + jnp.exp(-params))\n",
    "\n",
    "def get_p_C(param_C):\n",
    "    p = jnp.exp(-jnp.concatenate((param_C, jnp.asarray([0])))).astype(np.double)\n",
    "    return p / jnp.sum(p)\n",
    "\n",
    "def get_p_X1_C(param_x10_C):\n",
    "    p_x10_C = logisreg(param_x10_C).flatten()\n",
    "    return jnp.vstack((p_x10_C, 1-p_x10_C)).reshape(2, -1)\n",
    "\n",
    "def get_p_R_C(param_r0_C):\n",
    "    p_r0_C = logisreg(param_r0_C).flatten()\n",
    "    return jnp.vstack((p_r0_C, 1-p_r0_C)).reshape(2, -1)\n",
    "\n",
    "def get_p_W_R(param_w0_R):\n",
    "    p_w0_R = logisreg(param_w0_R).flatten()\n",
    "    return jnp.vstack((p_w0_R, 1-p_w0_R)).reshape(2, -1)\n",
    "\n",
    "def get_p_X_RX1():\n",
    "    p_X_RX1 = np.zeros((2, 2, 2))\n",
    "    p_X_RX1[0,0,:] = 1\n",
    "    p_X_RX1[0,1,0] = 1\n",
    "    p_X_RX1[1,1,1] = 1\n",
    "    return p_X_RX1\n",
    "\n",
    "def get_joint(params):\n",
    "    \"\"\"\n",
    "    calculate the joint distribution p(X1,X,R,C,W) given parameters\n",
    "    \"\"\"\n",
    "    param_C = params[:CARD_C-1]                   # card_C - 1 params\n",
    "    param_x10_C = params[CARD_C-1:2*CARD_C-1]     # card_C params\n",
    "    param_r0_C = params[2*CARD_C-1:3*CARD_C-1]    # card_C params\n",
    "    param_w0_R = params[3*CARD_C-1:]\n",
    "\n",
    "    p_C = get_p_C(param_C)\n",
    "    p_X1_C = get_p_X1_C(param_x10_C)\n",
    "    p_R_C = get_p_R_C(param_r0_C)\n",
    "    p_W_R = get_p_W_R(param_w0_R)\n",
    "    p_X_RX1 = get_p_X_RX1()\n",
    "\n",
    "    p_X1C = jnp.einsum('xc,c->xc', p_X1_C, p_C)\n",
    "    p_RX1C = jnp.einsum('rc,xc->rxc', p_R_C, p_X1C)\n",
    "    p_XRX1C = jnp.einsum('xry,ryc->xryc', p_X_RX1, p_RX1C)\n",
    "    p_WXRX1C = jnp.einsum('wr,xryc->wxryc', p_W_R, p_XRX1C)\n",
    "    return p_WXRX1C\n",
    "\n",
    "def get_p_WXC2(params):\n",
    "    p_WXRX1C = get_joint(params)\n",
    "    return p_WXRX1C.sum(axis=(2,3))\n",
    "\n",
    "def get_p_RX1_WXC(params):\n",
    "    p_WXRX1C = get_joint(params)\n",
    "    p_WXC = p_WXRX1C.sum(axis=(2,3))\n",
    "    # p_WXC = p_WXC + 1E-20\n",
    "    # p_WXC = p_WXC / p_WXC.sum()\n",
    "    p_RX1_WXC = jnp.einsum('wxryc,wxc->rywxc', p_WXRX1C, 1/p_WXC)\n",
    "    return p_RX1_WXC\n",
    "\n",
    "logisreg = jit(logisreg)\n",
    "get_p_C = jit(get_p_C)\n",
    "get_p_X1_C = jit(get_p_X1_C)\n",
    "get_p_R_C = jit(get_p_R_C)\n",
    "get_p_W_R = jit(get_p_W_R)\n",
    "get_joint = jit(get_joint)\n",
    "get_p_WXC2 = jit(get_p_WXC2)\n",
    "get_p_RX1_WXC = jit(get_p_RX1_WXC)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c009104f-12b0-4082-869a-5f2c722983ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "# EM algorithm\n",
    "def expectation(new_params, p_RX1_WXC, data):\n",
    "    # expectation step\n",
    "    joint = get_joint(new_params) # there are p(v) = 0 making llh = -inf\n",
    "    joint = joint + 1E-20\n",
    "    joint = joint / joint.sum()\n",
    "    E = - jnp.sum(jnp.einsum('wxryc,rywxc->wxc', jnp.log(joint), p_RX1_WXC) * data)\n",
    "    return E\n",
    "\n",
    "expectation = jit(expectation)\n",
    "grad_exp = jit(grad(expectation, argnums=0))\n",
    "\n",
    "# fit params\n",
    "def fit_em(new_params, data):\n",
    "    o_threshold = 1E-4\n",
    "    o_delta = 1\n",
    "    while o_delta > o_threshold:\n",
    "        old_params = new_params\n",
    "        p_RX1_WXC = get_p_RX1_WXC(old_params)\n",
    "\n",
    "        # maximization step\n",
    "        i_threshold = 1E-2\n",
    "        i_delta = 1\n",
    "        new_params = init_params\n",
    "        while i_delta > i_threshold:\n",
    "            step = grad_exp(new_params, p_RX1_WXC, data)\n",
    "            new_params = new_params - 0.0001 * step\n",
    "            i_delta = jnp.max(jnp.abs(step))\n",
    "\n",
    "        o_delta = jnp.max(jnp.abs(new_params - old_params))\n",
    "        print(o_delta)\n",
    "    return new_params"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "91d6e446-cfb3-4b91-b297-6c7d93878329",
   "metadata": {},
   "outputs": [],
   "source": [
    "# init params\n",
    "param_C = np.random.rand(CARD_C-1)      # CARD_C - 1 params\n",
    "param_x10_C = np.random.rand(CARD_C)    # CARD_C params\n",
    "param_r0_C = np.random.rand(CARD_C)     # CARD_C params\n",
    "param_w0_R = np.random.rand(2)\n",
    "init_params = jnp.asarray([*param_C, *param_x10_C, *param_r0_C, *param_w0_R])\n",
    "\n",
    "# fit\n",
    "data = p_WXC_emp.to_numpy().reshape(2, 2, CARD_C)\n",
    "data = jnp.asarray(data)\n",
    "em_params = fit_em(init_params, data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "19821dcc-10b5-4f22-b39f-e07fc195445f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# mle of p(w,x,c)\n",
    "p_WXC_em = get_p_WXC2(em_params).reshape(2, -1)\n",
    "p_XC_em = p_WXC_em.sum(axis=0)\n",
    "p_XC_em = fix_div_by_zero(p_XC_em)\n",
    "p_W_XC_em = np.einsum('wi,i->wi', p_WXC_em, 1/p_XC_em).reshape(2, 2, -1)\n",
    "\n",
    "p_WXC_em = pd.Series(get_p_WXC2(em_params).flatten())\n",
    "\n",
    "pd.DataFrame({\n",
    "    'wxc': WXC_vals,\n",
    "    'emp': p_WXC_emp,\n",
    "    'em_zar': p_WXC_em\n",
    "}).to_csv(f\"p_wxc-{file_name}.csv\", index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0bc7683b-1429-44e3-bbc7-22e6580e33d9",
   "metadata": {},
   "source": [
    "#### Check constraints"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49a62118-487a-424d-879e-d262d52404c1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Check: p(w_0|x_1, c) = p(w_0|x_1) for all c ?\n",
    "p_w0_x1C_em = pd.Series(p_W_XC_em[0,1,:])\n",
    "p_w0_x1C_em.describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d31a30df-ea55-414d-802b-8a87826c15b8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Is OR(c) > 1 for all c or OR(c) < 1 for all c?\n",
    "ORs = []\n",
    "for c, c_val in enumerate(C_vals):\n",
    "    ORs.append(\n",
    "        odd_ratio(p_W_XC_em , c)\n",
    "    )\n",
    "ORs = np.asarray(ORs);\n",
    "print(f\"Does marginal constraint OR>1 or OR<1 for all c hold?: {(ORs > 1).all() or (ORs < 1).all()}.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3896efd5-16ec-4c67-a962-417b0b4bf42a",
   "metadata": {},
   "source": [
    "## Sensitivity-analysis"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "341f4b9b-cda0-4047-80ff-9bbdf7b6ba2c",
   "metadata": {},
   "source": [
    "### Proxy-indicator conditional distribution and Compatibility bound"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4ec72290-7986-42b5-bad8-41b9095f7448",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_bounds(p_WXC):\n",
    "    \"\"\"\n",
    "    p_WXC is a 2x2xCARD_C array\n",
    "    Assuming C does NOT point to W\n",
    "    \"\"\"\n",
    "    p_XC = np.sum(p_WXC, axis=0)\n",
    "    p_XC = fix_div_by_zero(p_XC)\n",
    "    p_W_XC = np.einsum('wxc,xc->wxc', p_WXC, 1/p_XC).reshape(2, 2, -1)\n",
    "    \n",
    "    # p(w0|r1) = p(x0|x1) is point identified\n",
    "    p_w0_r1 = p_W_XC[0,1,0]\n",
    "    \n",
    "    # bounds for p(w0|r0)\n",
    "    if p_W_XC[0,0,0] > p_W_XC[0,1,0]:\n",
    "        analytic_lb = p_W_XC[0,:,:].max()\n",
    "        analytic_ub = 1\n",
    "        cutoff_lb = analytic_lb + (analytic_ub - analytic_lb)/10\n",
    "        cutoff_ub = analytic_ub\n",
    "    elif p_W_XC[0,0,0] < p_W_XC[0,1,0]:\n",
    "        analytic_lb = 0\n",
    "        analytic_ub = p_W_XC[0,:,:].min()\n",
    "        cutoff_lb = 0\n",
    "        cutoff_ub = analytic_ub - (analytic_ub - analytic_lb)/10\n",
    "    else:\n",
    "        print(\"Marginal constraint OR>1 or OR<1 does not hold.\")\n",
    "        analytic_lb = -1\n",
    "        analytic_ub = -1\n",
    "    \n",
    "    print(f\"p(w0|r1) is identfied = {p_w0_r1}.\")\n",
    "    print(f\"Bounds: {analytic_lb} < p(w0|r0) < {analytic_ub}.\")\n",
    "\n",
    "    K = 50    # number of points to consider\n",
    "    if analytic_lb == analytic_ub:\n",
    "        p_w0_r0s = [analytic_lb]\n",
    "    else:\n",
    "        p_w0_r0s = np.linspace(analytic_lb, analytic_ub, K)\n",
    "    return p_w0_r1, p_w0_r0s, analytic_lb, analytic_ub\n",
    "\n",
    "def get_bounds_2(p_WXC, C_vals):\n",
    "    \"\"\"\n",
    "    p_WXC is a 2x2xCARD_C array\n",
    "    Assuming C point to W\n",
    "    \"\"\"\n",
    "    p_C = np.sum(p_WXC, axis=(0,1))\n",
    "    p_C = fix_div_by_zero(p_C)\n",
    "    p_WX_C = np.einsum('wxc,c->wxc', p_WXC, 1/p_C).reshape(2, 2, -1)\n",
    "\n",
    "    p_w0_r1, analytic_lb, analytic_ub = np.zeros(len(p_C)), np.zeros(len(p_C)), np.zeros(len(p_C))\n",
    "    for c, c_val in enumerate(C_vals):\n",
    "        p_WX_c = p_WX_C[:,:,c].reshape(2, 2, -1)    # p(WX | C=c)\n",
    "        p_w0_r1[c], _, analytic_lb[c], analytic_ub[c] = get_bounds(p_WX_c, [0])\n",
    "    return p_w0_r1, analytic_lb, analytic_ub"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "516450c3-e8e9-4321-9723-374b722213b4",
   "metadata": {},
   "source": [
    "### Calculate rate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5988c275-a817-40c4-b60e-428932a20b78",
   "metadata": {},
   "outputs": [],
   "source": [
    "def calc_rate(p_WXC, p_w0_r1, p_w0_r0s):\n",
    "    \"\"\"\n",
    "    Assuming C does NOT point to W\n",
    "    \"\"\"\n",
    "    # ZI law restoration and target calculation\n",
    "    p_RXCs = []\n",
    "    p_x11s = []\n",
    "    for p_w0_r0 in p_w0_r0s:\n",
    "        p_W_R = np.asarray([\n",
    "            [p_w0_r0, p_w0_r1],\n",
    "            [1-p_w0_r0, 1-p_w0_r1],\n",
    "        ])\n",
    "        # Kuroki-Pearl matrix inversion equation\n",
    "        inv = np.asarray([\n",
    "            [1-p_w0_r1, -p_w0_r1],\n",
    "            [p_w0_r0-1, p_w0_r0],\n",
    "        ]) / (p_w0_r0 - p_w0_r1)\n",
    "        p_RXC = np.matmul(inv, p_WXC.reshape(2, -1))    # reshaped to W_axis x XC_axis\n",
    "        # p_RXC = np.linalg.inv(p_W_R) @ p_WXC.reshape(2, -1)\n",
    "        p_RXCs.append(p_RXC)\n",
    "    \n",
    "        # check that p_RXC is a random matrix\n",
    "        # assert (p_RXC >= -1E-12).all()    # non-negativity condition. Small noise may occur.\n",
    "        \n",
    "        # Target = clabsi rate if ZI had not occured = p(X(1) = 1)\n",
    "        if len(C_vals) == 1:    # if ZCAR then len == 1\n",
    "            # ZI MCAR: p(x(1)=1) = p(x(1)=1 | r=1) = p(x=1 | r=1)\n",
    "            p_R = p_RXC.sum(axis=1)\n",
    "            p_R = fix_div_by_zero(p_R)\n",
    "            p_X_R = np.einsum('rx,r->xr', p_RXC, 1/p_R)\n",
    "            p_x11 = p_X_R[1,1]\n",
    "            p_x11s.append(p_x11)\n",
    "        else:\n",
    "            # ZI MAR: p(x(1)=1) = \\sum_c p(x=1 | r=1, c) p(c)\n",
    "            p_RXC = p_RXC.reshape(2, 2, -1)    # reshape to W_axis x X_axis x C_axis\n",
    "            p_RC = np.sum(p_RXC, axis=1)\n",
    "            p_RC = fix_div_by_zero(p_RC)\n",
    "            p_X_RC = np.einsum('rxc,rc->xrc', p_RXC, 1/p_RC)\n",
    "            p_C = np.sum(p_RXC, axis=(0, 1))\n",
    "            p_x11 = np.matmul(p_X_RC[1,1,:], p_C)\n",
    "            p_x11s.append(p_x11)\n",
    "\n",
    "    return p_x11s, p_RXCs\n",
    "\n",
    "# def calc_rate_2(p_WXC, p_w0_r1, analytic_lbC, analytic_ubC, C_vals):\n",
    "#     \"\"\"\n",
    "#     Assuming C points to W\n",
    "#     \"\"\"\n",
    "#     # ZI law restoration and target calculation\n",
    "#     p_x11s = []\n",
    "#     for bound in [analytic_lbC, analytic_ubC]:\n",
    "#         p_RXC = np.zeros_like(p_WXC)\n",
    "#         # calc p(WXc) for each c\n",
    "#         for c, c_val in enumerate(C_vals):\n",
    "#             p_w0_r0 = bound[c]\n",
    "#             p_W_R = np.asarray([\n",
    "#                 [p_w0_r0, p_w0_r1],\n",
    "#                 [1-p_w0_r0, 1-p_w0_r1],\n",
    "#             ])\n",
    "#             # Kuroki-Pearl matrix inversion equation\n",
    "#             inv = np.asarray([\n",
    "#                 [1-p_w0_r1, -p_w0_r1],\n",
    "#                 [p_w0_r0-1, p_w0_r0],\n",
    "#             ]) / (p_w0_r0 - p_w0_r1)\n",
    "#             p_RXC[:,:,c] = inv @ p_WXC[:,:,c]\n",
    "        \n",
    "#         # ZI MAR: p(x(1)=1) = \\sum_c p(x=1 | r=1, c) p(c)\n",
    "#         p_RC = np.sum(p_RXC, axis=1)\n",
    "#         p_RC = fix_div_by_zero(p_RC)\n",
    "#         p_X_RC = np.einsum('rxc,rc->xrc', p_RXC, 1/p_RC)\n",
    "#         p_C = np.sum(p_RXC, axis=(0, 1))\n",
    "#         p_x11 = p_X_RC[1,1,:] @ p_C\n",
    "#         p_x11s.append(p_x11)\n",
    "\n",
    "#     dummy_xs = np.linspace(np.min(analytic_lbC), np.max(analytic_ubC), len(p_x11s))\n",
    "#     return p_x11s, dummy_xs"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ee561d29-d721-4e88-9d08-11f2c0253b02",
   "metadata": {},
   "source": [
    "### Comparison"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "56d19672-dcef-4501-8be7-c5f85a332987",
   "metadata": {},
   "source": [
    "We fit p(WXC) using ZI MAR EM, where $W$ is either 'EPIC' or 'composite'. We then perform sensitivity analysis using these fitted p(WXC).\n",
    "Finally we plot no_missing_clabsi_rate (or observed rate) vs estimated CLABSI rate using the newly found compatible p(W|R)s."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "d405aa03-b433-4304-a473-9dd527b81bc3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PatientData_20230315-W_E-X_NH-C_Pe_Ch_OP_TP_Ot_Po_PI_Tu\n",
      "p(w0|r1) is identfied = 0.5646676211015283.\n",
      "Bounds: 0.8982735294682401 < p(w0|r0) < 1.\n"
     ]
    }
   ],
   "source": [
    "# W = epic\n",
    "W = 'EPIC'\n",
    "file_name = (\n",
    "    'PatientData_20230315'\n",
    "    + '-W_' + ''.join([x[0] for x in W.split('_')])\n",
    "    + '-X_' + X[:2]\n",
    "    + '-C_' + '_'.join([str(x[0:2]) for x in C])\n",
    ")\n",
    "\n",
    "print(file_name)\n",
    "df = pd.read_csv(f\"p_wxc-{file_name}.csv\")\n",
    "p_WXC_em_e = deepcopy(df[\"em_zar\"])\n",
    "\n",
    "p_WXC = p_WXC_em_e.to_numpy().reshape(2,2,-1)\n",
    "p_w0_r1_em_e, p_w0_r0s_em_e, analytic_lb_em_e, analytic_ub_em_e = get_bounds(p_WXC)\n",
    "p_x11s_em_e, _ = calc_rate(p_WXC, p_w0_r1_em_e, p_w0_r0s_em_e)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "fceec19f-228b-43a5-92cf-b8a3532ae997",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PatientData_20230315-W_EoC-X_NH-C_Pe_Ch_OP_TP_Ot_Po_PI_Tu\n",
      "p(w0|r1) is identfied = 0.5642613279058033.\n",
      "Bounds: 0.8992726040514565 < p(w0|r0) < 1.\n"
     ]
    }
   ],
   "source": [
    "# # to read from save file and replot\n",
    "W = 'EPIC_or_CRISP'        # Inflation indicator's proxy\n",
    "file_name = (\n",
    "    'PatientData_20230315'\n",
    "    + '-W_' + ''.join([x[0] for x in W.split('_')])\n",
    "    + '-X_' + X[:2]\n",
    "    + '-C_' + '_'.join([str(x[0:2]) for x in C])\n",
    ")\n",
    "\n",
    "print(file_name)\n",
    "df = pd.read_csv(f\"p_wxc-{file_name}.csv\")\n",
    "p_WXC_em_mix = deepcopy(df[\"em_zar\"])\n",
    "\n",
    "p_WXC = p_WXC_em_mix.to_numpy().reshape(2,2,-1)\n",
    "p_w0_r1_em_mix, p_w0_r0s_em_mix, analytic_lb_em_mix, analytic_ub_em_mix = get_bounds(p_WXC)\n",
    "p_x11s_em_mix, _ = calc_rate(p_WXC, p_w0_r1_em_mix, p_w0_r0s_em_mix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b8ab4ce0-a28d-4f19-bb6e-ee45bcd9b6aa",
   "metadata": {},
   "outputs": [],
   "source": [
    "W = 'EPIC_or_CRISP'        # Inflation indicator's proxy\n",
    "output_name = (\n",
    "    'PatientData_20230315'\n",
    "    + '-W_' + ''.join([x[0] for x in W.split('_')])\n",
    "    + '-X_' + X[:2]\n",
    "    + '-C_' + '_'.join([str(x[0:2]) for x in C])\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "364f9d29-45a2-45a9-8d59-7271a279979f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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lJRkdtxEREREZP/sMoe6QYMGAFBi0Ckdk9qa60+hUEAIgUaNGhltIz1+79497WPu7u7w9fVFSkqK2fMKCgqQmpoKPz8/o+1UKpVBIE9ERERElZ9drlC3atUKgCb32dRNh6dPnwYA7YYvJXF3d0dQUBAAGN0JUffx4pU+2rRpI+s8Y+cSERERUdVnlwF1vXr10K5dOwDApk2bDI4fPXoUSUlJUKlUiIqKktVndHQ0AP2UDl379+8HoNlQxth5hw4dglqtNnleUFAQN2ghIiIiegrZZUANALNmzQIALF68GGfPntU+/uDBA23e8sSJE/V2Sdy5cyeaNWuG7t27G/Q3efJk+Pj4YN++fVizZo3esbi4OHz55ZfadrqGDx+OwMBAXLx4EfPmzdMLqr///nssXbrU6HlERERE9HSw263HAWDKlCn46KOP4OTkhO7du8PNzQ0HDx5EWloawsLCsH//fri4uGjbb9iwAa+++ioCAgJw8+ZNg/7279+Pvn37Ijc3F82bN8ezzz6L3377TbuRzNy5c/Huu+8anPfLL7+gW7duePjwIQIDA9GyZUskJyfj1KlTUKvVGDVqFNavXw+FQiH72rj1OBEREZF9q9Rbj0tiY2OxZcsWdOrUCcePH8e+fftQr149LF68GIcOHdILpuXo2bMnzp8/j1GjRiEtLQ1ff/01bt++jaioKMTHxxsNpgGgRYsWuHjxIiZMmICioiLs2bMHV65cQZcuXbB582Zs2LDBomCaiIiIiKoOu16hrsq4Qk1ERERk36rECjURERERkb1jQE1EREREZAO73NiFSpFQA/kPKnoURERERKXLuQagsI+1YQbUVV3+A+DbWhU9CiIiIqLS1fs+oPKt6FEAYMoHEREREZFNGFATEREREdmAATURERERkQ2YQ13VOdfQ5BgRERERVSXONSp6BFoMqKs6hdJuEvaJiIiIqiKmfBARERER2YABNRERERGRDRhQExERERHZgAE1EREREZENGFATEREREdmAATURERERkQ0YUBMRERER2YABNRERERGRDRhQExERERHZgAE1EREREZENGFATEREREdmAATURERERkQ0YUBMRERER2cCxogfwtBJCAAAyMjIqeCREREREZIwUp0lxmykMqCtIZmYmAMDf37+CR0JEREREJcnMzISXl5fJ4wphLuSmMqFWq3H37l14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",
      "text/plain": [
       "<Figure size 800x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot sensitivity-analysis curve\n",
    "\n",
    "plt.figure(figsize=(8,5))\n",
    "\n",
    "plt.plot(p_w0_r0s_em_e, p_x11s_em_e, \"*\", c='#FE6100', lw=1, ms=8, label=\"EHRS\")            # EHRS is EPIC, for blind submission version\n",
    "plt.plot(p_w0_r0s_em_mix, p_x11s_em_mix, \"^\", c='#785EF0', lw=1, ms=8, label=\"EHRS or HIE\") # HIE is CRIPS, for blind submission version\n",
    "all_p_w0_r0s = [*p_w0_r0s_em_e, *p_w0_r0s_em_mix]\n",
    "observed_rate = np.sum(p_WXC_emp.to_numpy().reshape(2,2,-1), axis=(0,2))[1]\n",
    "plt.plot([np.min(all_p_w0_r0s), np.max(all_p_w0_r0s)], np.ones(2)*observed_rate, \"-\", c=\"#FFB000\", lw=3, label=f\"observed rate: {observed_rate*100:.2f}%\")\n",
    "\n",
    "plt.rcParams.update({'font.size': 16})\n",
    "\n",
    "plt.xlabel(\"Pr( not having data access | ZI-case ), $p(W=0|R=0)$\", fontsize=16) #, fontweight='bold')\n",
    "plt.ylabel(\"CLABSI rate\", fontsize=16) #, fontweight='bold')\n",
    "plt.legend(loc=\"upper right\", fontsize=16)\n",
    "plt.suptitle(\"Adjusted CLABSI rate sensitivity analysis\", fontsize=20)\n",
    "plt.title(\"Data: PatientData_20230315\", fontsize=12)\n",
    "plt.savefig(f'{output_name}.jpeg')\n",
    "plt.savefig('UAI_clabsi.jpeg')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
