Skip to content

Instantly share code, notes, and snippets.

@fonnesbeck
Created May 6, 2015 19:01
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save fonnesbeck/04e6e569e207fc045a22 to your computer and use it in GitHub Desktop.
Save fonnesbeck/04e6e569e207fc045a22 to your computer and use it in GitHub Desktop.
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "code",
"execution_count": 1,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
":0: FutureWarning: IPython widgets are experimental and may change in the future.\n"
]
}
],
"source": [
"%matplotlib inline\n",
"import numpy as np\n",
"import pandas as pd\n",
"import matplotlib.pyplot as plt\n",
"import pymc3 as pm"
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"flu = pd.read_csv('data/flu.csv', index_col=0)"
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"(1406, 60)"
]
},
"execution_count": 3,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"flu.shape"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Turn into table of unique patients, with appropriate organism columns"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"flu_only = flu.groupby('PatientID')['OrganismName'].apply(lambda s: \n",
" len([x for x in s if str(x).startswith('Influenza')])==len(s)).astype(int)"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"coinfections = flu.groupby('PatientID')['OrganismName'].apply(lambda s: \n",
" [x for x in s.dropna() if not str(x).startswith('Influenza')])"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"MRSA coinfection"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"mrsa = coinfections.apply(lambda x: x.count('Staphylococcus aureus, meth resist') > 0).astype(int)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Any coinfection"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"any_coinf = coinfections.apply(lambda x: int(len(x)>0))"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"/usr/local/lib/python3.4/site-packages/pandas/util/decorators.py:81: FutureWarning: the 'cols' keyword is deprecated, use 'subset' instead\n",
" warnings.warn(msg, FutureWarning)\n"
]
}
],
"source": [
"flu_unique = flu.drop_duplicates(cols=['PatientID']).set_index('PatientID')"
]
},
{
"cell_type": "code",
"execution_count": 9,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"flu_unique['flu_only'] = flu_only\n",
"flu_unique['mrsa'] = mrsa\n",
"flu_unique['any_coinf'] = any_coinf"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Add time from admission to time on ECMO"
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"admit_through_emco = flu_unique.AdmitToTimeOnHours.add(flu_unique.HoursECMO, fill_value=0)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"See how many have no time information from admission, and drop these"
]
},
{
"cell_type": "code",
"execution_count": 11,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"1"
]
},
"execution_count": 11,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"missing = admit_through_emco.isnull()\n",
"missing.sum()"
]
},
{
"cell_type": "code",
"execution_count": 12,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"/usr/local/lib/python3.4/site-packages/pandas/computation/expressions.py:190: UserWarning: evaluating in Python space because the '-' operator is not supported by numexpr for the bool dtype, use '^' instead\n",
" unsupported[op_str]))\n"
]
}
],
"source": [
"flu_complete = flu_unique[missing-True]\n",
"admit_through_emco.dropna(inplace=True)"
]
},
{
"cell_type": "code",
"execution_count": 13,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"0"
]
},
"execution_count": 13,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"# Confirm no null here\n",
"admit_through_emco.isnull().sum()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Time off ECMO through to event (death or discharge)"
]
},
{
"cell_type": "code",
"execution_count": 14,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"off_ecmo_to_event = flu_complete.TimeOffToDCDateHours.add(flu_complete.TimeOffToDeathDateHours, \n",
" fill_value=0)"
]
},
{
"cell_type": "code",
"execution_count": 15,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"51"
]
},
"execution_count": 15,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"off_ecmo_to_event.isnull().sum()"
]
},
{
"cell_type": "code",
"execution_count": 16,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"/usr/local/lib/python3.4/site-packages/IPython/kernel/__main__.py:2: SettingWithCopyWarning: \n",
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
"Try using .loc[row_indexer,col_indexer] = value instead\n",
"\n",
"See the the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy\n",
" from IPython.kernel.zmq import kernelapp as app\n"
]
}
],
"source": [
"# Not sure why add() does not work here\n",
"flu_complete['time_to_event'] = (admit_through_emco.values + off_ecmo_to_event.fillna(0).values)"
]
},
{
"cell_type": "code",
"execution_count": 17,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"0"
]
},
"execution_count": 17,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"flu_complete.time_to_event.isnull().sum()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Clean covariates"
]
},
{
"cell_type": "code",
"execution_count": 18,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"W 554\n",
"A 102\n",
"B 83\n",
"H 82\n",
"O 56\n",
"dtype: int64"
]
},
"execution_count": 18,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"flu_complete.Race.value_counts()"
]
},
{
"cell_type": "code",
"execution_count": 19,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"/usr/local/lib/python3.4/site-packages/IPython/kernel/__main__.py:1: SettingWithCopyWarning: \n",
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
"Try using .loc[row_indexer,col_indexer] = value instead\n",
"\n",
"See the the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy\n",
" if __name__ == '__main__':\n"
]
}
],
"source": [
"flu_complete['non_white'] = (flu_complete.Race!='W').astype(int)"
]
},
{
"cell_type": "code",
"execution_count": 20,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"/usr/local/lib/python3.4/site-packages/IPython/kernel/__main__.py:1: SettingWithCopyWarning: \n",
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
"Try using .loc[row_indexer,col_indexer] = value instead\n",
"\n",
"See the the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy\n",
" if __name__ == '__main__':\n"
]
}
],
"source": [
"flu_complete['male'] = (flu_complete.Sex=='M').astype(int)"
]
},
{
"cell_type": "code",
"execution_count": 21,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"/usr/local/lib/python3.4/site-packages/IPython/kernel/__main__.py:1: SettingWithCopyWarning: \n",
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
"Try using .loc[row_indexer,col_indexer] = value instead\n",
"\n",
"See the the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy\n",
" if __name__ == '__main__':\n"
]
}
],
"source": [
"flu_complete['OI'] = flu_complete.FiO2 * flu_complete.MAP / flu_complete.PO2"
]
},
{
"cell_type": "code",
"execution_count": 22,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"/usr/local/lib/python3.4/site-packages/IPython/kernel/__main__.py:2: SettingWithCopyWarning: \n",
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
"Try using .loc[row_indexer,col_indexer] = value instead\n",
"\n",
"See the the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy\n",
" from IPython.kernel.zmq import kernelapp as app\n",
"/usr/local/lib/python3.4/site-packages/pandas/core/indexing.py:415: SettingWithCopyWarning: \n",
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
"Try using .loc[row_indexer,col_indexer] = value instead\n",
"\n",
"See the the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy\n",
" self.obj[item] = s\n"
]
}
],
"source": [
"# ECMO Type\n",
"flu_complete['VA'] = flu_complete.Mode.isin(['VA', 'VV-VA'])\n",
"# Set \"Other\" type to NA (there are only a couple)\n",
"flu_complete.loc[flu_complete.Mode=='Other', 'VA'] = None"
]
},
{
"cell_type": "code",
"execution_count": 23,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"# covariates = ['male', 'AgeYears', 'non_white', 'HoursECMO', 'pH', 'PCO2', 'PO2', 'HCO3', \n",
"# 'SaO2', 'mrsa', 'any_coinf']\n",
"covariates = ['male', 'AgeYears', 'non_white', 'pH', 'PCO2', 'HCO3', 'PO2', 'OI', \n",
" 'SaO2', 'mrsa', 'any_coinf', 'AdmitToTimeOnHours', 'VA', 'PEEP']"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Get counts of missing values"
]
},
{
"cell_type": "code",
"execution_count": 24,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"male 0\n",
"AgeYears 0\n",
"non_white 0\n",
"HoursECMO 0\n",
"pH 11\n",
"PCO2 10\n",
"HCO3 19\n",
"PO2 9\n",
"OI 43\n",
"SaO2 16\n",
"mrsa 0\n",
"any_coinf 0\n",
"AdmitToTimeOnHours 13\n",
"VA 2\n",
"PEEP 38\n",
"dtype: float64"
]
},
"execution_count": 24,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"flu_complete[covariates].isnull().mean().round(2)*100"
]
},
{
"cell_type": "code",
"execution_count": 28,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"Index(['RunNo', 'AgeDays', 'HoursECMO', 'SupportType', 'PrimaryDx', 'Mode', 'Discontinuation', 'DischargedAlive', 'DischargeLocation', 'YearECLS', 'VentType', 'Rate', 'FiO2', 'PIP', 'PEEP', 'MAP', 'HandBagging', 'pH', 'PCO2', 'PO2', 'HCO3', 'SaO2', 'Venttype24', 'Rate24', 'Fio224', 'PIP24', 'PEEP24', 'MAP24', 'Handbagging24', 'SBP', 'DBP', 'MapHemo', 'SVO2', 'PCWP', 'SPAP', 'DPAP', 'MPAP', 'CI', 'Race', 'Sex', 'AdmitToTimeOnHours', 'TimeOffToExtubationDateHours', 'TimeOffToDeathDateHours', 'TimeOffToDCDateHours', 'ExtubationToDCDateHours', 'ExtubationToDeathDateHours', 'year', 'HoursVent', 'AgeYears', 'age_class', 'RunID', 'OrganismNo', 'OrganismName', 'CultureSite', 'CultureTimeIsApproximate', 'OrganismTiming', 'Type', 'has_flu', 'fate', 'flu_only', 'mrsa', 'any_coinf', 'time_to_event', 'non_white', 'male', 'OI', 'VA'], dtype='object')"
]
},
"execution_count": 28,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"flu_complete.columns"
]
},
{
"cell_type": "code",
"execution_count": 29,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/html": [
"<div style=\"max-height:1000px;max-width:1500px;overflow:auto;\">\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>HoursECMO</th>\n",
" <th>AdmitToTimeOnHours</th>\n",
" </tr>\n",
" <tr>\n",
" <th>fate</th>\n",
" <th></th>\n",
" <th></th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>Died</th>\n",
" <td> 324.935754</td>\n",
" <td> 101.009709</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Survived</th>\n",
" <td> 293.647280</td>\n",
" <td> 60.439914</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" HoursECMO AdmitToTimeOnHours\n",
"fate \n",
"Died 324.935754 101.009709\n",
"Survived 293.647280 60.439914"
]
},
"execution_count": 29,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"flu_complete.groupby('fate')[['HoursECMO', 'AdmitToTimeOnHours']].mean()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"We are going to drop the missing values for some of the covariates, and not use some covariates with many missing values."
]
},
{
"cell_type": "code",
"execution_count": 25,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"drop_subset = ['HoursECMO', 'pH', 'PCO2', 'PO2', 'VA']"
]
},
{
"cell_type": "code",
"execution_count": 26,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"flu_complete = flu_complete.dropna(subset=drop_subset)"
]
},
{
"cell_type": "code",
"execution_count": 27,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"image/png": [
"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\n",
"ApZ93ScIAAAAAElFTkSuQmCC\n"
],
"text/plain": [
"<matplotlib.figure.Figure at 0x10ac36da0>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"flu_complete[['pH', 'PCO2', 'PO2', 'HCO3', \n",
" 'SaO2']].hist(bins=25);"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Survival Analysis"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Surivival time, in days"
]
},
{
"cell_type": "code",
"execution_count": 28,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"obs_t = flu_complete.time_to_event.values/24."
]
},
{
"cell_type": "code",
"execution_count": 29,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"image/png": [
"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\n",
"AAAASUVORK5CYII=\n"
],
"text/plain": [
"<matplotlib.figure.Figure at 0x10b4976d8>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"plt.hist(obs_t, bins=25);"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Fate of each patient"
]
},
{
"cell_type": "code",
"execution_count": 30,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"died = (flu_complete.fate=='Died').astype(int).values"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Kaplan-Meier Curves"
]
},
{
"cell_type": "code",
"execution_count": 31,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"from lifelines import KaplanMeierFitter"
]
},
{
"cell_type": "code",
"execution_count": 32,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"image/png": [
"iVBORw0KGgoAAAANSUhEUgAAAXMAAAEQCAYAAABC2pRmAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\n",
"AAALEgAACxIB0t1+/AAAIABJREFUeJzt3XuYHFWd//H3mVy55A4JN8MGEhLRkHBpgTC59YBBRCC6\n",
"EVd8UFZZgWV95Ked9Qe/Bwi/FV0aia4I/h4VV1AfFQVxXVYk00CC3JprIpdAgBCuIUwuhiSTTDLn\n",
"98epznQmXdM9U9Vdp3s+r+fpZ6aqq6s+qUzOVL516hxjrUVEROpbU9IBREQkOjXmIiINQI25iEgD\n",
"UGMuItIA1JiLiDQANeYiIg2gbGNujGk2xjxmjLmugm1bjDHLjDFLjTHpeCKKiEg5AyvYZghwLTCj\n",
"p42MMQa4BmgBDHAPkIsaUEREyit7ZW6tbQU2VLCvScBKa227tXYbsMoYMzFqQBERKa+SK/NKjQE2\n",
"GWNuwF2ZbwrWrYrxGCIiUkKcjXkbMBK4GNeY3xysExGRKutNY27KvL8KV2opbDvRWht6Vd7a2qpB\n",
"YURE+qClpWWv9rhsY26M+VfgY8A4Y8xwa+2Xg/ULgC3W2rsBrLWdxphFwBLAAov6EkhERMKFXQhX\n",
"cgP03621c6y1Hyw05MH62wsNedG6e621zdbamdbae8vtO5XNDa4kfBKMMXOSzlCOMkbnez5Qxrj4\n",
"njFqvqQfGpqe8PFFRBpC4o15KpuL8yZsbKy19yedoRxljM73fKCMcfE9Y9R8STfmFwGjE84gIlL3\n",
"kr4qPhbXmL+bcI69GGPm+P6bXBmj8z0flM7Y2traNHz48MVDhgyZaoxJ+qKMjRs3jhw5cuTGpHP0\n",
"xPeMGzduHDlixIgNO3fu3Nre3r54xowZS3rz+aQbc4AzUtncynwmra6KIhUaPnz44ilTplw0bNgw\n",
"bzsRSN9Ya3nzzTdT+Xz+e6lU6puVfi7p3+gbgYnAYQnn2IvvV2ugjHHwPR+UzjhkyJCpasgbkzGG\n",
"ww477MAhQ4b0arDCpBvzTcAJdD1sJCIV8KG0ItVljBnQm+2T/oF4DXdlPjKVzXn1AJHvfVJBGePg\n",
"ez6oj4ySvKQb83uAUcAZwAEJZxGRiObOncuTTz65e/miiy5i0aJFzJ07l7POOguAjo4ODjjgAK65\n",
"5pqq59m0aRM333xz6Pu7du3ii1/8Irt27arZMasl6cb8QWANcDowKOEse6jXWqpvfM/oez6oj4yl\n",
"XHbZZYwcOZKrrroKgFWrVrFu3TruuusuRo+uTY/kDRs2cNNNN4W+P2DAAH7yk58wYECvKhqRjlkt\n",
"STfm7cAfgEOB4QlnEZEYWGu5/PLL6ejo4Nvf/vbu9eeddx4///nP+fWvf825555b8f6efPJJ0uk0\n",
"c+bM4ZOf/CRtbV2Dsa5evZp58+Yxa9Ysmpub+d3vfrf7vYcffphPf/rTrF69mlmzZjF//vw99nvh\n",
"hRcyc+ZMhg0btsf6RYsWceGFF5JKpbj22mu56KKLOOaYY+js7ARgxYoVzJ8/n7lz5zJlyhR+//vf\n",
"V3zMX/ziF5xyyinMnDmTr33taxWfg4pYaxN5LVmyxJ5wXevEE65r/ecTrmu1J1zX+oWkspR6AXOS\n",
"zqCMyheWcfny5fdbD82ZM8cuWLDAHnjggXb79u17rH/sscfsrFmz7Gc/+1l7/fXX20WLFpXd344d\n",
"O+y0adPsW2+9Za219re//a39x3/8x93vX3bZZXbx4sWhn1+9erWdOnVqj8cYNmzYHstXX321Pf/8\n",
"8+0zzzxjR48ebdevX2+nT59un3/+eWutte+///7uP9tTTz1ljzrqqIqO+eyzz9rZs2fbjo4Oa621\n",
"l156qb3ttttCcwV/x3v9PCxZssSWWp90P/P1wLrg+5NT2dzd+UzauweIROpNKhvPjI35TO+n8m1q\n",
"auLMM8/kG9/4BjfccMPu9QMGDODKK6/kkEMO4e677+5hD11eeOEF1qxZw3nnnbe70RoyZMju9xcs\n",
"WMAll1zC6tWrOeecc5gzZ06v85Yybdo0RowYwaGHHsqoUaMYOXIkW7duBWC//fbj9ddf59FHH2XN\n",
"mjW88847Fe2ztbWV119/nY9+9KNYa9m2bVus5aZEG/N8Jr0+lc2tAV4BBuMmt/CiMbd1UKdUxuh8\n",
"zwd9y9iXRjguCxcuZPLkyRx33HHMmzePefPm7X6vpaUFoOLGfODAgUyYMIFcrvQvp5NPPpknnniC\n",
"hx56iMWLF3PHHXfwH//xH9H/ED245ZZbuPXWW7n44ouZNWtW4X9PZQ0cOJBzzjmH73znO1XJlXTN\n",
"HOCN4OuHgEOSDCIi8dhvv/247bbb+NKXvsS77/b9+mzy5Mls376dO++8c/e64sazs7OTpqYmmpub\n",
"yWQyPProo3t8fujQobS1te2ud5dqeCttjAvuuusurrjiCs4991xeeumlvT4fdszTTz+d22+/nZdf\n",
"frnPx+6JD435etz0cilgRMJZdquHvr3KGJ3v+aA+MhYY0/W4yEc+8hEuueQSzj///D7vr6mpibvu\n",
"uosf/ehHu28c/uAHP9j9/i9/+UtmzJjBzJkzWbhwITfeeOMenx83bhyzZ8/m2GOPZd68eTz++OM9\n",
"Zq7kz3XZZZdx6aWXMnfuXFavXs2oUaPYsmVL2WNOmDCBH//4x3zuc59j5syZNDc38/DDD/f6nIRm\n",
"jPM3Q2+0trbawkxDqWzuc8BtwGLg+/lM+tVEQhWp1wGYfON7Rt/zQemMK1asuH/q1KmzE4okNbBi\n",
"xYoHpk6dOqf7+uK2s1jSN0AL3gLexD3WPyWVzb2Wz6Q7kwzk+z9wUMY4+J4P6iNjX/30pz/llltu\n",
"KXl1fMopp/Ctb30rgVT1yZfGfBvu0f4P4/qcH4GbIFpEGtgFF1zABRdckHSMhuBDzRxgB7AS+Dtg\n",
"F3BgommojzqlMkbnez6oj4ySPF8a8/dxV+YA+wJjE8wi4j2b1M0uqRlrba9Kzb405quAvwbffx0Y\n",
"kcrmxiWYpy7qlMoYne/5oHTGnTt3blV73rg6Ozvp6Ojo1axIXjTm+Ux6F/A2cBOu1DIBmJ5kJhGf\n",
"tbe3L37zzTfXld9S6k1nZyd//etfn9u8efNlvfmcLzdAwU1UURg780RgZSqbG5zPpHckEaZeu6z5\n",
"xveMvueD0hlnzJixJJ/Pf2/9+vXp3k5iUA2+z68J/mcM5gBd39HRsXHz5s2XzZkz57Xyn+riU2Ne\n",
"OMl3A7OAO3DTyb2SWCIRjwXzQ1Y8R2Q11esvRZ9EzedFmSXwPtABPADsD3QCY5IK4/NfeoEyRud7\n",
"PlDGuPieMWo+3xrz9biHhwCmAeNS2ZxP/3sQEfGSN415cBP0FdxV+cvAV3APEKWSyFMPfXuVMTrf\n",
"84EyxsX3jFHzedOYB14E1tJVB/wbHjxAJCLiO68a83wmvRM3J2ihA+0sYFQqmzuo1ll8r6+BMsbB\n",
"93ygjHHxPWMj1cwLNgJDgOXA8bgeN7o6FxHpgY+N+VpgC/A4MBHXuE9IZXPlBx2Oke/1NVDGOPie\n",
"D5QxLr5nbLSaOflMegvuAaJXgFHAqbjp5A5OMpeIiM+8a8wDbwDvAX8BvgwMAsbXMoDv9TVQxjj4\n",
"ng+UMS6+Z2zEmjnAClxPllsBg+uDfmgqmxuUaCoREU952ZgHvVq24K7OAT6Bmx+0ZhM++15fA2WM\n",
"g+/5QBnj4nvGhquZF1kLDAP+BzgBl3VioolERDxVtjE3xrQYY5YZY5YaY9Jltr3AGPOoMeZBY8zc\n",
"iNnW4kosy4DJuKv04RH3WTHf62ugjHHwPR8oY1x8z1jVmrlxs6xeA5wGzAOuLrO/y4CTgTOAa6ME\n",
"w9XJAZ4Ovn4CGJbK5kZE3K+ISMMpd2U+CVhprW231m4DVhljeip1LMd1JTwL+FPEbG3AS7hhcJfg\n",
"xjgfRI1KLb7X10AZ4+B7PlDGuPiesdo18zHAJmPMDcaYxbj+3z0NS7sM+DzwceCpKMHymbTFjdWy\n",
"E/gj8CGgHTgilc3tE2XfIiKNptzwsm24B3YuxtWvbw7W7cUYcySQttaeGyzfZ4xZYq3dGrbz4sHY\n",
"C7+VipebBg9tOu7f/nsTbmhctq19bf4+4w7/M3CoMeaw7tvHuVxJPh+Wi7P6kEfL8S9ba+/3KU+p\n",
"5cI6X/LU67+XSvOVYnqaFNYY0wQsxZVOmoA/W2ubQ7adBHzfWnu6MWYQ8BhwsrW2vdT2ra2ttqWl\n",
"pewj+qls7iO4cs+VuBuglwPP5TPpR8t9VkSk0YS1nT2WWay1ncAiXM36nuB7AIwxC4wxZxRt+xKw\n",
"1BjzMK7c8t2whryX1uMa8duAg3ClnnEx7LdHvtfXQBnj4Hs+UMa4+J4xar6ys/hYa+8F7i2x/vYS\n",
"664lei+W7taw5wxE+wADUtnc2Hwm/W7MxxIRqUs+PzQEQD6T3oF7tH8U7gbox4EBwL7VPK7vfVJB\n",
"GePgez5Qxrj4nrFRx2bp7rng61+Af8D1cJmcXBwREb/US2PeBmwHssFyYbLnnrpJRuJ7fQ2UMQ6+\n",
"5wNljIvvGavdz9wL+Uz6fdzAWyOAh3GTPFtct0kRkX6vLhrzwOu4xns97gEiqOLToL7X10AZ4+B7\n",
"PlDGuPiesb/UzME15jtwXSTH4Br1EbWeTk5ExEf11JhvwvVmWRUsn4nrpliVyZ59r6+BMsbB93yg\n",
"jHHxPWO/qJnD7gkrNgH740ZSPBDXT/7YJHOJiPigbhrzwFu4RnwN8Kng6/BqlFp8r6+BMsbB93yg\n",
"jHHxPWN/qpmD62++FvdoP8AM3E3RD4V+QkSkH6irxjyfSXcAq4EhwBPAUcA64IOpbC7WP4vv9TVQ\n",
"xjj4ng+UMS6+Z+w3NfMi24ChuGnkPgtsDJZrNqWciIhv6rExbwM6gf8Mlg3uRmhznFfnvtfXQBnj\n",
"4Hs+UMa4+J6xv9XMwV2Jv0/XHKHTgFeB0biuiiIi/U7dNeb5THo77iboPsAG4H8Hbw3AdVuMhe/1\n",
"NVDGOPieD5QxLr5n7I81c4DNuHFaFgJjg3UDgKPivhEqIlIP6rXhewP3NOiaYPlU3OQVE4BDUtnc\n",
"gKgH8L2+BsoYB9/zgTLGxfeM/bFmTj6TXoe7EToMuB+4AtfLpQNowc0ZKiLSb9RlYx5YC+wHXBMs\n",
"jwbexjXqE6Lu3Pf6GihjHHzPB8oYF98z9teaObhxWobgxjUHyARf1wMjU9lcVaeVExHxST035q/h\n",
"boQa4BvASbihcXcCg4GDo+zc9/oaKGMcfM8HyhgX3zP2y5o57B5FsR3XHfHRYHVhGrmdwJQkcomI\n",
"JKFuG/PAe8AhRcsnB1/fBsaksrnD+rpj3+troIxx8D0fKGNcfM/Yn2vmAE/S9STofcAXcP3PO3FX\n",
"58ensjnNEyoiDa/eG/NtwWsEcH2w7qu4evlbwAG4YXJ7zff6GihjHHzPB8oYF98z9tuaOUA+k7bA\n",
"y8BBwFbgO8DxwJeDTV4DRqeyubGl9yAi0hjqujEPLMd1RxwI/BG4FZgdvFfo2TKutzv1vb4GyhgH\n",
"3/OBMsbF94z9vWZeuDrfgSupAPwp+Fp4cGgz7spdRKRh1X1jHngad2U+AHdDdC0wL3hvA3BoKpvr\n",
"1dW57/U1UMY4+J4PlDEuvmfs1zXzgnwm/RqwBRgUrPoLcG7w/U7cn3N8AtFERGqiIRrzwC6g8Aj/\n",
"T4Ovhdr5OuDwVDY3aK9PhfC9vgbKGAff84EyxsX3jP2+Zl7kbbrGNn8fd3V+dbBuM66mflQiyURE\n",
"qqyRGvOXcE+E7hcsL8INifuDYLkNmJDK5oZWsjPf62ugjHHwPR8oY1x8z6iaeSCfSW8EXgdG4q7C\n",
"O3D9zQ8A/g7XmB+OmzNURKShNExjHngMN+jW8GD5VdzV+vm4R/zfAA5KZXNlJ372vb4GyhgH3/OB\n",
"MsbF94yqmRcJ+py/h+vBYoLVdwKjgu834R4gmpvK5gbXPqGISHWUbcyNMS3GmGXGmKXGmHSZbQ81\n",
"xuSCbb8TX8zKBeWWTXTVzl8BptP14NBLuLLLsT3tx/f6GihjHHzPB8oYF98zVrVmbowxuGnZTsM9\n",
"hHN1mf1dD1xhrZ1lrf1alGARvUfX2OaP4HqzfDZYtsBqYHxvuiqKiPis3JX5JGCltbbdWrsNWGWM\n",
"mVhqQ2NMEzDRWvtw3CH74EX2/LPdA3yiaHkrblKLAwjhe30NlDEOvucDZYyL7xmrXTMfA2wyxtxg\n",
"jFmMK1+MCdn2QGCoMeZOY0yrMWZ+lGBR5DPpdew5ccXPgq8fKdrMotmIRKRBlGvM23Bd/S4PXqOC\n",
"dWHbbgQ+BXwMuNwYU7bXSBU9jRurZX/cQ0QvABcVvf8mMDaVzQ0o9WHf62ugjHHwPR8oY1x8z1jt\n",
"fuarcKUWcL1DJlprV4UE2Ynr532wtXYHbn7OHhX/t8IYMyfO5ccXthz55r0/24fgxufmV/96H24k\n",
"xVkAax+880Mbn3tkOq6xj/34WtaylrVcreVSjLW2p/cxxpwGXIUrS1xjrb03WL8A2GKtvbto2/HA\n",
"D3H9vG+31n4vbL+tra22paXFhL0fh1Q2NwQ4B3dlXpi84gBcv3NwvVoeyGfSr3b/rDFmju+/yZUx\n",
"Ot/zgTLGxfeMleYLazvLdk201t5rrW221s4sNOTB+tuLG/Jg3Rpr7RnB9qENea3kM+ntuJ4ro3G/\n",
"jH4CfADXVRFcI39cKpvbP5GAIiIxaaiHhkK8XfT9s8BDwGLco/2FLoyTun/I59/gBcoYne/5QBnj\n",
"4ntGjc1S3pbga+GJzytwkz3/32B5LTAxlc0N7/5BEZF60fCNeT6TbsM13gcWrb4KV24ZgetuuT9w\n",
"SvFDROVuNvhAGaPzPR8oY1x8zxg1X8M35oHX6Xq8H1wvHejqd/4a7mboSWFdFUVEfNZfGvPXcHOB\n",
"Fvd7f4yuXi2duDFcJhOM2eJ7fQ2UMQ6+5wNljIvvGVUzr0DQq+Vt3IiJBT8ADqOrlr4dVz8/IpXN\n",
"HYKISB3pF4154GXcn7fQeK8JvhZP9LwZGApM22/8lDNrmK1PfK8Bgv8Zfc8HyhgX3zNGzTcwphz1\n",
"4F1cKWUCbtIKcDc/D6arhg7uZunYg2Z9elIqm3se1z99Qz6T3lDLsCIivdFvrszzmfQuXD9z6Ppz\n",
"v4Ib4rf4oaGdwFujp81ZAZwAtAAzU9nc4bXKWinfa4Dgf0bf84EyxsX3jKqZ904b8A5wZLCcwV15\n",
"n1di2/W4GvoruJ4wx6ayuaoOPyAi0lf9qjHPZ9KdQA53M/RgYBfwG+AzwJDibdc+eGfhkf9dwfaj\n",
"gbNS2dxZqWzu7FQ2N6NmwUP4XgME/zP6ng+UMS6+Z1Q/814KerY8RVc3xVuDr98o89HXcIN1bcP1\n",
"fJmYyuZO1dW6iPig3zXmgbdxY68PxTXQ/weYA5xR2GBc8/ynu31mF9ARvNpx46F/gD0nvKgp32uA\n",
"4H9G3/OBMsbF94yqmfdBUG7ZjCudAPwF+B2uhn58hbsplF8mpbK5xBp0ERHop4154CVg36LlH+J6\n",
"uywETFHNvCftuJuqk1LZ3CmpbK45lc2VnCO1GnyvAYL/GX3PB8oYF98zqmbed6/j+pkXxmLZCXwL\n",
"GIsbWbFS23Alm9G4OUePTmVzo2LMKSJSVr9tzIN+5ztwdfOCN4FrgZZxzfN7c4W9BVe2WYebJ/XI\n",
"VDZX9QeyfK8Bgv8Zfc8HyhgX3zNGzdefngAtZTswjK4xz8HVz28B/hk3I9EuYBmwpIL9WdyTph8E\n",
"2lLZ3PpgfUc+k94aV2gRke767ZV54BXc05+Di9ZtBW7b/MqKm4BWXAN9BfD5Cve5LdjHScDpuB4y\n",
"p8UVuJjvNUDwP6Pv+UAZ4+J7Ro3NEkE+k34xlc2Nw00h90bxe1vfWvXSsCOmPo27Un8J+BJwG264\n",
"3HLair43wN+lsrn5wfLafCb9UOTwIiJFjLU2kQOHzTBda6lsbjzwUdzgW7tCNmvCXaW/iOtnPgg3\n",
"6uI3KzxME65RHwgMB5ZHiFwJC6zJZ9LtVT6OiNRYWNvZr6/MA28Gr0PpGha3u07gC3QNyDUGWIQr\n",
"pyyu4BiFq/ldwffH9DFrpUYAd+G6TopIP9Dfa+aFXi2P4GrdhYeIKNHP/DVcP/RngaXA1cBZwLxe\n",
"HrIN1+sl8mvtg3ceGvLeNtw0eIlr9DplLShjPHzPqH7mMQjGKn8G161wvzKbFzwA/Ao3psukKkXr\n",
"q8I47SLST/T7mnlBKptrws3/+WHcVXglBgNZXNmkMK7LDsJr77UyCDgQN9xvORZYns+k28puKSKJ\n",
"C2s7dWUeCMZrWYl7+OfACj+2A/h68P0dwN24uUWT1oGbwHpIBa9D2XNYAxGpQ2rMi+Qz6feBx4GR\n",
"6/J/OrHCj3UAc4GPARfiRlJMVyfhnsqMH7OtwtdO3BOrJ6ayuZNS2dwH4szY6HXKWlDGePieUTXz\n",
"+K0Flg/cd9hw4ADcTdF9ev7Ibq8CfwI+3ovPJK0N111yHDAROCzZOCLSF6qZhwhGP9wXGAlMxk30\n",
"vKXHDzkTgW/jyi2PBOt24q7gfTcc153x/nwmvSPpMCKyN/Uz76V8Jr0KIJXN7Ysbw+Vo3JV3OauA\n",
"x4ArcQ3jINzIjHOrkzRW24AJuH70byecRUR6QWWWEIX6VTBA1tO4hm4Y7sGh/dlztMXurqOrjv6J\n",
"YN0lweuTcWWscMz13ujAdWuMTaPXKWtBGePhe0bVzGsgmDf0Bdy45Ztw5ZaDKvz4NuB63MM8W4Hz\n",
"qpExRoOovK+9iHhCZZYQ3ccWzmfSu+cEDcYqH46rj6+qYHf/HXwdhht98fdxZBzXPD/srRHAV4AV\n",
"fdhtB5UNJlaRRh9DuhaUMR6+Z9R45gnIZ9I7U9ncH4D5uJmJ3q3wo5uBM6n+eb+SoqEJ+mBYKpvr\n",
"3qvFAm/lM+lk7piLSI9UZglRrn4VNGoP4p4CHdaLXW/BlWoiv9Y+eOeEkPe24p5m7Yu/AVOAU7q9\n",
"ZtGH7paNXqesBWWMh+8ZVTNP1nu4UsbIpIN08zRuWN++2Ibra9/9FVvpRUTip37mEQVjunycrpuG\n",
"A+k20UUCDgK+C3wmxn0eAqym9LgzFng2n0lX0g9fRCLocz9zY0wLbrhXC1xtrc2V2X4wbhKH66y1\n",
"N/Utbv0IxnT5L4BUNjcMOBv3sFGSc37uxPUV/3GF2/8EeLjMNhsIH7NmDK6hV2MukpAeG3NjjAGu\n",
"AVpwM+XcA/TYmAMXAU/Eki5Bxpg5fbi7vBU3lO6HqEFjvvbBO6ePa57/dIm33gO+yJ5zm4ZZAIyn\n",
"fGNeGMullNA+9308jzXjez5Qxrj4njFqvnJX5pOAldba9uBgq4wxE621JbvjGWP2wdVqf0PXrDz9\n",
"Rj6T3pXK5tbihsTdj2SvVMNmTepuY0zHOyCVze3VqA+beOyImPYvIj0o15iPATYZY27AXZlvCtaF\n",
"9a3+CnAjbtCmutbX35D5TPrdVDb3Cu7x//eD1btwV8uxCrkq763NuP9NfRn3d9wK/Fsv97EVmFpi\n",
"/cDJ/3T9umjxqsvnK7UCZYyH7xmr3c+8DddT42LcP/Sb2XPm+d2MMcOBmdbafzfGfD7Yvr96ATev\n",
"KLhxWU5OMEs5Pwd+EXx/Eq7m31ubg1d3Q+jfPwciNVOuMV9F15RoBggtsQDNwBBjzC+BI4ABxpj7\n",
"rLXPhe28uEZU6GPp0fJXgaf78vl8Jr3BGDMN4ITrWpcC09cvXzoHYPQxs1YCbxfGVSlcXfdleXvb\n",
"mxPHn33pb/v6+aJlu/bBO6fv94HJE/Y//Ggbw/5Y++Cd082gwYNcS56+x4O/z5LLhXW+5Cm13D1r\n",
"0nlClvv876WGy9Ottd/1KE+f85VStmuiMeY04Cpcb5ZrrLX3BusXAFustXeX+Mz5wP499WbxvWti\n",
"nDdLglpyE+6G5Dxcv+3IergB2lfH48aR+Trx3MQevGHFsuZRU2c+EMO+quLdh/8wbezJZ/05n0n/\n",
"NeksYXy/cQfKGIdK84W1nepnXkPBmC4fp+cRF+MwGNeV8P1yG5bwLWAZbgq8OAzB74fTBgPt+Uz6\n",
"nqSDiFRC45l7oGhMl2r/Ejse95BPX6yPMwhuLHifaawZaQhqzENU679kwZgusTQgYRlT2VyU/Q8A\n",
"Do7w+T1UoRQUq3WP3n3MgSee8UzSOXrie3kAlDEO1e5nLvXJ4kZN7MtEE1vpfz1QBqayuUNj3ueu\n",
"fCb9Tsz7FAmlxjyEz7/BC3rI+BJu3tK+WI+rc8fC56tygANPPONx3DDGzXHvO5XN/S6fSe+Mup86\n",
"/1n0hu8ZNZ65lLKD0gNiVWoybqz2Yh3A/0Tcr486gWpcQdf9g3NSX3zuZZAo38c+hrIZm3CjJ1by\n",
"Kh6nPI974Gl8t9dF9KGWXoV5SmPlez5oiJ9FL/ieMWo+XZk3pu3AA1T2y3oscCRdg2itDF7dnRBP\n",
"NBGpBjXmIXyvr0F4xqDHzFuV7COVzfV69qDe8L1m7ns+qO+fRZ/4nlE1c4nDgOAF4TXx7cAPQt4f\n",
"CXwVWB5/tLplgEmpbK7UDE3r8pl03P35pZ9TzTyE7/U1iC3jNlxDPRzXnTHsYaNLgS/gxknv/nqK\n",
"kAmkfa9JVzFfO/Bh3HDIxa8TcfcgKtaPfharyveMqplLJPlM+g2Cae5S2dwY4NSQTduDVyl/q0K0\n",
"ehc2TvyomqaQfkNX5iF8r69BfWT0vSbtez6oj79nZYxONXOJW2EM8t4OCTCd0g8bvYObSk9EqkhX\n",
"5iF8r69BVTK244YA6G0pYBluJMhju71mdnZsvzzWhDHzvaYP/fZnMXa+Z1TNXGKTz6S3pLK5l4Gj\n",
"evnRHKUn+h4PZCMHE5GyNJ657CGVzX0Y15jH0XVuPG4+0fNj2FejGAW8Bng7GUYEu/KZdKMN9+Ad\n",
"jWculTJ09TmX+HUAU+iajrFRGNwMWvclHaS/UmMewvexj6FqGXcR489F586O/ZsGDjoirv3FbeML\n",
"j00eOeUjjxL/pBxh3qeXM0D5PiY8wLuP/PGEsSed2ZeZrWrG93/TGs9c4rYFN5JgHDbZXTvfZ+Cg\n",
"K2LaX+yGHzl9GPAp4EtJZxGJQo15CJ9/gxfUQcZNA4bs43W9vGnQ4MOBRUnn6InvV+UAY086czlu\n",
"PlVv+f56gNOoAAAMTklEQVTvRf3MpRr2Z+9+5hZ4r8R6EfGA+pmH8L1PKlQtYxtwP/BEt9d2+nDl\n",
"5Xs/7o3PPTIl6Qzl+H4OAd595I/HJJ2hHN//TaufucQqn0mXvEGXyuZ62/dcRGpIV+YhfK+vQX1k\n",
"9L3eO/Lok15IOkM5vp9D2F0z95rv/15UM5daGo7rJ13KZhpvflDppVQ2p2cUquzbx5Ver8Y8hO99\n",
"UqHmGV8gfMyWw3A3TTd1f8P3PtIbn3tkysijT0o6Ro98P4cA7z70hw+PnXFWG7Ag6SxhNqxYdvSo\n",
"qTOfSzpHmArzhVZT1JhLRfKZ9KvAq6XeS2VzTbgGve5Y29mJm9T6hph3vQ24kn7yvxXbuasTN0yB\n",
"t3Zseu8g3CieXqow3wFhb2hsFokslc2dgGvMwyZk8JnBzQgU94XNtcDf4x7CEonLAd8+zt6usVlE\n",
"9maBFVXYb7+4Ihd/qDdLCN/7pEJ9ZPS9j7Tv+UAZ4+J7xqj5dGUucdgJ7EeJmYYGDR89svZxRPof\n",
"NeYhfO/JAl5lfJ7SN0eHjj5mdq2z9IrvvURAGePie8ao+dSYS2T5THo77nH/PaSyubA+6SISM9XM\n",
"Q9RDPboeMq5fvvSDSWfoie91VFDGuPieMWo+NeYiIg1AjXkIj+rRoeoh4+hjZj2fdIae+F5HBWWM\n",
"i+8ZVTMX3w0ExiYdooztlBiKIKIdwG2UHv/9v4D/jPl40s9V1JgbY1qAq3E/mFdba3M9bPtDYDLu\n",
"yboLrLUlHwH3ncZmiUX7q7+5bteETy98IukgYdbcdeMp48++1BB/Y/45YGiJ9bOBXt1HqIexWZQx\n",
"uqj5yjbmxhgDXAO04Broe4DQxtxae1HwubnAQuDivoaT+pbPpDvNwpZ33sv/6eWks4QZmv38JGBE\n",
"FXa9NXh15/Wkx1K/KqmZTwJWWmvbrbXbgFXGmIkVfG4zJbqr1QvPr3gBZYzD1MzPliWdoRyfryYL\n",
"lDG6WtTMxwCbjDE34K7MNwXrVpX53BeB70UJJyIilamkMW8DRuLKJQa4OVgXyhhzJu5qvsdZXIpr\n",
"voU+0x4tfxV42qM8pZanW2u/61GevZYL63zJ0315yIGHDZ2a+dnuPr6Fq6MqLtPbzxf3P65Bvj4t\n",
"r7nrxr8fMubQVb7kKbW8ve3NiePPvvS3vuTpY743CFF2CFxjTBOwFDgVV5b5s7W2uYftjwf+wVr7\n",
"9Z726/sQuHVwc1EZYzB07AdOn5r52QhgbY0OeRqQwg2RWxHfb9yBMsahwnyhQ+CWrZlbazuBRcAS\n",
"3M3PRYX3jDELjDFndPvI7UDKGHOfMaZuyyw+N0AFyhidaubxUMboatLP3Fp7L3BvifW3l1h3RJRA\n",
"IiLSe3oCNEQ9jHuijNGtyH5+ZgKHHYibM7Wi13v5e07uzfZJvIKMg+M9TfFq9LFZ9ASoSG1twNXM\n",
"f1XpB8Ycf+oAPJ+5aMzxpw3EzV/5hYSj9FtqzEP4XusFZYxDUDM/GxgW8647KT3/5+PAJ3qzI9M0\n",
"IJZA1WSamsYC3086R09UMxdpbDuAF4FBMe93ArAN16iLVJ0a8xC+d6kDZYzD4wtbTqlGvlQ2dxDu\n",
"uYzIfO9SB7D+mQeOHj3N71mlfD+PUfPpBqiISANQYx7C56vJAmWMzvd84H+tF2D0tNnPJZ2hHN/P\n",
"Y9R8asxFRBqAGvMQvvePBmWMg+/5wP/+0eBq5klnKMf386g5QEVERI15mHqopSpjdL7nA/9rvaCa\n",
"eRxUMxcRETXmYeqhlqqM0fmeD/yv9YJq5nFQzVxERPQEaJh6qKUqY3RVzNcOHBDy3k7KzNZVzPda\n",
"L8DoabOfwk0n+ceks4QpzPLkqwrzhT5VrMZcpDpylP73NQY4ucZZamETcCbg/6hg9W0M8LNSb6gx\n",
"D+H7mCKgjHGoVr58Jr0d2N59fSqb27+3+/J9TBFQxjhUmG+fsDdUMxcRaQBqzEP4fDVZoIzR+Z4P\n",
"6qNmrozRqZ+5iIioMQ9TD/2PlTE63/OB//2jQRnjoH7mIiKixjxMPdRSlTE63/OB/7VeUMY4aA5Q\n",
"kfozCBiXdIgq2AW8l3SI/kqNeQjf+0eDMsYhgXxtwJ9784EXf7RwxlEXXvdQlfLEYtWtV82aeP4i\n",
"r9uTBulnHsrrky/SaPKZ9E7g3d58xix8YmM+k+7VZ2pt8Dc/8zdgdNI5+jPVzEP4fDVZoIzR+Z4P\n",
"6iPjtCt+tTTpDOX4fFUO6mcuIiKoMQ9VD/2PlTE63/NBfWR85pufmZV0hnLUz1xERLynxjxEPdQp\n",
"lTE63/NBfWRUzTw61cxFRESNeZh6qFMqY3S+54P6yKiaeXRR86mfuYjEpYnwqfISN3D/USOo/3yj\n",
"Qj8fb5zGUQ91SmWMzvd8UB8Zp13xqyXARDyeNm7M9DnPJp2hJxXm0xygIlI9+Uy6E3gx6Rz9QWtr\n",
"a8n1ZWvmxpgWY8wyY8xSY0w6rm19Vw91SmWMzvd8oIxx8T1j1Hw9XpkbYwxwDdCCu7y/BzfreKRt\n",
"RUQkXuWuzCcBK6217dbabcAqY8zEGLb1Xj3UKZUxOt/zgTLGxfeMUfOVq5mPATYZY27AXW1vCtat\n",
"iritiIjEqNyVeRswErg8eI0K1kXd1nu+19dAGePgez5Qxrj4njFqPmOt7WnnTcBS4FRcw/9na21z\n",
"1G0BWltbww8sIiKhWlpa9uqi2GNjDmCMOQ24CrDANdbae4P1C4At1tq7y20rIiLVVbYxFxER/2ls\n",
"FhGRBqDGXESkAagxFxFpADVvzH185N8Y81NjzMPGmJwx5vxg3alJ5zTGNBtjHjPGXFe0ruT5S+q8\n",
"hmTc63wmldEY80NjzH3GmPuNMRN6ypHgOSyV0ZtzGBz334Is9/p4HkPyeXUOi44/2Biz2hhzSbBc\n",
"sq3pdU5rbc1euIeJ/gIMBfYBltby+D3kugX4gG85cUMjnANc11OuJPN2z1jqfCadMTj+XOAmH89h\n",
"94zB9z/17RwGGU4BfujreSzk8/wcfgX4HXBJnOex1lfmvj7yb9jzfyle5LTWtgIbKsiVWN4SGWHv\n",
"80mSGQObgR095Eg6X3HGAt/OIcCJwAs9ZEk6YyFfgVfn0BizD/BR4K4yeXqds9ZD4Pr6yP9m4JfG\n",
"mDbgf+FvzrBcTSHrk8pbfD4vs9a+TPLn9IvA93rI4cM5LGQED8+hMeYB4GCgGTgyJEti57FbPvDw\n",
"HOKuym8ExgXLsf081roxLzzyfzEu4M148Mi/tfYrAMaY6UAWWIiHOQk/f00h6xPR7XxeD8wnwb97\n",
"Y8yZuKucF4wxR4XkSPQcFmcE/85hkGm2MSYF3Ar8S0iWxM5jt3yn+3YOjTHDgZnW2n83xnw+OH5s\n",
"/6Zr3Zivwv33AVzAidbapK92i7UDHcDL+JWz8OhuyfNn3FAKSectNQNK4XxCQn/3xpjjgTnW2q/3\n",
"lCPJc1giY7HEz2E3a3FPeJf8N+LBz2IhXzFfzmEzMMQY80vgCNysTMtK5enTeUyg+H8a8GDwhzit\n",
"1scPyfQr4AHgj8DhvuQE/hW4H3ge+H/Buo+WypVU3pCMe53PpDICrwRZ7gO+5+k5LJXRm3MYHPfX\n",
"QGuQ58iesiT091wqn1fnsFve84FL4vx51OP8IiINQA8NiYg0ADXmIiINQI25iEgDUGMuItIA1JiL\n",
"iDQANeYiIg1AjbnUBWPMNGPMx0LeO8oYc3WMx/paMFrd5h62ifWYIlGpn7nUheDx5xOstf9Sw2P+\n",
"zVo7vFbHE4lCV+bivWDc58uB+cHYzlcG64cGV9DLjTF/6PaZ+4IxrlcZY/4hGCv85qL3jwvGub7f\n",
"GHOHMWZMhVl6OubsYDzt64Pj540xo6MeU6QSaszFe9bam4BrgTustbOstdcE69uttTNxgz6V8jLw\n",
"feCfcGOufxLAGDMIN+b6edbaOcAvgOtC9tE9S7ljTgZ+ZK2dCzwbHDfSMUUqUeuBtkRq6RlgKrDC\n",
"WrvRGLNvsH4KMB74hTHG4AYy2h7TMZ+21q4Mvn8VN/JdtY8posZc+pXCDaKdwKvW2lpOGZbEMaUf\n",
"UZlF6kU7wYD+wZVtXxQ+txI3FOn83W+U3mdfj1NKpccU6RM15lIvlgCTjDEPAv8dTL/Vk1LdtCyA\n",
"tbYTOBu40BjzF2PMMuCfS2w/NLjh+k9RgvfymCJ9oq6JIiINQFfmIiINQI25iEgDUGMuItIA1JiL\n",
"iDQANeYiIg1AjbmISANQYy4i0gDUmIuINID/D/gAL5UofpYxAAAAAElFTkSuQmCC\n"
],
"text/plain": [
"<matplotlib.figure.Figure at 0x10b8b1940>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"km = KaplanMeierFitter()\n",
"km.fit(obs_t, event_observed=died)\n",
"ax = km.plot()"
]
},
{
"cell_type": "code",
"execution_count": 33,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"mrsa_ind = flu_complete.mrsa.astype(bool).values"
]
},
{
"cell_type": "code",
"execution_count": 34,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"<matplotlib.axes._subplots.AxesSubplot at 0x10b8d1ba8>"
]
},
"execution_count": 34,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": [
"iVBORw0KGgoAAAANSUhEUgAAAXMAAAEQCAYAAABC2pRmAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\n",
"AAALEgAACxIB0t1+/AAAIABJREFUeJzt3XuYXHWd7/v3d6269b07ITdu4RIgBiIZtOUWMBdxRBEH\n",
"FRXnGXU7MzqgzoiYGQfP3ipn43ZsRzejx7jPOcwc5nm2XBxGRUYikI4kKELwRhwkknAJAXLr+6Wu\n",
"a/3OH1UVOp2qrqqu1b1+1f19PU896Vq1aq1PryTfXv2t3/otMcaglFKqsTlhB1BKKVU/LeZKKTUH\n",
"aDFXSqk5QIu5UkrNAVrMlVJqDtBirpRSc0DFYi4ia0XkCRH5ahXrbhSRHSKyXUQ2BBNRKaVUJZEq\n",
"1okDXwYumWolERHgFmAjIMBPgN56AyqllKqs4pm5MWYrMFDFts4CdhtjUsaYJLBHRFbUG1AppVRl\n",
"1ZyZV2shMCQiXyd/Zj5UWLYnwH0opZQqIchi3gd0AteTL+abC8uUUkrNsFqKuVR4fQ/5Vktx3RXG\n",
"mLJn5Vu3btVJYZRSaho2btx4XD2uWMxF5O+AK4ElItJujPl4Yfm1wJgx5scAxhhfRL4EPAwY4EvT\n",
"CaSUUqq8cifC1XwA+g/GmHXGmNcVC3lh+feKhXzCsoeMMWuNMZcZYx6qtO1Pf+qe91YTPgwisi7s\n",
"DJVoxvrZng80Y1Bsz1hvvlAvGhqKR94Q5v6VUmquCLWY9zXHV3b39LaFmaEcY8xPw85QiWasn+35\n",
"QDMGxfaM9eYLtZi/2tb0Jxfu77s6zAxKKTUXBDk0cVqGY5GVYWcoRUTW2f6TXDPWz/Z8MHsZt27d\n",
"6rS3t38jHo+vFpGaTvQGBwc7Ozs7B2cqWxBszzg4ONjZ0dExkMvlxlOp1DcuueSSh2t5f+jFfLAp\n",
"tmbTJ+66uuf/+sB9YWdRaj5rb2//xsqVK/+qra0tFnaW+cwYw8svv9y9c+fO27q7u2+t9n2htlkc\n",
"3+8fikcXDcej54aZoxTbz9ZAMwbB9nwwexnj8fhqLeThExFOPvnkRfF4vKbJCkMt5q5hOOM6J6Zd\n",
"Z0GYOZRSUGtrRc0sEXFrWT/Uv7zL9x0+Kec6p4xH3EXdPb1WFXTbx6SCZgyC7fmgMTKq8IV9Zh4F\n",
"eLUtcTmgv94ppULnOA7f+MY3AHjyySdxHIft27cD8KUvfYkzzjiDyy+/nDe+8Y3ceOONx7z3Rz/6\n",
"EZdccgmXXXYZa9euJZlMHvP67bffjuu6vPLKK8HnDnyLNWrJ5HakIu6pQEvYWSbSXmowbM9oez5o\n",
"jIxzSVNTEw8++CAAd9xxBytWHDuT9yc/+Um2b9/Ok08+ye9//3u2bNkCQDqd5uMf/zj3338/O3bs\n",
"4NFHH6WpqemY995zzz28733v45577gk8d+jFvCOVeQoR96wjw9d//vo73xZ2HqWUXdavX89tt93G\n",
"1VdfzcqVK/nmN78JQDKZ5GMf+xiXXHIJF1544dHlAI888ghXXHEFn/3sZ1m/fj3d3d309/dXtT/H\n",
"cfijP/ojHn/8cfbu3cvKlceOnjYmPzXKwMAAfX19nHLKKQD4vo8xpux++vr6OHjwIF/5ylfmXjE3\n",
"MLrqyMifAxxuSZyeFVkUZp6JGqFPqRnrZ3s+aIyMM23//v3cd999bNmyha9+NX8Hy1tvvZXOzk5+\n",
"/vOf88gjj/Dd736Xbdu2HX3P7t27+cu//Eu2bdvGueeeyw9+8IOq9iUifPjDH+YjH/kI73znO48W\n",
"76LNmzdzwQUXsH79enp6ejj33PxgvKamJm6//Xauuuoqrr/+el544YVj3nfvvfdy7bXXsnz5chzH\n",
"4aWXXqrjiBwv1HHmOUeuifrmoYjn7/eF1vGo2xlmHqVUed09wdwFcuem2m8PfN111wFw2mmnMTQ0\n",
"BMCWLVu4++67AUgkEnz0ox/lgQceYP369QCsWbOGc845B4DTTz+dwcHXrhe6++67+da3vgXki3dv\n",
"by+RyGvl8JxzzuHv//7vede73sWPf3zMfILccMMNvPvd7+bSSy/lvPPOO+a1t7/97Vx55ZXceeed\n",
"bNiwgfvvv59Vq1YB+RZLf38/999/P4cOHeKee+7hpptuqvlYlBNqMY/6Jlf4UrKu05lxHWvmaWmE\n",
"PqVmrJ/t+cCejNMpwjNt4lmzMYb8rYgre//738/73//+Kdf50Ic+VPa10047jb/4i7/gpptu4o47\n",
"7jjmNRHhgx/8IAcOHOCuu+7illtu4dChQwwNDfGrX/0KgFdeeYVrrrkm0GIees8cQCCbdt2zPYdF\n",
"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\n",
"A/5/J2cBqyDzsp0AAAAASUVORK5CYII=\n"
],
"text/plain": [
"<matplotlib.figure.Figure at 0x10b8e49b0>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"km = KaplanMeierFitter()\n",
"km.fit(obs_t[~mrsa_ind], event_observed=died[~mrsa_ind], label='non-MRSA')\n",
"ax = km.plot()\n",
"\n",
"km.fit(obs_t[mrsa_ind], event_observed=died[mrsa_ind], label='MRSA')\n",
"km.plot(ax=ax)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Cumulative Hazard"
]
},
{
"cell_type": "code",
"execution_count": 35,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"<matplotlib.axes._subplots.AxesSubplot at 0x10ba0d748>"
]
},
"execution_count": 35,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": [
"iVBORw0KGgoAAAANSUhEUgAAAXMAAAEQCAYAAABC2pRmAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\n",
"AAALEgAACxIB0t1+/AAAIABJREFUeJzt3XucHXV9//HXZxPYBEjIhVsEoZEAgRII4AEh2Vx2uRZa\n",
"wBa0atMfUJBbafnpotXWArVeWJQfrdeq8Pup8OCiRPwprSR7gBCJsAhCEEgNJZAGDbq5GEISkuyn\n",
"f8zZZLOcOZedOed8Z8/7+XjsA2bOnJl3JrufnXzOd75j7o6IiGRbS6MDiIhIcirmIiLDgIq5iMgw\n",
"oGIuIjIMqJiLiAwDKuYiIsNA2WJuZp82s7yZLTCzyWW2vd3MlhS2n5deTBERKcUqHWduZjOAee7+\n",
"4RLb3Ab8o7uvTCmfiIhUoJo2y0nAC2W2sSr3KSIiKRhZyUZm9ggwCZhZZtMNwJ1m1gtc6+4vJcwn\n",
"IiIVqKbNkgP+yd3PrGDb6UTtlvMT5hMRkQpUdGVesBqodCKXzcDWUht0d3drUhgRkSHo6OiwwevK\n",
"FnMzuxvYB9gEXD1g/QXARnd/YMC6u4jaMRuAq4YSSERE4sVdCJf9sNLd3+fuHe5+zsAeuLvfO7CQ\n",
"F9a9391nF7Z9JXnsxjGzOY3OUI4yJhd6PlDGNISeD5Jn1MgTEZFhQMU8hrs/3OgM5ShjcqHnA2VM\n",
"Q+j5IHlGFXMRkWGgmtEsTcXM5oT+21wZkws9HxTP2N3d3TJ27NhbWltbp5lZwy/K1q1bN27cuHHr\n",
"Gp0jTuj5IMq49957r922bdubmzdvvuWUU05ZWM37VcxFMmjs2LG3TJ069fIxY8bs3ugski53Z9Wq\n",
"Vbmenp5bc7ncP1f6vob/Rg9V6FdroIxpCD0fFM/Y2to6TYV8eDIzDjrooH1bW1vbq3mfirlIBoXQ\n",
"WpHaMrMR1Wyvb4gYzTAutR5Czxh6PshGRmk8FXMRSc3kyZP5yle+smN52rRpvPrqqzuWDznkED78\n",
"4dhZtFO3fv16vvrVr8a+vn37di655BK2b99et2PWiop5jKz2UkMTesbQ80E2Mg5066230tfXB0T9\n",
"335LlizhqKOOIp/P73i91tauXbvLL5fBRowYwbe+9S1GjKiqo5HomLWiYi4iqWpra+O73/0uEI3M\n",
"6HfPPfdw8cUX09bWxsKFlY+6e+qpp2hvb2fOnDm8973vpbe3d8drK1as4IwzzmDWrFnMnDmT73//\n",
"+zteW7JkCRdeeCErVqxg1qxZnH/+rpO4XnrppbS1tTFmzJhd1t9www1ceuml5HI5PvOZz3D55Zdz\n",
"zDHH7PgFtHTpUs4//3zmzp3L1KlT+cEPflDxMe+44w5mzJhBW1sbH/nIRyo+BxVx94Z8LVy40Bt1\n",
"7Eq+gDmNzqCMyheX8dlnn33YAzR58mR/7rnn/LjjjvO+vj4/+uij/ZVXXnF396lTp/rmzZv9wQcf\n",
"9Isvvrii/b311lt+7LHH+muvvebu7t/73vd2ee+1117rt9xyS+z7V6xY4dOmTSt5jDFjxuyyfP31\n",
"1/u8efP8mWee8QkTJviaNWt8+vTp/sILL7i7+xtvvOFbtmxxd/enn37aDz/88IqO+ctf/tJnz57t\n",
"W7dudXf3q6++2r/zne/E5ir8Hb/t+yGudmqcucgwlOvKp7Kfns6qRscBMGnSJE488UTuu+++HW2W\n",
"xYsXs2bNGubOncv27dtZuXIl27dvL9veePHFF3n11Vf54Ac/uKNotba27nj9ggsu4Morr2TFihWc\n",
"d955zJkzp+q8xRx77LHsvffeHHjggYwfP55x48bx5ptvArDnnnuycuVKHn/8cV599VV+85vfVLTP\n",
"7u5uVq5cyemnn467s2nTJiZMmJBKXtBNQ7E8A31KZUwu9HwwtIxDKcJp8OhfEnR2dvKBD3xgx/q7\n",
"776bf/u3f+Pcc88F4PLLL+fBBx/krLPOKrm/kSNHMnnyZPL54r+cTj75ZH7+85/z2GOPccstt3Df\n",
"fffxL//yLyn9aYq77bbb+Pa3v80VV1zBrFmzdvyZyxk5ciTnnXceX/jCF2qSSz1zEUndoYceyuTJ\n",
"k1m2bBnbt2/nRz/6EaeddtqO188++2zuuuuusvs54ogj2LJlC/Pnz9+xbmDx7Ovro6WlhZkzZ9LZ\n",
"2cnjjz++y/tHjRpFb2/vjn53scJbaTHud//99/PJT36S973vffzqV7962/vjjnnmmWdy77338tJL\n",
"O5+mWe2xS1Exj5GFsb3KmFzo+SAbGfsNHL3y8Y9/nG3btrFo0SKmTp3KHnvsseO1U089lQULFrB1\n",
"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\n"
],
"text/plain": [
"<matplotlib.figure.Figure at 0x10b932b70>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"from lifelines import NelsonAalenFitter\n",
"na = NelsonAalenFitter()\n",
"\n",
"na.fit(obs_t, event_observed=died)\n",
"na.plot()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Unique failure times"
]
},
{
"cell_type": "code",
"execution_count": 36,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"array([ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12,\n",
" 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25,\n",
" 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38,\n",
" 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 50, 53, 54,\n",
" 55, 59, 61, 62, 63, 67, 68, 73, 77, 108, 121, 125, 126,\n",
" 133, 142, 150, 201, 227, 235, 301])"
]
},
"execution_count": 36,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"times = np.unique((flu_complete.time_to_event[flu_complete.fate=='Died'].values/24).astype(int))\n",
"times"
]
},
{
"cell_type": "code",
"execution_count": 37,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"N_obs = len(obs_t)\n",
"T = len(times) - 1"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Calculate risk set"
]
},
{
"cell_type": "code",
"execution_count": 38,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"array([[1, 1, 1, ..., 0, 0, 0],\n",
" [1, 1, 1, ..., 0, 0, 0],\n",
" [1, 1, 1, ..., 0, 0, 0],\n",
" ..., \n",
" [1, 0, 0, ..., 0, 0, 0],\n",
" [1, 1, 1, ..., 0, 0, 0],\n",
" [1, 1, 1, ..., 0, 0, 0]])"
]
},
"execution_count": 38,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"Y = np.array([[int(obs >= t) for t in times] for obs in obs_t])\n",
"Y"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Counting process. Jump = 1 if $\\text{obs}_t \\in [ t_j, t_{j+1} )$"
]
},
{
"cell_type": "code",
"execution_count": 39,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"dN = np.array([[Y[i,j]*(times[j+1] >= obs_t[i])*died[i] for i in range(N_obs)] for j in range(T)])"
]
},
{
"cell_type": "code",
"execution_count": 40,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"array([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0,\n",
" 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n",
" 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n",
" 0, 0])"
]
},
"execution_count": 40,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"# Process for one patient\n",
"dN[:,1]"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Covariates"
]
},
{
"cell_type": "code",
"execution_count": 41,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"standardize = lambda x: (x - x[np.isnan(x)-True].mean()) / x[np.isnan(x)-True].std()"
]
},
{
"cell_type": "code",
"execution_count": 42,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"analysis_covariates = ['male', 'AgeYears', 'non_white', 'HoursECMO', 'pH', 'PCO2', 'PO2', 'mrsa', 'any_coinf', 'VA']"
]
},
{
"cell_type": "code",
"execution_count": 43,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"male 0\n",
"AgeYears 0\n",
"non_white 0\n",
"HoursECMO 0\n",
"pH 0\n",
"PCO2 0\n",
"PO2 0\n",
"mrsa 0\n",
"any_coinf 0\n",
"VA 0\n",
"dtype: int64"
]
},
"execution_count": 43,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"flu_complete[analysis_covariates].isnull().sum()"
]
},
{
"cell_type": "code",
"execution_count": 44,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"male, AgeYears, non_white, HoursECMO, pH, PCO2, PO2, mrsa, any_coinf, VA= \\\n",
" flu_complete[analysis_covariates].values.T\n",
"\n",
"\n",
"HoursECMO_std = standardize(HoursECMO)\n",
"AgeYears_std = standardize(AgeYears)\n",
"pH_std = standardize(pH)\n",
"PCO2_std = standardize(PCO2)\n",
"PO2_std = standardize(PO2)\n",
"# HCO3_std = standardize(HCO3)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Model"
]
},
{
"cell_type": "code",
"execution_count": 45,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"import theano.tensor as tt\n",
"from pymc3 import Model, Normal, Poisson, DensityDist, T as StudentT, Uniform, Deterministic, HalfCauchy, Laplace, Exponential\n",
"from pymc3 import Bernoulli, Gamma, MvNormal, BinaryMetropolis\n",
"from pymc3.distributions.timeseries import GaussianRandomWalk\n",
"from pymc3 import sample, NUTS, Slice, Metropolis, forestplot, find_MAP"
]
},
{
"cell_type": "code",
"execution_count": 46,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"n_kernels = 5\n",
"kernels = np.linspace(AgeYears_std.min(), AgeYears_std.max(), n_kernels)\n",
"\n",
"def rbf(s, x):\n",
" return [tt.exp( ((x - k)/ s)**2) for k in kernels]"
]
},
{
"cell_type": "code",
"execution_count": 54,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"with Model() as model:\n",
" \n",
" sigma = Uniform('sigma', 0, 100)\n",
" \n",
" alpha_sd = Uniform('alpha_sd', 0, 100)\n",
"\n",
" alpha = GaussianRandomWalk('alpha', sd=alpha_sd, shape=n_kernels)\n",
"\n",
" a = tt.dot(alpha, rbf(sigma, AgeYears_std))\n",
" \n",
" X = np.c_[[male, pH_std, PCO2_std, PO2_std, HoursECMO_std, non_white, mrsa, any_coinf]].T\n",
" \n",
" # Intercept for survival rate\n",
" beta0 = Normal('beta0', 0.0, 0.001)\n",
" # Treatment effect\n",
" beta = Normal('beta', 0, 0.001, shape=X.shape[1])\n",
"\n",
" # Survival rates\n",
" lam = tt.exp(beta0 + tt.dot(X, beta) + a)\n",
"\n",
" def exp_logp(failure, value):\n",
" # Exponential survival log-likelihood\n",
" return tt.sum(failure * tt.log(lam) - lam * value)\n",
"\n",
" surv_like = DensityDist('surv_like', exp_logp, observed=(died, obs_t))\n"
]
},
{
"cell_type": "code",
"execution_count": 55,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
" [-----------------100%-----------------] 2000 of 2000 complete in 821.2 sec"
]
}
],
"source": [
"with model:\n",
" trace = sample(2000, step=NUTS(), njobs=2)"
]
},
{
"cell_type": "code",
"execution_count": 56,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"<matplotlib.gridspec.GridSpec at 0x10dcbffd0>"
]
},
"execution_count": 56,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": [
"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\n",
"MnQtWlzdyTfA4xZ82wk135P75BbdpmZvnWhF2QxnbQRGjs2tV3fNWTbhlOQJwDOq6hVD16KVq6oq\n",
"yRFw9VR86ayVY9qOzWkPp9Gr2wuAm5JcClxbVccPVJNWuP4D3+R9fK1s03RsTnM43QqclGRVVV1Y\n",
"VftNWqnvSn4IcNmSVqdp5th60sCm9u+cJEnLl2PrSZKaYzhJkppjOEmSmmM4SZKaYzhJY5KsH7oG\n",
"aaWzt540JklVlcP/SAOy5SRJao7hJElqjuEkSWqO4SRJao7hJG3PsfWkgdlbT5LUHFtOkqTmGE6S\n",
"pOYYTpKk5hhOkqTmGE7SGMfWk4Znbz1pjGPrScOz5SRJao7hJElqjuEkSWqO4SRJao7hJG3PsfWk\n",
"gdlbT5LUHFtOkqTmGE6SpOYYTpKk5hhOkqTmGE7SGMfWk4Znbz1pjGPrScOz5SRJao7hJElqjuEk\n",
"SWqO4SRJao7hJG3PsfWkgdlbT5LUHFtOkqTmGE6SpObsPnQB0mJKEmB1P7m5vI8tTQXDSctWF0z7\n",
"nw/HrunmbPh4kiMNKKl9U9shIsmpwOHA+qq6MMkbgKcC/wK8pKpu6Nc7DTgKOK6qLh6s4N5yvZJP\n",
"mPrnUUWgG1uvqtYPXI40L8vlHDPtLacTtwROVZ0EkORpwInAS/v5Jye5c7gSf22ar+SXQ/jszOhz\n",
"TDh1fPmW8JJaNc3nmHHTHk6TPAn48ti8JT2pzHwiH5+9bi2wNivglDfEiX3kg3pwN2fDRti00w9q\n",
"QhlEmlKru2Bat2c/vQY2rQauHbKo+VhW4ZTkMuBBwAGLs/3l33pYLMO8dtX/bO6nr1oLmdXFwGi9\n",
"BpW09JZVOFXVgUmeCJwLrFn47e/aSWq+V/LaFQEeN7dH2HLS9NoMZ20ERs4xW6/OpsqyCqfezWx/\n",
"/6wJVVVJjoCrp/7LSkntWU7nmGkPp61Xt0nOB+4H3A78+WAV7UR/oEzd/d8VxrH1NLWWyzlmmsPp\n",
"VuCkJKuq6sKqOmLSSn1X8kOAy5a0Ok0tu5FLw5vav3OSJC1fjq0nSWqO4SRJao7hJElqjuEkjUmy\n",
"fugapJXODhHSmCRVVf4RrjQgW06SpOYYTpKk5hhOkqTmGE6SpOYYTtL2HFtPGpi99SRJzbHlJElq\n",
"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\n"
],
"text/plain": [
"<matplotlib.figure.Figure at 0x10ee44898>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"forestplot(trace, vars=['alpha'])"
]
},
{
"cell_type": "code",
"execution_count": 57,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"<matplotlib.gridspec.GridSpec at 0x10fae6b70>"
]
},
"execution_count": 57,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": [
"iVBORw0KGgoAAAANSUhEUgAAAagAAAEsCAYAAACWkycOAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\n",
"AAALEgAACxIB0t1+/AAAIABJREFUeJzt3XucHGWd7/HPFwLILgE1XkAuCgrqCxJUIICISAImKkdx\n",
"lQSvg3BWEM8uB+/KORAEPLqKEmATVpCL7gEi6wVxzbgQgkCABDlCIogiRAh3BJQQAgj5nT/qGVLp\n",
"9MzUJNNVz/R8369Xv2bq6eqqX3dX17efqmdqFBGYmZnlZoOmCzAzM2vHAWVmZllyQJmZWZYcUGZm\n",
"liUHlJmZZckBZWZmWXJANUDSBpL+j6Slkh6QdJ6kTVvm6ZH0pKR7JC1LP8el+yTpB6l9gaQtU/u3\n",
"JX1miLW8XNL5kh5M67hV0leG79n2u94fSDq+n/vOkvTeNu1LJU0aYJkbp9fkfkmrJHVs+5Z0eWk9\n",
"90g6Yx2Xc4Kk7w93fcNN0qXptf3bQO+Brb+0TfR99u+TdLOkDw7h8ftJWjZMtfRIumY4lrUuxjS1\n",
"4lHuGGAfYDywEjgHOA04smW+H0bE4W0ePwXYOiK2lTQDOEbSBcBk4C1DrOXnwC3ADhHxlKSxwHZD\n",
"XMawioij1vFxzwLbSno1cNfwVrXWug4srefV0eV/UBgR7wOQ1NHX1V7w44j4OICkicAVkpZExO8r\n",
"Pn64tkcN47KGzD2oZrwDuCQinoyI54FjgY9IelnLfOrn8c8BG6YewsZpeibw+bS8SiS9G9gGOCoi\n",
"ngKIiOURcWvLfOelHt8Z6VvdvZJ2Lt0vSV+SdEfq5cyWtEnLMqan++9JPYbN2tRzU/qW/rSkdsEM\n",
"MF7SVZIeknSNpB2rPt/Seg6X9DtJd0uaI+mlQ11G6yLbrGO+pM+n1+5Pku6UtF/LPDdRvPfvL/WS\n",
"X9Uyz0HpG/Q9knolbddy/6tTL25fSb9J37jPKd3/b5JOb3nMRZJOKk2/RNJ3Uu/5AUm3SHpb1eda\n",
"Ws7hkpakWu+W9Pn+5rXqImIRsBR441AeJ+n9km6U9LCkC1vuG/Q9l3QpcCqwR2n73HN9n8+QRIRv\n",
"Nd+A/wVcA4xL0xOBx4H9S/N8KLUtBX4F7NeyjH8F7gTmAp8EfroOdRwP/KTCfOcBDwH/mKbHttx/\n",
"LLAE2JJiB3YucGbp/jdS9BT3S9N7A48Cx/ezvvnA4W3al6bn++I0fSpwU5v5Xg08D2zQ5r73A/cB\n",
"O6XpE4Gfr+P7ONB65gO3AW9O018Frm4z3wnA9/tZ/m7AE8Beafpw4JY2NawCeoFXtr4/wO7Aw8CY\n",
"NL058CSwXWmeTYADAZVek1v7qWkpMKlN++vSe/zGUttmdXyeuu1W3ibS5+mjwL3ASyo+fj/gb8DX\n",
"0ns7Dnis/L5Vfc+BnnbbbV0396Ca8TVgHnC1pD8ARwHPAK/omyEiLqLYiW5PsfH8VNL2pfs/HRGv\n",
"BQ6mOGR47DrUsTWwvOK8l0TE2WndrY/5JHBSRDwYxVZ9HHBE6f5DgMsi4lfp8dcDv1iHegG+GRF/\n",
"Sb8fD+yaDrVV9UlgZkT8IU2fBLxD0lbrWM9AvhURv0m/X83QD53+d+DfI+IGgIg4F9hE0l4t8wXw\n",
"kYh4KM33wvsTEb+mCOSDUtN04NqIuKc0zzMRcXl67wD+A9hpiLX+FXgaeGdfLzAinhziMmy196fD\n",
"qU8D7wHeGhGPD+HxD0TEV9J7+yjFl6UXtr9hes87zgHVgIhYFREzImLniNiJYke0OUUvpTzfI+nn\n",
"lRQ7uIPWWhh8DvgxcJSk6yX9UNKLK5byBKVQHMRjA9y3LXCqpLvSh+o64KnSTn9Lim/ewyoiVlD0\n",
"Ml8+hIdtCxxbqvUOim/+nT7v9jeG/nnbFjikr1ZJS4GXpvZWA+28zgEOS79/HDi7fGc6RHuspKvT\n",
"CfF/BTbQEAaZpG11IkWPbn46XDu56uNtLT+JiB2AOcAW5S8UkvYqHXJbJmlBheWtsf0Nx3teh6yK\n",
"GcXeS/FN6YYB5tkozfMCSdsAHwEWAntExN4U35T+Z8X1LqQ4vvx3Q654TXcCPRGxQ7ptHxHjIuKB\n",
"dP+9wPYtj9lwHdf1wsAeFaMaXwLc0//sbWs9rqXWl0fEwnWsp5PuAma31PqKiLhkiMv5d4pe4t4U\n",
"h+Iubbn/fwAfAD4YEftShNiQRcQdEfGZiHg9Ra//stZzkTZknwZ2Kp/Pi4gbImLbiNgu/dxnHZY7\n",
"LO95pzmgGiDp7yVtkX7fAfgXivMxT5fm2a7v24ykA4EJwE9bFvVNih1B68CITanmUuB+4N8kbZ7W\n",
"NU5Su57aQL4DnCbp9aX6tyjdPwd4d98JVknTKEJ5XXxD0isljaF43Xoj4uE28/V3Mv804AQVI6P6\n",
"aq3a42y3jn4HDVT0OMXAj40kbdhyqHEWcKSkKS+ssH2tA9YQEX8FfgZcBFwQEc+1zLIt8CDwiIqB\n",
"Ot9M7RsN5YmUD0FTDN55hrW3TRuCdLj2w8CM8jY7DKq+548DO6oY3YukrYexhkE5oJqxC3CLpHuB\n",
"XwKnR8SZLfN8FrhX0p+ALwDv7DvkB5BG3GwZEXPSMh5U8bcPU4HTqSAi/kYxNH0VcEd6/DUUJ+fX\n",
"mHWQ5ZxPERYXp9FbdwGnlO6/E/gnivNo91CcxB3oHFR/6wvgQoqgfgjYgeKcUn/z/knSzS21zk+P\n",
"mZkOkdwFnD/Q82tH0uXAgtJ6Wv8OqurQ3AuBp4BlFANNDi7Vejvw34Avptd1KUWvZON1WNfZFDul\n",
"77W571SKw6T3A/8JfJciWNrtjAK4KL12L4ygTF9wLuk79ETxzX9qmzC0IYpiFN9JwIV9QbEui2mZ\n",
"rvqe/xL4f8Cdkm6n/89bR/SN4DAzM8uKe1BmZpYlB5SZmWXJAWVmZllyQJmZWZZ8sdhk3rx5Hi1i\n",
"NoJNnjx5fYf8rzPvP9Zfu/fPo/jMKpIUEdHYTtBstPEhPjMzy5IDyszMsuSAMjOzLDmgzKo7sekC\n",
"zEYTD5IwM7MsuQdlZmZZckCZmVmWHFBmZpYlB5SZmWWpKwJK0rmSlkp6d9O1WP1UmJBuHbvSg6QZ\n",
"nVq2ma2ta0bxSToe+HVEDPSfWq3LFIE0cQ4cPbVomT0XFh4aHdiwm77UUQrf8WlySSeeo9lA6t4G\n",
"s7xYrKQe4ADgzcAsin8XPoXi35MfDLwGOCciyv9me+0LDUpTgBMo/qX5tyPix52tfOSTKv+r8ky0\n",
"ltszDZjWqX5U+fWJWHub65R2QSypI0Fs1k4T22CWPagUUK8F/kIRoi8CbgZ+ERHPSdoEWBQRu5Ye\n",
"cwJwY18PKiX9b4B9gKeB+cABEfFsrU+mw0ZeoIxkYu1AXD9VQq6T73GdIWsjm6QJcP610DO2aLng\n",
"CThs34hY3Kl1ZtmDSh5MP58EtqKo9e2SDgJWAJsO8viXAdsAl1HsWbYAtgaWdqTahoz2HUzpW92U\n",
"omV273Ae4uv0F4Cmv2AMtv7Rvn1Zs3IOKJV+Rvp5ekTsImk7YPoAjyEiHpF0G/C+iFje8WqtERER\n",
"kqbDoo4cFy/voCWiqR12p4PYrIIlMKuX4nQLxTbIkk6uMOeAijY/r5W0gOJw32NtHvM1SW+IiFPT\n",
"9JeByyQFcF9EfLSjFVsj0k66Y4cZShq7Fl+ng9hsME1sg1megzIzM+uKv4MyM7Pu44AyM7MsOaDM\n",
"zCxLDigzM8uSA8qsIl+Lz6xeHsVnVlHT1+IzG23cgzIzsyw5oMzMLEsOKDMzy5IDyszMsuSAMquu\n",
"sWvxmY1GHsVnZmZZcg/KzMyy5IAyM7MsOaDMzCxLDigzM8uSA8qsIl+Lz6xeHsVnVpGvxWdWL/eg\n",
"zMwsSw4oMzPLkgPKzMyy5IAyM7MsjWm6ALNWkgSMT5NLIp+RPL4Wn1mNur4HJenGdr9bnopwmjgH\n",
"zr+2uO15cQqsxkXEjKZrMBtNun6YuaRFETGx9XfLk6QJELc0Xcdq2iCjHpyNIhkfSahN1xzik/Q7\n",
"YAHFG/rziDip767ybLUXZgOSaPnQ5fYZjFWt/bcIb0fWWauPJBw9tWiZPVfSoaMtpLomoIAXAccA\n",
"K4FrJX03Ih4CXi/pSopwemWTBdraWnf2pQ/mlKJldi8s7PeDuXbAdd5wrNMhZ4MYX4RTz9g0PRUW\n",
"jgcWN1lU3bopoP4cESsAJN0EbAc8BNweEZNS+6IG67MKIiIkTYdFaxzaaCKIOmmg5+PwMit00yCJ\n",
"V0l6iaQNgbcAf0ztPsQ3wkRhcbpF0YbquIE2gD0vgQueKG57/bA4D4VAJ9ZTgxlLYFbv6u1wdm/R\n",
"Nrp0zSAJSbcCi4CdgR9ExBmp3YMkbEj6Oznta/FZnTxIorsC6saI2KPpOqx7OaDM6tVNh/i6I2nN\n",
"zAzooh6UWae5B2VWr27qQZmZWRdxQJlV52vxmdXIh/jMzCxL7kGZmVmWHFBmZpYlB5SZmWXJAWVm\n",
"ZllyQJlVJGlG0zWYjSYexWdWkf9Q16xe7kGZmVmWHFBmZpYlB5SZmWXJAWVmZllyQJlV52vxmdXI\n",
"o/jMzCxL7kGZmVmWHFBmZpYlB5SZmWXJAWVmZllyQJlV5GvxmdUr21F8kuYDGwIbA5dExKmSJgHH\n",
"A88Bf42ID6R5pwPHAM8DZ0TED1P7WcDrAQGfiIil9T8T6xZVr8UnScD4NLkkcv2QmWUu54C6EnhP\n",
"RKyUtAD4EDAHOCAiVkgaExHPSdocmAfskx56FTAlIpaXlrU/MC0iPlXvs7BuUiWginCaOAeOnlq0\n",
"zJ4LCw91SJkN3ZimCxiAKD7vGwOrgN2AeRGxAiAinkvz7Qn0RsSzFA+4IrVdUVrWcuCZugq30UWi\n",
"FD6tOdQzDZimlliLwFdF73LuSa+/nAMKYC7F4byZwCbAI23mGQf8uTT9WGorOyItw2zYrBlMw/9Y\n",
"h9jI1a4nLck96SHKOaACmBoRKwHS+add28z3GLBzaXoc8Nu+CUkHAb+PiNs7WKt1sXKYDB4sARwH\n",
"7JKmbwVOhgpZ40DqKuOLcOoZm6anwsLxwOImixppch7FJ9b8VN8ATJK0BUDfz9Q+WdJGkjYBJgML\n",
"0zy7Ae+IiNPqK9tGIono77Z6rhOqLAk4hSKgdqFqOLXWMOQnYNaFcu9BrZ6IeErSl4CfSVoFrJR0\n",
"SEQ8IWkm8CuKc1UzSwMkLgGWpRGBiyPimDqfgI0c1XovMyouTcCE1VOrD/dMKVpm93rgRNdbArN6\n",
"gdJ7zpImCxqJsh3FZ9ZNfMJ89PF7vv4cUGZmlqWcz0GZmdko5oAyM7MsOaDMKvK1+Mzq5XNQZhVV\n",
"vRafmQ0P96DMzCxLDigzM8uSA8rMzLLkgDIzsyw5oMyqO7HpAsxGE4/iMzOzLLkHZWZmWXJAmZlZ\n",
"lhxQZmaWJQeUmZllyQFlVpGvxWdWL4/iM6vI1+Izq5d7UGZmliUHlJmZZckBZWZmWXJAmZlZlhxQ\n",
"ZtX5WnxmNfIoPjMzy9KI60FJmi/pakk3SPpsapsu6TpJ10iaVpr3rDT/VZK2b65q6xQVJqSbh4Cb\n",
"dZER14OSdCXwnohYKWkB8CHgR8A+aZargCkRsbz0mP2BaRHxqbrrHc1SYIxPk0timDe2YvkT58DR\n",
"U4uW2XNh4aHDvR6z9dHpz0E3G9N0AetAFO/5xsAqYCLQGxHPUtxxBbAncEXpMcuBZ+outExiFG6U\n",
"az7l4e/ftL6kPdOAaQOtJwL3sqw27b5ESfKXqIpGYkABzAWeA2ZSPIc/l+57DBjXMv8Rad7ajc5g\n",
"ytf6vB8ON1sH44tw6hmbpqfCwvHA4iaLGilGYkAFMDUiVgJIeiewc+n+ccBv+yYkHQT8PiJur7XK\n",
"pBt3avmEbgDHAbuk6VuBk6FDL7k0I2BGseYufF/NcjMSz0HNpzgH9VSa3hzoBfajGPQxn3QOStJu\n",
"wIci4nONFTxKlQ5tTClaZvd24vxQncf3fS0+G6q6PgfdaiQG1JXAQX0BldqmA8dQnJM6IyLmpPa7\n",
"gGWpfXFEHNNAyaNWt50cdkDZuui2z0GdRlxAmTXFAWVWrxH3d1BmZjY6OKDMzCxLDiiz6nwtPrMa\n",
"+RyUmZllyT0oMzPLkgPKzMyy5IAyM7MsOaDMzCxLDiiziiTNaLoGs9HEo/jMKvKVJMzq5R6UmZll\n",
"yQFlZmZZckCZmVmWHFBmZpYlB5RZdb4Wn1mNPIrPzMyy5B6UmZllyQFlZmZZckCZmVmWHFBmZpYl\n",
"B5RZRb4Wn1m9PIrPrCJfi8+sXgP2oCTd2O73TpM0X9Kv0s/vltonSbpK0hWSfpTaXi3peUnbSNpU\n",
"0hOS3p7umy7pOknXSJpWV/02OqkwId0cZGbracwg90c/v3daAFMjYmVfg6RNgVOAAyJihaRy7b8F\n",
"DgWWAXel+TcHPgfsk+a5StLciFhexxOw0aUIpIlz4OipRcvsuZIODR+iMFtngwWU2v0uqQc4Mk2e\n",
"FxFnp/YbI2KPNr/3AHsBb0jLmRwRz0s6GjgcWAl8v285aZ7W3t3ewLyIWAEQEc+V7vtDWvZOwLzU\n",
"tifQGxHPphquSG1XDPKczSqT+r64teZQzzRg2mD9qAjWmiP1vsanySUOOVtXI31bGiygXi/pSorA\n",
"eCWApHEU4bRvmmeepP+MiPsZuMe1JUUwrSq1fRA4MCIeb7PuX0h6Hrg+Io4DXgE8MkCti4CtgL9P\n",
"0+OAP5fufyy1mQ1ZXxCtDqThXe6aonWetkFmNpBu6NUPFlC3R8QkAEmLUtsOwK8j4vnUfgOwI3A/\n",
"DPghurwlnAA+Bhwp6aXApRGxILWvdYgPeBjYtZ9lR0R8N9XzzdT2GLBzaZ5xFIcCzYYsAknMiGBG\n",
"u/tLO4MpRcvsXlg4pJ3BQOEnEQ4pG6LxRTj1jE3TU2HheGBxk0UNxWDDzNsd4rsL2F3SmHQe6K0U\n",
"h9hemEfS37G6J9OviLgvIr4O/G/g9JZ1tdZ2AzBJ0hZpHVv0U2d5/smSNpK0CTAZWDhYTWbtFOER\n",
"J0hEuxvEKrjhEHjz5sXt+mkQq/qbv/0yBq+h6rxm3WDIgyQi4lFJZwFXp/ZzI+KB9Pui1INZQYVB\n",
"FZK+A7wJGAuc2bKuX0haBdwdEYdFxFOSvgT8LLWvlHTIAHU+IWkm8CtgFXCaB0jYuqrWexEwYb3W\n",
"Mxw9MbNkCczqBUrbEkuaLGio/HdQZpkZ6Se2LR8jfVtyQJmZWZZ8qSMzM8uSA8qsIl+Lz6xePsRn\n",
"VpGvxWdWL/egzMwsSw4oMzPLkgPKzMyy5IAyM7MsOaDMqjux6QLMRhOP4jMzsyy5B2VmZllyQJmZ\n",
"WZYcUGZmliUHlJmZZckBZVaRr8VnVi+P4jOryNfiM6uXe1BmZpYlB5SZmWXJAWVmZllyQJmZWZYc\n",
"UGbV+Vp8ZjXyKD4zM8uSe1BmZpalLANK0o0D3LeZpOPatP9jZ6syW02FCenmv40y64AsAwro97hj\n",
"RDwZEae0ueuTHazH7AVFIL2lF753HZx3Lex5sUPK2vEXmfUz4DkoSbcAlwNvA66MiK+k9h7gyDTb\n",
"eRFxdpv550XEWj2d0rI/BhARP0jTk4B9I+LEQdZ7GLBZROxRWtYFwMHATWn+k1P7FOAEYBXw7Yj4\n",
"cfWXxrqF1P8XHutfBN6hrocikCbOgaOnFi2z58LCQ8Mn/isbLKDuAXYHHgVujojxksYBlwH7ptnm\n",
"AR+OiPvbzT/AsvcCJqXHbwG8CngmIi6StAzYrb/lSFoUERMHakvfVn4D7AM8DcwHDoiIZwd7UaxZ\n",
"+QbKjHQzcIANRtIEOP9a6BlbtFzwBBy2b0QsbraykWPMIPc/GBEPA0hamdp2AH4dEc+n9huAHYH7\n",
"+5m/P3dQ9IaOBTYEbqUIPoAHhrCcPq0flpcB26RliiIEtwaWVlye1SDfMGrnRIqACuA4YJfUfitw\n",
"Mmtvgs1ygNhIN1hAqc3vdwG7S+p77FuBmQPM31ZEPCppIvBj4G6KT/i3Ky6nXdtGSlfzTMt/RNJt\n",
"wPsiYvlAtVhzRtJOtAhTbVActvnUFPjjBnDxAvjduyJOGUFBazVZArN6gSnF5Ozeos2qGiygovX3\n",
"FCxnAVen9nMj4oH+5h/Ek8B3gb8AX4iIJyoup13b5cBcSUsj4lOp7cvAZZICuC8iPlqhJrN+RURI\n",
"mg6L+g47L/E5BWvH28r68x/qmlXkf7dhVq/BelDrTdJ81uzxiOLLxaROr9vMzEaujgdUROzf6XWY\n",
"1cTX4jOrkQ/xmZlZlnK9koSZmY1yDigzM8uSA8rMzLLkgDIzsyw5oMwqkjSj6RrMRhOP4jOryH+o\n",
"a1Yv96DMzCxLDigzM8uSA8rMzLLkgDIzsyw5oMyq87X4zGrkUXxmZpYl96DMzCxLDigzM8uSA8rM\n",
"zLLkgDIzsyw5oMwq8rX4zOrlUXxmFflafGb1cg/KzMyyNKbpAsxyJUnA+DS5pMlazEYjB5RZG0U4\n",
"TZwDR08tWmbPhYXNFmU2yvgclHWERBduWIIhPq0Isjtn1dozDO8ErI0ctpMse1CSeoADgDcDs4B/\n",
"AqYA+wN7AW+g2FtMjojnJR0NHA6sBL4fEWen5XwCOBh4DXBORJyx/rV1447XqjlhyI8Y6vbS6UBr\n",
"1zOUdKhDyspy2U6y7EGlgHot8BeKEH0RcDPwEorA+UBErCrNf2Vqe7xlOWMi4jlJmwCLImLXup6D\n",
"jWylD+iUomV2LyzMbkfexBemHHuFNrwkTYDzr4WesUXLBU/AYftGxOI668iyB5U8mH4+CWzJ6lov\n",
"L4dT8jHgSEkvBS6NiAWp/e2SDgJWAJt2umDrHhERUhyyemzE9dNA0+Rdc62h6DAc3XIOKJV+DriR\n",
"RsR9wNdTT+k6YLd01+kRsYuk7YDpHavUulKEBBOaLmNYjZSeoTVuCczqpTi1QrGd1D+SNeeAitLP\n",
"aGlbg6TvAG8CxgJnlu66VtICisODj3WoTrMRo+gZajos8iAJ61cu20mW56DMzMx8JQmzinwtPrN6\n",
"uQdlVpGvxWdWL/egzMwsSw4oMzPLkgPKzMyy5IAyM7MsOaDMqjux6QLMRhOP4jMzsyy5B2VmZlly\n",
"QJmZWZYcUGZmliUHlJmZZckBZVaRr8VnVi+P4jOryNfiM6uXe1BmZpYlB5SZmWXJAWVmZllyQJmZ\n",
"WZYcUGbV+Vp8ZjXyKD4zM8uSe1BmZpYlB5SZmWVpRAaUpM0kHTeE+adI+o2kn3ayLmuWChPSzX9Q\n",
"azbCjYpzUJJmAedHxKKma7HOKAJp4hw4emrRMnsuLDw0RsMGbtalBg0oSZ8ADgZeA5wTEWek9luA\n",
"y4G3AfMi4jhJOwEnRcT0NM/VwLsiYsUAy98D+DpFb+7uiDgstfcAR6bZzouIs0vthwGbRcQepeWU\n",
"67kyIr6S2n8E7A0sA+6MiA9XemWsMan3Mz5NLhkoZCQ6EkARrNUDkzQjImZ0Yn1mQzGUz8hIViWg\n",
"xkTEc5I2ARZFxK6p/R5gd+BR4OaIGJ/a/wv4ILAt8JmIOGKQ5d9EEWIPl9rGAZcB+6amecCHI+L+\n",
"0jyLImJiabptPem+c4FvRcRtAz5Za9zaPaGesc1WVCZok4ftwsysU0bT0YIxFeZ5u6SDgBXApqX2\n",
"B/tCRdLKUvv/BQ4FXgt8b6AFS3pZeTklOwC/jojn03w3ADsC99O//uoBvAPptOHryQx9MRHF6af0\n",
"oZ1StM7uHe4PrUQ4jCwD44tweuHL21RYOB5Y3GRRnVAloE6PiF0kbQdML7Wrn98vAX5K0Tv74kAL\n",
"jog/S9pK0jYRcW/prruA3SX11fdWYGbLw1t3FP3VYx3UqUNsQ68hKG5LUuv100DThnuohEPKrD5V\n",
"AupaSQuAm4HHSu3R7veIeErSn4A/VKzhk8AP0jHVhyNiWkQ8Kuks4Oo0z7kR8UDL41p3jG3r6Wfa\n",
"hslw76zXryckYMJwltNSm8PJsrAEZvUCpc/IC9/MukpHRvFJ+g/gyIh4dNgXbl0v1xPA/n9Qlotc\n",
"PyPDrUoPqjJJ+wEnAxeXw0nSfNbsxQiIiJg0nOu37pA+bDkeT/e1+CwLGX9GhtWo+DsoMzMbeUbk\n",
"lSTMzKz7OaDMzCxLDigzM8uSA8rMzLLkgDKrSNKMpmswG008is+sIv8dlFm93IMyM7MsOaDMzCxL\n",
"DigzM8uSA8rMzLLkQRLJvHnz/EKYjWCTJ09ubACL9x/rr93754AyM7Ms+RCfmZllyQFlZmZZckCZ\n",
"mVmWHFBmZpYlB1QmJG0t6UpJV0s6NYN6Npb0J0lHN1zHWZLmS7pK0vYN1TBZ0jXpvWn0v0Dn8Hq0\n",
"ymVbyY2kt0laJOlfclqXpPMkXZ/2Nx/vUD3Dsp0O6798t/XyLeC4iLi+6UKSo4Cbmi4iIo4CkLQ/\n",
"8AXgU3WuX5KArwKTAQG/BK6ss4aypl+PfmSxrWRoE+BrwFszW1cA0yJiWaeKGa7t1D2oDEjaAHhd\n",
"LuEkaVPgncClTddSshx4poH17gj8PiKejoiVwB8lva6BOlo19XqsIdNtJQsRMQ94PMN1ifr2/Wts\n",
"p5L2k9RT9cHuQdVM0oEU3yiCYkMJ4GTgRZJ+AmwOnBkRP2mols8C7wbOBF7Z6RoGqyUilqRZjgBm\n",
"1lVPyTjgr5K+ner6a2r7YwO1lDX1erT6Z2reVmy9LQculPQocGxE3NnBdR0BzJS0K3AasAXFvq4H\n",
"OCUFa78cUDWLiMuBy8ttksYAfwE+QPGeLJDUm76x113L5sC+EfGNtBHV8tf57Wop1XQQRS/m9jpq\n",
"afEo8GKKQxQCZqe2xjT8epTraGRbsfUTEf8MIOlNFKcW3t+J9bTZTveX9HbgNRHx/SrLcEBlICKe\n",
"k7QM2Coi7pP0dIPlvA3YRNKFwA7AhpLmR8RtTRQjaTfgHRHxuSbWT9FT2rGvHIpDsY31njJ4Pcqy\n",
"2lYyVmdwD2VdTwN/60gR/W+nQ3otfKmjTEjaDjiL4hDfJRHR+OGbNMJns4iY1WANdwHLgFXA4og4\n",
"poEaDgROoDjs+NXU22tEDq9HOzlsK7mR9EXgXRSHP6+OiCPrXpekQ4AVEfGL0rwXA1tRHOr7dETc\n",
"3YF6hmU7dUCZmVmWPIrPzMyy5IAyM7MsOaDMzCxLDigzM8uSA8rMajMc16eT9AlJCyVdmy6lY13K\n",
"fwdlZnXhdxd6AAABBklEQVQajuvTHQu8CdiM4tqIew9DXZYh96DMrDbtrhknaYqk61KP6B8qLGYx\n",
"cADwXqC3A2VaJtyDMrPGpKvFfwPYh+LKBvMl/RzYj/6vzXgN0EPxBfuiJuq2ejigzKxJLwO2AS6j\n",
"CKItgK37uzajpNcCkyJiepqeL+mKiHiqxpqtJg4oM2uCACLiEUm3Ae+LiOUVHrcBRYghaSOKC/mu\n",
"6liV1igHlJnVpnzNOEmbp2vGfRm4TFIA90XER/t7fETckf6z8fUUIXdaRDR5cWXrIF+Lz8zMsuRR\n",
"fGZmliUHlJmZZckBZWZmWXJAmZlZlhxQZmaWJQeUmZllyQFlZmZZckCZmVmW/j9+62Vecma46gAA\n",
"AABJRU5ErkJggg==\n"
],
"text/plain": [
"<matplotlib.figure.Figure at 0x1100c5860>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"forestplot(trace, vars=['beta'], ylabels=['male', 'pH', 'PCO2', 'PO2', 'HoursECMO', 'non_white', 'mrsa', 'any_coinf'])"
]
},
{
"cell_type": "code",
"execution_count": 31,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"Index(['RunNo', 'AgeDays', 'HoursECMO', 'SupportType', 'PrimaryDx', 'Mode', 'Discontinuation', 'DischargedAlive', 'DischargeLocation', 'YearECLS', 'VentType', 'Rate', 'FiO2', 'PIP', 'PEEP', 'MAP', 'HandBagging', 'pH', 'PCO2', 'PO2', 'HCO3', 'SaO2', 'Venttype24', 'Rate24', 'Fio224', 'PIP24', 'PEEP24', 'MAP24', 'Handbagging24', 'SBP', 'DBP', 'MapHemo', 'SVO2', 'PCWP', 'SPAP', 'DPAP', 'MPAP', 'CI', 'Race', 'Sex', 'AdmitToTimeOnHours', 'TimeOffToExtubationDateHours', 'TimeOffToDeathDateHours', 'TimeOffToDCDateHours', 'ExtubationToDCDateHours', 'ExtubationToDeathDateHours', 'year', 'HoursVent', 'AgeYears', 'age_class', 'RunID', 'OrganismNo', 'OrganismName', 'CultureSite', 'CultureTimeIsApproximate', 'OrganismTiming', 'Type', 'has_flu', 'fate', 'flu_only', 'mrsa', 'any_coinf', 'time_to_event', 'non_white', 'male', 'OI', 'VA'], dtype='object')"
]
},
"execution_count": 31,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"flu_complete.columns"
]
},
{
"cell_type": "code",
"execution_count": 33,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"2009 338\n",
"2011 186\n",
"2010 115\n",
"2012 73\n",
"2008 31\n",
"2007 25\n",
"2003 24\n",
"2005 19\n",
"2006 17\n",
"2000 14\n",
"1998 10\n",
"1999 9\n",
"2002 8\n",
"2001 8\n",
"2004 6\n",
"1997 3\n",
"1996 2\n",
"1995 1\n",
"1994 1\n",
"1993 1\n",
"1992 1\n",
"dtype: int64"
]
},
"execution_count": 33,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"flu_complete.year.value_counts()"
]
},
{
"cell_type": "code",
"execution_count": 82,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"<matplotlib.gridspec.GridSpec at 0x125108850>"
]
},
"execution_count": 82,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": [
"iVBORw0KGgoAAAANSUhEUgAAAa0AAAEjCAYAAACB7F6fAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\n",
"AAALEgAACxIB0t1+/AAAIABJREFUeJzt3XlYVGX/P/D3GSZEQMABERU3EIQBlVBDU1QgSbCszDJL\n",
"RW17Mu2XS4RWRqaBuORalo+4pLZpj+bToxmguWspmMzkSppoRIpiuLHdvz/I+YowOMjAzC3v13Vx\n",
"XZwzZ859n5nhvM99zmcOihBCgIiISAIqS3eAiIjIVAwtIiKSBkOLiIikwdAiIiJpMLSIiEgaDC0i\n",
"IpIGQ4ukNmLECPTt29fk6crEx8fDx8en1vooI5VKhTVr1li6G2QG27Ztg0qlwrlz5yzdFbNgaEnq\n",
"ypUriIuLg7e3N5ycnNCjRw+kpKSUW2b58uVQqVQVftLS0gzL6HQ6dOnSBU2aNMHLL7+M7OzscuuY\n",
"OHEiRo8ebXK/9u3bh8ceeww+Pj5wcHCAn58fXnnlFRw/frxmG1wFRVEMvy9YsABr164t99itj5uy\n",
"jrvVpk0bTJ8+vVrPeeihhzBy5Mgat031w4gRIwx/x2q1Gs2bN8dTTz1Vq39fN61atQoqleUjw/I9\n",
"oLvy0ksvYc2aNXjnnXewY8cOhIWFISoqCjt37iy3nI2NDf7880/k5OQYfkJDQw2PT58+HYGBgdiy\n",
"ZQt+++03jB8/3vDY/v378Z///AczZ840qU8ffvghevbsiVatWiE5ORmZmZmYO3cuioqKEBcXZ/R5\n",
"xcXF1dz68m79fnyjRo3g7Oxc6WOmruNumRqQtaWmryPJoVevXsjJycGpU6ewYMEC/PTTT3jkkUcs\n",
"3a26I0g6165dE/fdd5+YPXt2ufmdO3cWUVFRhully5YJtVpd5bo8PDzEgQMHhBBCfPXVVyI4OFgI\n",
"IcSNGzdEYGCg2LJli0l90uv1wtbWVsyYMaPSx8+fPy+EEGLr1q1CURSxc+dO0a9fP9G4cWOxePFi\n",
"IYQQK1asEPfff79wdHQUPj4+Yvr06aK4uNiwjr///luMGDFCNGnSRLRv317MmjVLxMTEiIceesiw\n",
"jLHppUuXCq1WK9zc3MTw4cPF33//bVjm3XffFe3atSvX371794rw8HCh0WhEixYtxMiRI8WFCxeq\n",
"fA3atGkjpk+fbphu3bq1eP/998XkyZNFmzZtRNOmTcW4ceMM2xQTEyMURSn38+OPPwohhLh06ZJ4\n",
"5ZVXhJeXl3BychI9evQQ27dvN6y7stdx3rx5wt7eXqxZs6Zcv86ePStsbGxEamqqEEKI1atXiwce\n",
"eEA4OzsLNzc30b9/f3Hs2LFyz1EURaxevdowvWrVKjFgwADRuHFjodFoRK9evUR2dnaVrweZX0xM\n",
"jOjbt2+5efHx8UJRFHH58uVKn3Pzs7Jnzx4RFRUlXFxchFarFZs2bSq33OTJk4W/v7+wt7cXLVu2\n",
"FP/6179Efn5+uXXc+jNy5Mja2cg74EhLQkVFRSgpKYGjo2O5+Y0aNcKOHTvKzSspKYG3tzeaN2+O\n",
"sLAwfPfdd+Uef/jhh7Fu3Trk5+djw4YNeOyxxwAAU6dORUhIyB2vB930+eefw9bWttxI7Vaurq7l\n",
"pl9++WWMGTMG6enpeOSRRzBnzhy8+eabeP7557F3715MnDgRCxYswHvvvWd4zrBhw7Bz50589dVX\n",
"+Oabb5CRkYGNGzeWG91UNto5cOAANm7ciK+++gpr167F7t27MXz4cKPb8tNPPyE0NBShoaHYsmUL\n",
"Fi5cCJ1Oh4EDB5r0Wtxq7ty5yM/Px9dff424uDjMmzcPK1asAADMnz8foaGhGDx4sGEU3L17d5SU\n",
"lCAsLAy//fYbPvzwQ2zduhWdO3dG3759ceTIEaOv45NPPonHH38cn332WbllVq1ahRYtWiA8PBwA\n",
"UFhYiClTpuDgwYNYuXIlrl69iv79+6OoqKjSbThw4ACGDRuGPn36YM+ePdi+fTtiYmKq/VqQeYh/\n",
"zgqUlpbi0KFD+Prrr9G1a1c0atSoyue9/PLL6N+/P7Zs2YJ27dph8ODBuHTpkuFxe3t7LFmyBIcP\n",
"H8a0adOwefNmvPbaawCAHj16YOHChQBg+KzOmzevlrbwDiwSlVRjoaGhIiAgQOzYsUPk5+eL5ORk\n",
"oVKphEqlEpcuXRJCCLFnzx6xfPlykZ6eLtatWycGDx4sFEURX331lWE9WVlZ4l//+pfQarXijTfe\n",
"EOfPnxfp6emiTZs24sKFC2LcuHHCy8tLhIWFiePHjxvtz6BBg0SnTp3u2O+bR2zvv/++YV5hYaFw\n",
"dHQUS5YsKbfstGnThIuLixBCiOPHjwtFUcTSpUsNj1+6dEmo1epyR56VjbQURRGnTp0yzFuyZIlQ\n",
"FEWcPHlSCFFxpBUZGSmee+65cn3ZuXOnUBRFZGRkGN22ykZagYGB5Zbp1KmTGDJkiGH6oYceqnDE\n",
"umbNGuHs7GwYnQohRGlpqWjfvr14/fXXhRCVv45CCLF582ahVqtFTk6OYV5gYKCYPHmy0X7rdDqh\n",
"KIrYtWuXYd6tI620tDRhZ2d3x5Em1b6YmBihVquFo6OjsLOzE4qiiH79+lX53tz8rMyaNcswLz09\n",
"XSiKUuWZlI8++kg0aNDAMP3ZZ58JRVHMsyE1wJGWpFatWoXmzZujd+/e0Gg0+PjjjzF27FgIIaBW\n",
"qwEA3bp1Q0xMDIKCgjBw4EB88cUXiImJKVcs0LZtW3z88cfQ6XRISkqCs7MzRo0ahYULF2Lfvn3Y\n",
"uXMndu3ahdDQULzzzjtV9klU47pQv379DL8fP34cV65cweuvv45GjRoZfqZPn47Lly/jwoUL0Ov1\n",
"AIDIyEjD85ydndGtW7c7tuXt7Y3WrVsbpm+OHm+u83bp6elYt25dub7069cPiqLgxIkTJm+joigV\n",
"rjUEBwfjzz//rPJ56enpuHLlCtq0aWNo38nJCVlZWRXav/V1BMoKO9zd3Q2VfwcPHoROpys3sszI\n",
"yMATTzwBLy8vODk5ISQkBADw+++/V9qfPn36IDAwEL6+vhgyZAiWLFmCCxcumPYikNl169YNhw4d\n",
"wvbt2zF+/Hhs377d8Fl2dHQ0fGb69+9f7nm3fhY7duwIlUpV7rP4zTffoFevXmjRogUaNWqEiRMn\n",
"oqioCDk5OXWzYSZSW7oDdHdatWqFLVu24Pr167h+/TpcXFwwbtw4NGvWDA4ODkafFxISUq667naJ\n",
"iYkICAhA//79MXr0aAwcOBAeHh546aWXEBgYiJKSEtjY2FR4nlarxaZNm1BUVIT77rvvjv1v3ry5\n",
"4feSkhIAwNq1a+Hr61th2caNGxtdjylBWZ0wBcpOu8TFxWHYsGEVHmvatGm11nX7KRuVSoXS0tIq\n",
"n1NSUgJ/f3+sX7++wmP29vblpm99HYGywpvnnnsOK1euxLhx47By5Uo88MADaN++PQDg6tWriIyM\n",
"RMeOHbF8+XI0bdoUV69eRZcuXVBYWFhpfxRFwb59+7Br1y6kpKRg8eLFiI2NRUZGRrmDAaobdnZ2\n",
"8PLygpeXF7p27YqcnByMHj0aGRkZ+OWXXwzLNWzYsNzzbv0sqlQqKIpi+Czu27cPTz31FF599VXM\n",
"nj0bjRs3RmpqKl555RWjnwtL4UhLcnZ2dnBxccGNGzfwxRdfYNCgQVUuf/DgQXh7e1f6mF6vx5Il\n",
"SzB//nwAZdfOrl+/DgC4du0a8vPzcfXq1Uqf+8wzz6C4uBhz5syp9PGqjszbt28PBwcHnDx50vDH\n",
"eOuPSqWCVqsFAGzZssXwvPz8fOzbt6/K7QWArKwsnD592jD9ww8/AIBhnbcLDg5GZmZmpX2p6oDg\n",
"btja2lao+uvcuTOysrLQqFGjCu17eHjccZ3Dhw/HoUOHkJGRgc8//7zcKOvXX3/F+fPnMXXqVPTq\n",
"1Qvt27dHZmbmHYNdpVIhNDQU7733Hn766Sc0atTIcG2O6tbt12zj4+Oh1+vx5ZdflvusNGvWzOR1\n",
"7ty5Ew0bNsScOXPQtWtXtGvXDvv37y+3jK2tLQDzVNrWBEdakkpJScGNGzfg7++PM2fOYMqUKWjQ\n",
"oAHi4+MNy8THxyMkJAQ+Pj44deoUvv76ayQnJ1e6sykpKcGoUaPw4YcfGkY2jz76KGJjYxEWFoYV\n",
"K1YgKCjI6MVef39/TJ8+HXFxcThz5gwGDx6MFi1a4MSJE1i7di3y8vKMjvBsbW3xwQcfYPLkyVAU\n",
"BRERESguLsbhw4eRkZGBxMREtGvXDgMGDEBiYiK8vLzg7u6OxMREODk53fGP6OYo9P3338eFCxeQ\n",
"lJSExx9/HF5eXpUun5iYiO7du2PChAkYNmwYGjVqhOPHj2Pt2rVYuHAh7OzsKn3e7f0w5Y+7bdu2\n",
"2Lp1KzIyMuDp6QkXFxc888wzmDdvHvr374/p06fDx8cHf/75J9LS0qDVag3FMsYEBgbi/vvvx8iR\n",
"I3H58mUMGTLE8Fjr1q3RoEEDLFy4EI6Ojvjrr7/w0UcfVVmqv2HDBvz2228IDQ2Fk5MTduzYgXPn\n",
"zqFly5Z33D4yv9s/Vzf/NpKSksq919Xh5+eHq1evYtasWXjiiSewb98+pKamllumbdu2AIDVq1ej\n",
"b9++cHR0NPtBnEksdTGNambdunXCx8dH2NnZiXbt2okXXnhBXLx4sdwy48ePF23bthUNGzYUGo1G\n",
"9OjRQ3zzzTeVrm/mzJniqaeeKjfvxo0bIiYmRjg7O4vg4GBx+PDhO/Zrz549YsCAAcLLy0vY29uL\n",
"9u3bi1dffdVQ9LB161ahUqnE2bNnKzz366+/Ft26dRPOzs6icePGolu3boZyeCHKSt5jYmKEm5ub\n",
"aNeunUhKShIjRowoV4hhbPrf//638PPzE66urhVK3uPj44WPj0+5vmRkZIj+/fsLDw8P4eDgIPz9\n",
"/cuVq1fm9kKM26eFEOKFF14QYWFhhumsrCzRq1cv4ejoKFQqlaHk/e+//xYTJ04U7du3F3Z2dqJF\n",
"ixZi4MCBhkKQql5HIYSYN2+eUBRFDBw4sMJj//vf/0RUVJRo3Lix6N27tzh06JBQq9VixYoVhmVu\n",
"LcTYvn27CA8PF02aNBF2dnbC19fX6FcbqHbd/vm+affu3UKlUonvv/++wmPGPiu3v+dz584VnTt3\n",
"Fk2bNhWDBw8WGzduFCqVSpw+fdqwzOuvvy7c3d0tWvKuCMH/XExERHLgNS0iIpIGQ4uIiKTB0CIi\n",
"ImkwtIiISBoseTfi9nJPIpJPRESExdrmPqTmKnv/WD1oxMWLFy3dBTJCo9EgLy/P0t0gK1fVnVTq\n",
"AvchNWPs/ePpQSIikgZDi4iIpMHQIiIiaTC0SDqxsbGW7gIRWQgLMYzgRVQiubEQQ24sxCAiIukx\n",
"tIiISBr3fGjpdDokJiZauhtkxYQQ0Ol00Ol0Fv8Hd0RUtXs+tIiqIoTAyJEfICrqFKKiTmHUqAQG\n",
"F5EVk+I2Trm5uUhISICfnx90Oh2CgoLQo0cPrFq1CgDw4osvorCwEMuXL0dhYSFatWqFQYMGVfjX\n",
"5NevX0dycjKOHz8OIQSGDx+O4OBgS2wS1UBiYiLi4uKqXEajqc5F+FmG3zZsGApX1+r1Jy+PF9zJ\n",
"NEII6PV6AIBWq63yP0ZT5aQILQA4d+4cXnzxRTz//POYMGECLl26hHfffRc7d+5ESkoKnn32WUyd\n",
"OhUqlQq7d+/G6tWrMWHChHLr+Oabb9CmTRuMHj0aly5dQlJSEkOrllQvNKorCUlJM2px/dVTu9tq\n",
"HMNSLjdH9WlpQQCAiIgNSE6exOCqJmlCS6PRQKvVAgC8vb0RGBgItVoNX19fbN68GYWFhVizZg1+\n",
"/fVXCCFQUlJSYR2//PILioqKsG3bNgDAlStXkJubC3d397rclHqhNneoGs2d1296kAgAbwEI/Gda\n",
"B2AaANN2JAwOMpVer0daWhAKCoYCAFJTy+YFBARYuGdykSa07O3tDb+r1WrDtFqtRlFREb7//ns0\n",
"atQICQkJyM7OxsyZMytdz/PPP28IP7IOdzNSMd/oRgEwHcDhf6aHwNTAMm8/qsZwJCojTWjdSV5e\n",
"Hvz8/AAAKSkplS7TqVMnpKSkoG3btmjYsCF+++03tG3bti67SZWo7g7ZlJGWqSqesvmMp2yoVmi1\n",
"WoSHr0daWtl0RMQhaLXRlu2UhKQJrdt3IrdOK4qCqKgoLFmyBP/973/Ro0ePCo8DwJNPPonly5dj\n",
"4sSJsLOzg7u7O95888262QCySoqiYNmyybdcHI9mYFGt4GfNPHgbJyN4CxbrZUr1IBFv4yQ3Y+8f\n",
"Q8sIfuCI5MbQkhvvPUhERNJjaBERkTQYWkREJA2GFhERSYOhRdLhXfuJ6i9WDxrByh/rpdFokJeX\n",
"Z+lukJVj9aDcWD1IRETSY2gREZE0GFpERCQNhhYREUmDoUXSiY2NtXQXiMhCWD1oBCt/iOTG6kG5\n",
"sXqQiIikx9AiIiJpMLSIiEgaDC0iIpIGQ4ukw3sPEtVf9Sa04uPjkZWVZZjOzc3FhAkTLNgj+Qgh\n",
"oNPpoNPpYMmi06SkJIu1TUSWVW9CS1EUS3dBakIIjBz5AaKiTiEq6hRGjUqwaHARUf2ktnQHzC03\n",
"NxcJCQnw9fVFZmYmvL29MWbMGEt3SxoaTVXfbZll+G3DhqFwdTW+ZF4ev6NCdDshBPR6PQBAq9Xy\n",
"YPou3HOhBQDnzp3DkCFD8MILL2DevHk4ePAgAGD+/PmwtbUFABQXF0OlurcGmlUHTt2qSV8YeHQv\n",
"unm2Ii0tCAAQEbEBycmTGFzVdE+Glr29PR544AEAQM+ePZGRkQEAeO211+Dl5QUA+Ouvv+65C/rm\n",
"2tlXHjgCwFsAAv+Z1gGYBqDiHxxDh6givV6PtLQgFBQMBQCkppbNCwgIsHDP5HJPhpYp6tP1GPOM\n",
"wBQA0wEc/md6CCoLrJq2Z0rg8d6DRPXXPRlaV69exf79+3H//fdj9+7dePDBB/H9999bulsWY46R\n",
"T8VTG59Z7NRGXFxcnbdJVFNarRbh4euRllY2HRFxCFpttGU7JaF7MrSaN2+On3/+GStWrIC3tzeC\n",
"g4MrDS2eSzadoihYtmzyLReRo/n6EVUD/4bM4567y3tubi5mzJiB2bNn12g9vEMzkdx4l3e51au7\n",
"vPPohYjo3nTPjbTMhUdJRHLjSEtu9WqkRfe2e+2rCkRkOo60jOBRkvXSaDTIy8uzdDfIynGkJTeO\n",
"tIiISHoMLSIikgZDi4iIpMHQIiIiaTC0SDq89yBR/cXqQSNY+UMkN1YPyo3Vg0REJD2GFhERSYOh\n",
"RURE0mBoERGRNBhaJB3ee5Co/mL1oBGs/LFevPcgmYLVg3Jj9SAREUmPoUVERNJQW7oDVRk8eDBa\n",
"t24NRVEQGBiIIUOGQK1Wo6CgACtXrsRvv/2GkpISNGnSBCNGjECzZs2Qm5uLpUuXIi8vDyqVCr17\n",
"90Z0dDQAYMeOHfj2228BAJ6ennjiiSfQqlUrS24iERFVg1WHVoMGDZCUlITi4mLMnDkThw4dQnBw\n",
"MBISEhAWFobRo0cDAI4dO4aLFy/C1dUV7733Hl5++WV07NgRhYWFmDlzJmxsbPDwww+jadOmeO+9\n",
"92Bvb49t27bhk08+wfTp0y28lWQKIQT0er2lu0FEFibF6UG1Wo3AwEAcOXIEOp0OarUaDz30kOFx\n",
"X19faLVa7Ny5Ey4uLujYsSMAwNbWFtHR0Vi/fr1hOXt7ewBAcHAwLly4UPcbQ9UmhMDIkR8gMjIL\n",
"kZFZaN++O1g/RDISQkCn00Gn0/EzfJeseqR105UrV3Dw4EE8+eSTOHPmDLy8vCpdLjs7G506dSo3\n",
"T6vV4vLly7h+/Trs7OwM81NSUtClS5da7TdVn0ZjrOJrluG3o0eHw9XV+Dry8li1Rdbn5sFXWloQ\n",
"ACAiYgOSkydBURQL90wuVh1ahYWFiI2NRcOGDdG1a1dotVqcOXOmxuvNzMzEjh07MG3aNDP0kipj\n",
"PHysu20GHtUWvV6PtLQgFBQMBQCkppbNCwgIsHDP5GLVoWVra4ukpKRy81q2bIm9e/dWurynpydS\n",
"U1Px9NNPG+bp9Xo4OzsbRlmnT5/Gp59+ismTJ8PBwaH2Ol/P3brzr3mACQBvAQj8Z1oHYBqAmh+h\n",
"MqSI5GLVoVWZwMBAfP7550hJSTFc1zpx4gQKCwvRs2dPrFu3DocPH0aHDh1QWFiIzZs3Y8CAAQCA\n",
"8+fPY/bs2Rg7diw8PDwsuRn1Sk2DQQiBESNuICXlFACgb98bWLbsIk+rkFS0Wi3Cw9cjLa1sOiLi\n",
"ELTaaMt2SkJWfUeMmJgYrFixosL8goICrFixAqdOnUJpaamh5N3Dw6NcybuiKOjVqxceeeQRAMDi\n",
"xYuxf/9+uLm5AQBsbGyQkJBQadv8Nrt1ubV6UKvVMrDojqzxjhj8HJvO2Ptn1aFlSQwt65WYmIi4\n",
"uDhLd4OsnDWGFpmOoVVN/MBZL957kEzB0JIb7z1IRETSY2gREZE0GFpERCQNhhYREUmDoUXSiY2N\n",
"tXQXiMhCWD1oBCt/iOTG6kG5sXqQiIikx9AiIiJpMLSIiEgaDC0iIpIGQ4ukk5iYaOkuEJGFsHrQ\n",
"CFb+WC/ee5BMwepBubF6kIiIpMfQIiIiaTC0iIhIGgwtIiKSBkOLpMN7DxLVX9JWDw4ePBitW7eG\n",
"oigIDAzEkCFDoFarcfnyZSQnJ+Ps2bMAgM6dO+Ppp5+GSqXCL7/8gjVr1qC4uBju7u4YMGAA/Pz8\n",
"Kl0/K3+I5MbqQbndc9WDDRo0QFJSEqZPn47s7GwcOnQIQggkJCSgU6dOmDlzJmbMmIG8vDysWbMG\n",
"AODk5IS4uDjMmjULjzzyCObMmWPhrbh3CSGg0+mg0+kg6XEREVkhaUPrJrVajcDAQBw5cgSZmZnI\n",
"y8tDWFgYAEClUmHAgAHYtGkTCgsL0aZNG7i4uAAA/P39UVRUhOLiYkt2/54khMDIkR8gKuoUIiOz\n",
"MGjQJJSWllq6W0QWx4O5mlNbugM1deXKFRw8eBBPPvkkzpw5gw4dOpR73NPTE05OTsjJyUGrVq0M\n",
"83ft2gVfX1+o1dK/BBal0Rg7BTPL8NvWrcPh5lb5Unl5PIVC9cPNg7m0tCAAQETEBiQnT4KiKBbu\n",
"mVyk3WMXFhYiNjYWDRs2RNeuXaHVanHmzJlKl739Q3HmzBl8+eWXeOedd+qiq1bLeODI1QcGH8lA\n",
"r9cjLS0IBQVDAQCpqWXzAgICLNwzuUgbWra2tkhKSio3z9PTE+vXry83Lzs7G/n5+fDw8AAAXLhw\n",
"AbNmzcLYsWPh7u5eZ/21Rqbs7O8uVASAtwAE/jOtAzANgLmOKOMBxDOsiOohaUOrMh06dIBGo8G2\n",
"bdvQp08flJaW4ttvv0W/fv1ga2uLK1euIDExEc899xx8fX0t3V0p3G0wlJZOwJNPjsf+/e2hUvnh\n",
"oYdizXYqRKN5D3l5/6/G6yGqS1qtFuHh65GWVjYdEXEIWm20ZTslIWlL3mNiYrBixYoK828veb//\n",
"/vvxzDPPQKVSYd26dVi/fj2aNWtmWP7tt9+Gk5NThfWwXLXmhBDQ6/UAyv5gzXXunjfMJVNYY8l7\n",
"bf1N3IuMvX/ShlZtY2hZL4YWmcIaQ4tMd899T4uIiOofhhYREUmDoUXS4b0HieovXtMyguejieTG\n",
"a1py4zUtIiKSHkOLiIikwdAiIiJpMLSIiEgaDC2STmJioqW7QEQWwupBI1j5Y714RwwyBasH5cbq\n",
"QSIikh5Di4iIpMHQIiIiaTC0iIhIGgwtkg7vPUhUf7F60AhW/hDJjdWDcmP1IBERSY+hRURE0mBo\n",
"ERGRNKQPrf3792Pw4ME4d+6cpbtCVk4IAZ1OB51OB17KJZKT9KG1a9cuBAcHY+fOnZbuCtWRu7n3\n",
"oBACI0d+gMjILERGZmHUqAQGF9U5HjjVnNTVg9evX8eECRPw3nvvYfr06fjwww8hhMDSpUuRnp6O\n",
"5s2bw9bWFqGhoejWrRuysrKwdOlSXLlyBW5ubnjttdfg5ORU6bpZ+WO9TLn3oEZz95VjeXl87+8F\n",
"1lY9ePPAKS0tCAAQEXEIycmToCiKJbpn9Yy9f+o67odZ/fTTT+jUqRPc3Nzg5OSErKwslJaW4syZ\n",
"M5g1axby8vIQGxuLXr16obi4GB999BEmTZoEV1dXfP/990hLS8Pjjz9u6c0gI6oKnpqEUk3avRMG\n",
"Hhmj1+uRlhaEgoKhAIDU1LJ5AQEBFu6ZXKQOrV27dqF///4AgG7dumHXrl1wcHBA165d0bBhQ7Ro\n",
"0QK+vr4AgHPnzuGvv/7CjBkzAAClpaVo0qSJxfpOd5aXd9GM4SQAvAUg8J9pHYBpAO7uKJfhRGQZ\n",
"0oZWQUEBdDodzpw5A6AshBRFQUREhNHnODo6Iikpqa66SGZQWThoNNUPDSEERoy4gZSUUwCAvn1v\n",
"YNmyizw1Q3VGq9UiPHw90tLKpiMiDkGrjbZspyQkbWjt3bsXvXr1wosvvmiYFx8fD39/f3z11VeI\n",
"iIjAxYsXcfz4cfTr1w/Nmzc3PC8kJAQlJSXIycmBp6enpTaB6pCiKFi+/C3o9XoAZTsQBhbVJUVR\n",
"sGzZ5Fs+g9H8DN4FaUNr165dFa5HhYSEYPfu3WjRogUmTpyI5s2bw8fHB/b29lCr1XjjjTewdOlS\n",
"fP7551Cr1ejfvz9DS0J3e+9BRVF4/YAsip/BmpO6etCY69evw87ODrm5uZg0aRLmzJkDZ2fnaq2D\n",
"1YNEcrO26kGqnnuyetCYGTNm4PLly7h+/TqGDx9e7cAiIiLrdE+OtMyBR0lEcuNIS268yzsREUmP\n",
"oUVERNJgaJF07ubeg0R0b+A1LSN4Ptp6mXLvQSJe05Ibr2kREZH0GFpERCQNhhYREUmDoUVERNJg\n",
"aJF07vbeg0QkP1YPGsHKHyK5sXpQbqweJCIi6TG0iIhIGgwtIiKSBkOLiIikwdAi6fDeg0T1F6sH\n",
"jWDlj/XivQfJFKwelNtd/efiYcOG4bPPPjNMb9u2DVlZWRg1apR5e3eL+Ph4XLp0Cba2tgAADw8P\n",
"jB8/HgCwf/9+bNiwAYWFhSgpKUFYWBgeffRRLFq0CHv37sWSJUtgZ2cHAFi+fDk2bdqEpUuXwtHR\n",
"EZcvX0bTnnRgAAAZTklEQVRycjLOnj0LAOjcuTOefvppqFT1c7AphIBerwcAaLVaKIpi4R4REd1Z\n",
"laFVWzuykpIS2NjYGG3ztddeg5eXV7n56enpWLduHSZNmgQXFxcUFhYiJSXF8LiHhwd++uknhIaG\n",
"orS0FJmZmdBoNADKdtAJCQmIjIzE66+/jtLSUixevBhr1qzB0KFDa2UbrZkQAiNHfoC0tCAAQETE\n",
"BiQnT2JwEZHVqzK0qnL+/HksXLgQubm5aNq0KV599VW4ublh0aJF6Ny5M7p16wbg/0ZrOp0Oa9eu\n",
"hYODA86ePYsPP/wQH330EU6fPo3i4mIMGjQI3bt3N9re+vXrMXz4cLi4uAAAbG1tER0dDaAs6B58\n",
"8EHs3r0boaGh0Ov18PPzQ3p6OgAgMzMTeXl5CAsLAwCoVCoMGDAAb775Jp5++mnDqO5epNEYO0Uy\n",
"y/Dbhg1D4epa9Xry8niqg6imeIaj5qoMrcLCwnK3zCkoKECXLl0AAN999x2Cg4MxYMAA/Oc//8Gy\n",
"ZcvwxhtvVHgTbp3W6/VITExE27ZtkZmZiZKSEsyYMQMAcPXqVQBlb+r8+fMNQdKxY0cMHToUZ86c\n",
"qTD6ulWzZs3w888/48qVK9i1axdCQ0ORnp4OIQTOnDmDDh06lFve09MTTk5OyMnJQatWre74QlmK\n",
"8dCpW7XRDwYh1Sc8w2EeVYaWra0tkpKSDNM3r2kBQEZGBqZOnQoACAsLw3//+987NtamTRu0bdsW\n",
"QFlonDhxAitXrkSfPn0MwWHs9KApQkJCsGvXLpw4cQIvvfSSYb6xD4UMHxZz7NgrBo4A8BaAwH+m\n",
"dQCmAaj89bC2cOG9B0lGer0eaWlBKCgouySRmlo2LyAgwMI9k8tdnx4Eyo4cgPI7//vuuw/FxcUA\n",
"gBs3bqCoqMjw2K3VIC4uLpg5cyb27NmDTz75BL169cLDDz9stK2WLVvi5MmTCAwMrPTxm6cI33zz\n",
"TfTp08fQJ0VR0KJFC6xfv77c8tnZ2cjPz4eHh0c1t9pyzDfaUQBMB3D4n+khMBZY1Wm3rsItLi6u\n",
"TtohIutz16F1//3348cff0T//v2xdetW+Pv7AwB8fX2h1+vRs2dP/PjjjygtLa30+RcvXoSDgwN6\n",
"9+4NGxsb6HS6Ktt7/PHHsWrVKsTFxcHFxQVFRUVISUlBVFQUgLIAdXNzw5AhQ9CxY8dyz+3YsSM0\n",
"Gg22bduGPn36oLS0FN9++y369esn1fUsc4ZC2amKlf+cqvgFERGHeKqCqBZptVqEh69HWlrZdETE\n",
"IWi10ZbtlITuunowOjoaixYtwqZNm+Dh4YFXX30VQFkpeUZGBsaNG4fu3bsbStBvX9/vv/+OVatW\n",
"QaVSoXHjxhgxYoThsVuvaTk5OeHtt9/G/fffj8LCQiQlJaGoqAilpaUIDw+vsO6HHnqo0vYmTZqE\n",
"5ORkfPfddwDKQveZZ56pavPvaYqiYNmyybdcFI5mYBHVIv7NmQe/XGwEvxhIJDd+uVhu/NckREQk\n",
"PYYWSYf3HiSqv3h60AgO7a0X7z1IpuDpQbnx9CAREUmPoUVERNJgaBERkTQYWkREJA2GFkmH9x4k\n",
"qr9YPWgEK3+I5MbqQbmxepCIiKTH0CIiImkwtIiISBoMLSIikgZDi6TDew8S1V+sHjSClT/Wi/ce\n",
"JFOwelBurB4kIiLpMbSIiEgaDC0iIpKG2tIdIMsQQkCv1wMAtFotFEWxcI+IiO5M2pGWTqczWkW2\n",
"ePFinD17FgDwzTff1GW3pCCEwMiRHyAq6hSiok5h1KgEyFSPw3sPEtVf0lYP6nQ6bNy4EXFxcVUu\n",
"N3z4cKxcubLa65ep8kejqfsqqbw8eV4fqp+ssXqQZzhMZ+z9q9HpwdzcXCQkJCAgIAA6nQ7+/v4Y\n",
"NWoUsrOz8fHHH6OgoABt2rTB6NGj4eDggPj4eAQEBODAgQNo0KABRowYgbZt21a67sTERDz77LNo\n",
"1aoVYmNj8cADD2DQoEH48ssv4ebmhmbNmqGoqAhz587F6dOn8cADD2DIkCEAgPj4eAwfPhx79uxB\n",
"YWEhYmNj0bJlS4wdOxbbt2/Hhg0bUFRUhA4dOuDFF1+syUsAwDKhYWnWss0MT5LFzTMcaWlBAICI\n",
"iA1ITp7E4KqmGl/TOnfuHEaNGoVRo0YhISEBx44dw//+9z889thjCAkJwbJly/D1119jxIgRUBQF\n",
"f/31Fz744APs2rULmzZtwujRoytdr5+fH3799Ve4ubnBxsYGx44dAwAcOXIEL730EvLy8qDX6zF7\n",
"9mw0adIEcXFxiIyMhKurq+FD8Nxzz+H7779HUlISACA7OxupqalITEyEjY0NFixYgOPHj8PHx6dG\n",
"r4E17ThNCxMB4C0Agf9M6wBMA1D9Px5r2nYia6bX65GWFoSCgqEAgNTUsnkBAQEW7plcahxaGo0G\n",
"HTp0AFA23NXr9Th58iQmTJgARVHQp08fLFmyxLB8aGgoVCoVAgICqrze5O/vj02bNsHd3R3BwcE4\n",
"fPgwCgsLkZubi2bNmiEvLw/t2rVD8+bNAQDt27fH0aNH8eCDDxpdZ2ZmJnJycvDWW28BAIqKiqDT\n",
"6WocWqawlpFJGQXAdACH/5kegrsJLKButovBSEQ31Ti07O3t/29lajWuX78OoGwoXNmw18HBwbBs\n",
"YWGh0fV6e3vj5MmTcHd3R8eOHfH3338jJSUF3t7eFdZ1c31FRUV37G+nTp2Mju5qkzXueIXwvO10\n",
"xSGeriCqJVqtFuHh65GWVjYdEXEIWm20ZTslIbNXD6rVanh7e2Pfvn0oKSnBtm3b7mr4q1ar4erq\n",
"ir1796J9+/bw8/PDxo0b4e/vX631qFQq3LhxAwAQGBiIQ4cOITs7GwBQUFCA8+fPV7tv9wpFUbBs\n",
"2WRs2tQGmza1kSaweO9BkpGsf2/WpsYjrdtfdEVR8NRTT+Hjjz/GqlWr0LZtW6Mjmzu9Yf7+/sjM\n",
"zMR9990HPz8/5OXlGUJLURST3vBHH30UU6ZMgaenJ8aOHYuYmBjMmjULKpUKtra2eOGFF+Dm5mbi\n",
"1t57FEWR7px6UlLSHatGiayRjH9v1kbakvfaJlPJe33DG+aSKayx5J1MxxvmEhGR9Cx+G6eMjAys\n",
"WbOm3Dx3d3dMnDjRQj0iIiJrZfHQCgoKQlBQkKW7QUREEuDpQZIO7z1IVH+xEMMIXkQlkhsLMeTG\n",
"QgwiIpIeQ4uIiKTB0CIiImkwtIiISBoMLZIO7z1IVH+xetAIVv5YL97GiUzB6kG5sXqQiIikx9Ai\n",
"IiJpMLSIiEgaDC0iIpIGQ4ukw3sPEtVfrB40gpU/RHJj9aDcWD1IRETSuydDq6SkxNJdILojIQR0\n",
"Oh10Oh14woPINBb/J5CmyM3NRUJCAvz8/KDT6RAUFIQePXpg1apVAIAXX3wRe/fuxcWLF5GdnY0m\n",
"TZrgueeewyeffGIYok+YMAEeHh6YOXMmzp8/D3t7e0RGRqJ79+6W3DSqh26G1ZQpn+Hnn3sBACIi\n",
"NiA5eRIURbFw76i2CCGg1+sBAFqtlu/1XZLimlZubi7Gjh2Ld999F76+vpgwYQJat26N1157DTt3\n",
"7kRWVhYaNWqEXbt2YerUqXBycsJXX30FNzc3hIeHo6SkBCUlJbC1tUVBQQEcHR1x9epVTJw4EUlJ\n",
"SXB0dKzQJs9H0600GsteH7kbeXn1+zNsTde0hBAYOfIDpKWV/Zf2iIhDPEi5A2PvnxQjLaDs1j1a\n",
"rRYA4O3tjcDAQKjVavj6+mLz5s3o3LkzgoOD4eTkBABo164dVq9ejcuXLyMsLAzOzs4AgN27d2Pv\n",
"3r3Iz8/HtWvX8Mcff8DHx8di23Wvqt2dfPw/P1QVGYPWFDKGsV6vR1paEAoKhgIAUlPL5gUEBFi4\n",
"Z/KRJrTs7e0Nv6vVasO0Wq1GUVERgPLJHBwcDC8vL2zfvh3vvPMOxo8fj4YNG2LLli2Ij4+Ho6Mj\n",
"YmNjDc8lmbwH+UNLAHgLQOA/0zoA0wDc+0feMoYOWQ9pQqu6cnNz4e7ujgEDBiAnJwfZ2dlwc3OD\n",
"k5MTHB0dceTIEZw+fdrS3bxn1eaOSaORd8d362kiIfzRtesWTJ36PAIC+kFRLlm6e1RLtFotwsPX\n",
"Iy2tbDoi4hC02mjLdkpS0oTW7ed+K5u+dd7u3buxY8cO2NraokWLFujevTtsbGzg5uaGcePGoWXL\n",
"lujQoUOd9J3oJkVRsGzZ5FsuyM/hdY16oOL7Hs33/S5JUYhhCSzEsF781yRkCmsqxKDq45eLiYhI\n",
"egwtkg7vPUhUf/H0oBEc2hPJjacH5cbTg0REJD2GFhERSYOhRURE0mBoERGRNBhaJJ3ExERLd4GI\n",
"LITVg0aw8sd68cvFZApWD8qN1YNERCQ9hhYREUmDoUVERNJgaBERkTQYWiQd3nuQqP5i9aARrPwh\n",
"khurB+XG6kEiIpIeQ4uIiKTB0CIiImkwtIiISBr3VGjl5eVhzpw5d1zul19+wdtvv42pU6fWQa/I\n",
"FEII6HQ66HQ63Kk2iPceJKq/6mX14KxZsxAVFYWAgACjy7Dyp+4IITBy5Af44YeOAIDIyMNITp4E\n",
"RVEqXZ73HiRTWGP1oBACer0eAKDVao1+xsn4+2e20Jo5cybOnz8Pe3t7REZGonv37hg2bBgee+wx\n",
"7N69G61bt8bzzz8PGxsbvPHGG5g3bx5sbGxw9epVxMbGYv78+VCpKg78cnJy8Mknn+DChQto2LAh\n",
"JkyYAHd3d3z22WfYt28fFEXBkCFD8OCDDyI3NxczZszA7NmzsW3bNmRkZODatWs4f/48IiIiEB0d\n",
"jbVr1+Lbb7+FRqNBly5dMHTo0Eq3h6FVMxpNbe4wFAAVP7Z5eXzP6P9YW2jdPDhLSwsCAEREHKry\n",
"4Ky+M/b+qc3VwCuvvAJHR0dcvXoVEydORIcOHVBYWAiNRoM5c+Zg8eLFOHDgAHr37g2tVouDBw+i\n",
"a9eu2L17N0JCQioNLACYP38+evfujYcffhjFxcUoLS3F6dOncfToUSQlJeHSpUuYMmUKtFpthefq\n",
"dDokJSXBzs4O48ePR2RkJAYNGgSdTodhw4bBy8vLXJtvdWo3NKyTpbaZYUmm0Ov1SEsLQkFB2YFy\n",
"amrZvKrO+FBFZgut3bt3Y+/evcjPz8e1a9fwxx9/QKVSoWfPngCAwMBA/Prrr+jduzciIiKwYcMG\n",
"dO3aFdu2bcO//vWvStd57do1nD17FhEREWWdVZd198CBA+jWrRvs7e1hb28Pb29vnDhxAq1atSr3\n",
"/I4dOxrS2tPTE6dOnUK7du3MtclWzdQdqXWEmwDwFoDAf6Z1AKahbERlfRhSRJZjltD6888/sWXL\n",
"FsTHx8PR0RGxsbEoKirCfffdB1tb27KG1GoUFRUBANq3b4+//voLOp0OpaWl8PT0rFZ7iqJUuFhf\n",
"2RDbwcHB8LuNjQ0KCwuru2n3PGvYAQshMGLEDaSknAIA9O17A8uWXazimpZ19JuoOrRaLcLD1yMt\n",
"rWw6IuIQtNpoy3ZKQmYJrYsXL8LJyQmOjo44cuQITp8+fcfn9O7dG/Pnz8egQYOMLtOwYUN4enoi\n",
"JSUFkZGRKCkpgRACnTt3xpIlSxAREYFLly7h5MmTaNeuHW7cuGGOzaE6pigKli9/y+QL1Lz3IMlI\n",
"URQsWzb5ls95NK9n3QWzhJafnx/c3Nwwbtw4tGzZEh06dABQ+ejnpp49e+KLL75Ajx49qlz32LFj\n",
"8cknn+C7776Dg4MDxo8fj1atWqF9+/aIjY2Foih4/vnn4ezsjNzcXH4IJKUoisnn9uPi4mq5N0S1\n",
"ozqfc6qcxUred+7ciYyMDIwZM8YSzd8RqweJ5GZt1YNUPbVePVgdycnJOHr0KMaNG2eJ5omISFJW\n",
"8+XipUuX4ujRo+XmRUdHo0+fPhbpD4+SiOTGkZbcav3LxfcafuCI5MbQkhv/nxbdM3jvQaL6iyMt\n",
"I3iUZL1470EyBUdacuNIi4iIpMfQIiIiaTC0iIhIGgwtIiKSBgsxjEhNTbV0F4iohm7+hwhL4D6k\n",
"5ip7/xhaREQkDZ4eJCIiaTC0iIhIGgwtIiKSBkOLiIikYZF/TSKba9euYcGCBcjNzUXTpk0xduxY\n",
"2NnZVVju+vXr+Pe//43ff/8dRUVFeOWVV+Dr61tn7QNAaWkp4uLioNFozPbPEk1p//z581i0aBHy\n",
"8/Ph5OSEPn361OgO/Xq9HitWrEBJSQkiIiIQFRVVYZk1a9bg4MGDaNCgAUaPHo0WLVrcdXvVbX/H\n",
"jh349ttvAQCenp544okn0KpVqzpr/6YTJ07g7bffxrhx4xASElKn7Z84cQIrVqzA9evX4eDggPj4\n",
"+Dprv7CwEJ9++il+//13NGzYEI888gi6du1qtvZrw0cffYT09HQ4OTlh9uzZVtGmTqdDUlISmjZt\n",
"CgAICQnBk08+adY+mHvfAEF39Nlnn4n169cLIYT4z3/+I1atWlXpcgsWLBCpqalCCCGKi4vFlStX\n",
"6rR9IYTYuHGjmDdvnkhMTDRL26a2f/HiRfHbb78JIYTIz88XL7zwgjhz5sxdtVdSUiLGjBkj/vzz\n",
"T1FUVCQmTpxYYV0HDhwQH3zwgRBCiGPHjonJkyffVVt32/7Ro0cN7+/WrVvrvP2by8XHx4uEhASx\n",
"Z8+eOm2/oKBAjBs3Tpw/f14IUfae12X733//vViyZIkQQojc3FwxZswYUVpaarY+1Aa9Xi+ysrLE\n",
"+PHjrabNzMxMs+4rKmPKvmH06NEmr4+nB03w888/o3fv3gCAPn364KeffqqwzNWrV3HkyBGEh4cD\n",
"AGxsbGBvb19n7QPAhQsXkJ6ejvDwcAgzfpPBlPZdXFzQpk0bAICTkxO8vb3v+oahJ06cgIeHB9zd\n",
"3aFWq9GjRw/8/PPPRvvk4+ODK1eu4NKlS3fV3t207+vra3h/g4ODceHCBbO0bWr7ALBp0yZ069YN\n",
"Tk5OZmvb1PZ37tyJkJAQuLq6AoBZ+2BK+/b29rh27RqKi4tRUFAAW1tbKIpitj7UBn9/fzg4OFhd\n",
"m+bcV1TGnPsGgNe0TJKfnw8XFxcAgLOzM/Lz8yssk5ubCycnJyxatAgTJkzA4sWLUVhYWGftA8CK\n",
"FSswdOhQqFTmfVtNbf+mnJwcZGdnw8fH567ay8vLM+wMgcrv6n77Mq6urma787sp7d8qJSUFXbp0\n",
"MUvbprafl5eHn3/+GZGRkQBg1h22Ke3/8ccfKCgowJQpUxAbG4sdO3bUafs9e/ZEaWkpnn/+eUyZ\n",
"MgWvvfaa2dqvTxRFwbFjxzB+/HgkJCQgOzu7Vtur6b4B4DUtg/fff7/SI/UhQ4aUmza2cygpKcHJ\n",
"kycxcOBAvPjii/j000+xZ88ew2igtts/cOAAnJyc0LZtW+h0OpPaNGf7N12/fh1z585FTEyM0etu\n",
"5lLbR4imyMzMxI4dOzBt2rQ6bXf58uV49tlnoSgKhBB1/lqUlJRAr9fjnXfewY0bNzBt2jSEhITA\n",
"1ta2TtrfvHkzbGxsDNe1EhMTsWjRIrMfsN3r2rZti48//hg2Njb48ccfMWPGDCxYsKBW2rp93/DN\n",
"N99g7969AMr+jUtsbCwAwM/PD6NGjTK6HobWP9555x2jjzk7O+PSpUtwcXHBxYsX4ezsXGEZV1dX\n",
"ODo6Go64e/TogR9//NHk0Kpp+0ePHsWBAweQnp6OoqIiXLt2DQsXLsSYMWPqpH0AKC4uxuzZsxEa\n",
"Glqji+Iajabc6bYLFy5Ao9FUe5nabB8ATp8+jU8//RSTJ08262kfU9rPysrC3LlzAQB///03MjIy\n",
"oFarzTLiM6V9V1dXBAUFGUbgXl5e0Ov1CAoKqpP29Xo9wsPD0aBBA/j4+KBx48b4448/zFqMUx80\n",
"bNjQ8Ht4eDhWr16NgoICODo6mrWdyvYNAwcOxMCBAwEAr776KpKSkkxaFw9LTNClSxds27YNAPDj\n",
"jz9WukN2cXGBh4cHjh8/jtLSUhw8eBAdO3ass/afffZZfPzxx1i0aBFef/11BAQEmBxY5mhfCIHF\n",
"ixfD09MT/fv3r1F73t7eyMnJQW5uLoqLi7F79+4KO+MuXbpg+/btAIBjx47BwcHBsAOtKVPaP3/+\n",
"PGbPno2xY8fCw8PDLO1Wp/2FCxdi0aJFWLRoEbp164YXXnjBbKcoTWm/a9eu0Ov1uHHjBgoKCnDq\n",
"1Cn4+fnVWfsdOnTAgQMHUFpaij///BMFBQUMrLtw6dIlwyj9wIEDsLW1NXtgmXPfAPDegyYxVvKd\n",
"l5eHTz75BJMmTQIAnDt3DosWLcLly5fRqlWrKkvTa6P9m/R6PTZu3Ig333yzxm2b2v6RI0fw7rvv\n",
"olWrVoZTiM8+++xdH3nr9XosX77cUPIcHR2NH374AQDQt29fAMDq1atx8OBB2NnZ4ZVXXoGnp6dZ\n",
"tteU9hcvXoz9+/fDzc0NQFnhTUJCQp21f6uPPvoInTt3NnvJ+53a37JlCzZt2oSioiI8+uijePjh\n",
"h+us/atXr+LLL7/EkSNH4OTkhKioKAQHB5ut/dowd+5c/Prrr/j777/h7OyMp59+GmFhYXXS5uXL\n",
"l+Hi4oKnnnoKJSUlAMpex82bN+OHH36ASqVC69atER0dDS8vL7P2wZR9w5gxY7Bw4UKT1sfQIiIi\n",
"afD0IBERSYOhRURE0mBoERGRNBhaREQkDYYWERFJg6FFRETSYGgREZE0GFpERCSN/w85j9572TW8\n",
"gAAAAABJRU5ErkJggg==\n"
],
"text/plain": [
"<matplotlib.figure.Figure at 0x12528d250>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"forestplot(trace, vars=['beta'], ylabels=['male', 'pH', 'PCO2', 'PO2', 'HoursECMO', 'non_white', 'mrsa', 'any_coinf'])"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Same model above, but with a Weibull hazard function"
]
},
{
"cell_type": "code",
"execution_count": 51,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"with Model() as model_weibull:\n",
" \n",
" X = np.c_[[male, pH_std, PCO2_std, PO2_std, HoursECMO_std, non_white, mrsa, any_coinf]].T\n",
" \n",
" # Intercept for survival rate\n",
" beta0 = Normal('beta0', 0.0, 0.001)\n",
" # Treatment effect\n",
" beta = Normal('beta', 0, 0.001, shape=X.shape[1])\n",
"\n",
" # Survival rates\n",
" lam = tt.exp(beta0 + tt.dot(X, beta))\n",
"\n",
" alpha = Exponential('alpha', 1)\n",
" def weibull_logp(failure, times):\n",
" # Weibull survival log-likelihood\n",
" return tt.sum(failure*(tt.log(alpha) + (alpha-1)*tt.log(times*lam) + tt.log(lam)) - (lam*times)**alpha)\n",
"\n",
" surv_like = DensityDist('surv_like', weibull_logp, observed=(died, obs_t))\n"
]
},
{
"cell_type": "code",
"execution_count": 52,
"metadata": {
"collapsed": false
},
"outputs": [
{
"ename": "PositiveDefiniteError",
"evalue": "Scaling is not positive definite. Simple check failed. Diagonal contains negatives. Check indexes [0 1 2 3 4 5 6 7 8]",
"output_type": "error",
"traceback": [
"\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
"\u001b[0;31mPositiveDefiniteError\u001b[0m Traceback (most recent call last)",
"\u001b[0;32m<ipython-input-52-4e1716b5764d>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m 1\u001b[0m \u001b[0;32mwith\u001b[0m \u001b[0mmodel_weibull\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0mtrace_weibull\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msample\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m2000\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mstep\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mNUTS\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
"\u001b[0;32m/usr/local/lib/python3.4/site-packages/pymc3/step_methods/nuts.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, vars, scaling, step_scale, is_cov, state, Emax, target_accept, gamma, k, t0, model, **kwargs)\u001b[0m\n\u001b[1;32m 67\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 68\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 69\u001b[0;31m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpotential\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mquad_potential\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mscaling\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mis_cov\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mas_cov\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mFalse\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 70\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 71\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mstate\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m/usr/local/lib/python3.4/site-packages/pymc3/step_methods/quadpotential.py\u001b[0m in \u001b[0;36mquad_potential\u001b[0;34m(C, is_cov, as_cov)\u001b[0m\n\u001b[1;32m 33\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0mQuadPotential_SparseInv\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mC\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 34\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 35\u001b[0;31m \u001b[0mpartial_check_positive_definite\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mC\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 36\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mC\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mndim\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 37\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mis_cov\u001b[0m \u001b[0;34m!=\u001b[0m \u001b[0mas_cov\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m/usr/local/lib/python3.4/site-packages/pymc3/step_methods/quadpotential.py\u001b[0m in \u001b[0;36mpartial_check_positive_definite\u001b[0;34m(C)\u001b[0m\n\u001b[1;32m 56\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 57\u001b[0m raise PositiveDefiniteError(\n\u001b[0;32m---> 58\u001b[0;31m \"Simple check failed. Diagonal contains negatives\", i)\n\u001b[0m\u001b[1;32m 59\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 60\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;31mPositiveDefiniteError\u001b[0m: Scaling is not positive definite. Simple check failed. Diagonal contains negatives. Check indexes [0 1 2 3 4 5 6 7 8]"
]
}
],
"source": [
"with model_weibull:\n",
" trace_weibull = sample(2000, step=NUTS())"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"The following incorporates a spline for the age effect."
]
},
{
"cell_type": "code",
"execution_count": 41,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"def interpolate(x0, y0, x):\n",
" \n",
" x = np.array(x)\n",
"\n",
" idx = np.searchsorted(x0, x)\n",
" dl = np.array(x - x0[idx - 1])\n",
" dr = np.array(x0[idx] - x)\n",
" d=dl+dr\n",
" wl = dr/d\n",
"\n",
" return wl*y0[idx-1] + (1-wl)*y0[idx]"
]
},
{
"cell_type": "code",
"execution_count": 37,
"metadata": {
"collapsed": false
},
"outputs": [
{
"ename": "NameError",
"evalue": "name 'interpolate' is not defined",
"output_type": "error",
"traceback": [
"\u001b[0;31m---------------------------------------------------------------------------\u001b[0m\n\u001b[0;31mNameError\u001b[0m Traceback (most recent call last)",
"\u001b[0;32m<ipython-input-37-db5cbe3c3dee>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m 9\u001b[0m \u001b[0mspline\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mNormal\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'spline'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcoeff_tau\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mshape\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mnknots\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 10\u001b[0m \u001b[0mknots\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlinspace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mAgeYears\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmin\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mAgeYears\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmax\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnknots\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 11\u001b[0;31m \u001b[0mbeta1\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mDeterministic\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'beta1'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0minterpolate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mknots\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mspline\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mAgeYears\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 12\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 13\u001b[0m \u001b[0;31m# Intercept for survival rate\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;31mNameError\u001b[0m: name 'interpolate' is not defined"
]
}
],
"source": [
"nknots = 10\n",
"\n",
"with Model() as model_spline:\n",
" \n",
" #X = np.c_[[male, non_white, mrsa, any_coinf]].T\n",
" \n",
" coeff_sd = Uniform('coeff_sd', 0, 100)\n",
" coeff_tau = coeff_sd**-2\n",
" spline = Normal('spline', 0, coeff_tau, shape=nknots)\n",
" knots = np.linspace(AgeYears.min(), AgeYears.max()+1, nknots)\n",
" beta1 = Deterministic('beta1', interpolate(knots, spline, AgeYears))\n",
" \n",
" # Intercept for survival rate\n",
" beta0 = Normal('beta0', 0.0, 0.001)\n",
" # Treatment effect\n",
" #beta = Normal('beta', 0, 0.001, shape=X.shape[1])\n",
"\n",
" # Survival rates\n",
" lam = tt.exp(beta0 + beta1)# + tt.dot(X, beta))\n",
" \n",
" def exp_logp(failure, value):\n",
" # Exponential survival log-likelihood\n",
" return tt.sum(failure * tt.log(lam) - lam * value)\n",
"\n",
" surv_like = DensityDist('surv_like', exp_logp, observed=(died, obs_t))\n"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"with model_spline:\n",
" trace_spline = sample(1000, step=NUTS())"
]
},
{
"cell_type": "code",
"execution_count": 51,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"<matplotlib.gridspec.GridSpec at 0x11bb06a90>"
]
},
"execution_count": 51,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": [
"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\n"
],
"text/plain": [
"<matplotlib.figure.Figure at 0x11bf197d0>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"forestplot(trace_spline, vars=['beta'], \n",
" ylabels=['male', 'non_white', 'mrsa', 'any_coinf'])"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": []
},
{
"cell_type": "code",
"execution_count": 59,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"<matplotlib.gridspec.GridSpec at 0x11da06210>"
]
},
"execution_count": 59,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": [
"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\n"
],
"text/plain": [
"<matplotlib.figure.Figure at 0x11d95b1d0>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"forestplot(trace_spline, vars=['spline']) "
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Log-logistic model"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"with Model() as log_logistic_model:\n",
" \n",
" sigma = Uniform('sigma', 0, 100)\n",
" \n",
" alpha_sd = Uniform('alpha_sd', 0, 100)\n",
"\n",
" alpha = GaussianRandomWalk('alpha', sd=alpha_sd, shape=n_kernels)\n",
"\n",
" a = tt.dot(alpha, rbf(sigma, AgeYears_std))\n",
" \n",
" X = np.c_[[male, pH_std, PCO2_std, PO2_std, HoursECMO_std, non_white, mrsa, any_coinf]].T\n",
" \n",
" # Intercept for survival rate\n",
" beta0 = Normal('beta0', 0.0, 0.001)\n",
" # Treatment effect\n",
" beta = Normal('beta', 0, 0.001, shape=X.shape[1])\n",
"\n",
" # Survival rates\n",
" lam = tt.exp(beta0 + tt.dot(X, beta) + a)\n",
"\n",
" def exp_logp(failure, value):\n",
" # Exponential survival log-likelihood\n",
" return tt.sum(failure * tt.log(lam) - lam * value)\n",
"\n",
" surv_like = DensityDist('surv_like', exp_logp, observed=(died, obs_t))\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Radial basis function model"
]
},
{
"cell_type": "code",
"execution_count": 40,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"(array([ 248., 106., 75., 103., 79., 64., 66., 40., 7., 4.]),\n",
" array([ 0. , 8.13123288, 16.26246575, 24.39369863,\n",
" 32.52493151, 40.65616438, 48.78739726, 56.91863014,\n",
" 65.04986301, 73.18109589, 81.31232877]),\n",
" <a list of 10 Patch objects>)"
]
},
"execution_count": 40,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": [
"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\n",
"5ehcCxculNvt1tjYmCYmJjQ2Nia/3+/oTBcvXlR+fr7mzZsnl8ulz3/+8/rzn/98yzMlfOvmRm+R\n",
"0NPTk+gxbiocDsvn80mSvF6vwuGwY7MEAgH19vYqPz/f8bkmJye1d+9eDQwMaMOGDVqyZInjM/36\n",
"17/Wo48+qtHR0dgxp2eyLEs1NTVyuVxav3691q9f7+hMgUBAHo9HR48e1XvvvaelS5dqx44djt9P\n",
"H9Xe3q7S0lJJzn7/Fi1apAcffFBVVVWaN2+eCgsLVVBQ4OhMS5Ys0UsvvaSRkRF96lOfUnd3t5Yt\n",
"W3bLMzn+Fgh3Msty7s0SIpGIamtrtWPHDi1YsOC625yYy+Vy6dChQ/rggw/005/+VH/7298cnenU\n",
"qVPyeDxaunSp/v73v9/wHCfup5qaGqWmpmp4eFg1NTXKyrr+LT4SPdPExIQuXLigb3zjG8rLy9ML\n",
"L7yg5uZmR2f6qGg0qlOnTunRRx/92G2Jnqu/v19//OMf1djYqIULF6qurk5vvPGGozNlZWVp8+bN\n",
"+slPfqL58+crNzdXLtf1GzEzmSnhoff7/QoGg7GPg8Gg/H5/ose4Ka/Xq0uXLsnn82loaEherzfh\n",
"M0SjUdXW1mrNmjUqKSm5Y+aSrj29Xblypc6fP+/oTOfOndOpU6fU3d2tq1evanR0VM8995zj91Nq\n",
"aqokyePxqKSkRD09PY7OlJaWJr/fr7y8PEnSF7/4RTU1Ncnn890RP08fPkL1eDySnP05P3/+vD77\n",
"2c9q8eLFkqT7779f77zzjuP3VVlZWWzr7aWXXlJaWtot308J36P/6FskRKNRdXR0qKioKNFj3FRR\n",
"UZFaW1slSW1tbSouLk7o+rZt69ixY8rKytKmTZvuiLmGh4d15coVSdeuwHnrrbe0dOlSR2faunWr\n",
"nn/+eTU2NmrPnj2699579Z3vfMfRmcbGxmLbSJFIRKdPn1ZOTo6jM/l8Pt111126ePGiJOn06dNa\n",
"smSJvvCFLzj6c/6hj27bSM7+nH/mM5/Ru+++q/Hxcdm2rdOnTys7O9vx++rDbZnBwUGdPHlSq1ev\n",
"vuX7yZFXxt4pb5Fw+PBhnT17VsPDw/L5fHr44YdVXFzs6KVUb7/9tp5++mnl5OTEnpJt3bpVeXl5\n",
"js31j3/8Q42NjZqcnJRt21qzZo2+8pWvOH7Z4IfOnDmjV155RXv37nV0pkAgoEOHDkm69juN1atX\n",
"66GHHnL8furt7dUvfvELRaNR3X333aqqqtLk5KTj37tIJKLdu3fryJEjse1Jp++rP/zhD2pra5Nl\n",
"WVq6dKm+9a1vKRKJODrT008/rcuXL8vtdmv79u267777bvl+4i0QAMBwvDIWAAxH6AHAcIQeAAxH\n",
"6AHAcIQeAAxH6AHAcIQeAAxH6AHAcP8HdQ4QPMwg++IAAAAASUVORK5CYII=\n"
],
"text/plain": [
"<matplotlib.figure.Figure at 0x111210610>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"plt.hist(AgeYears)"
]
},
{
"cell_type": "code",
"execution_count": 75,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"array([[ 2., 0., 0., 0.],\n",
" [ 0., 3., 0., 0.],\n",
" [ 0., 0., 4., 0.],\n",
" [ 0., 0., 0., 5.]])"
]
},
"execution_count": 75,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"np.eye(4)*[2,3,4,5]"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"gaussian_basis = lambda x, h, l: np.exp(-(np.abs(x - h) / l)**2)\n",
"\n",
"n_rbf = 20\n",
"centers = np.linspace(AgeYears.min(), AgeYears.max()+1, n_rbf)\n",
"l = 3\n",
"# Weights\n",
"w = [[gaussian_basis(x, h, l) for h in centers] for x in AgeYears]\n",
"w_pred = [[gaussian_basis(x, h, l) for h in centers] for x in np.linspace(AgeYears.min(), AgeYears.max()+1, 100)]\n",
"\n",
"with Model() as model_rbf:\n",
" \n",
" # Prior on number of basis functions\n",
" z = Bernoulli('z', 0.5, shape=n_rbf)\n",
" \n",
" # Prior for non-zero coefficients\n",
" sigma = HalfCauchy('sigma', 25)\n",
" #kappa = Gamma('kappa', 0.5, 0.5, shape=n_rbf)\n",
" #Tau = tt.diag(kappa) #* sigma**-2\n",
" \n",
" #beta = MvNormal('beta', [0]*n_rbf, Tau, shape=n_rbf)\n",
" beta = GaussianRandomWalk('beta', sd=sigma, shape=n_rbf)\n",
"\n",
"\n",
" # Intercept for survival rate\n",
" beta0 = Normal('beta0', 0.0, 0.001)\n",
"\n",
" # Hazard rates\n",
" lam = Deterministic('lam', tt.exp(beta0 + tt.dot(w, z*beta)))\n",
" lam_pred = Deterministic('lam_pred', tt.exp(beta0 + tt.dot(w_pred, z*beta)))\n",
" \n",
" def exp_logp(failure, value):\n",
" # Exponential survival log-likelihood\n",
" return tt.sum(failure * tt.log(lam) - lam * value)\n",
"\n",
" surv_like = DensityDist('surv_like', exp_logp, observed=(died, obs_t))"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"/Library/Python/2.7/site-packages/theano/scan_module/scan_perform_ext.py:85: RuntimeWarning: numpy.ndarray size changed, may indicate binary incompatibility\n",
" from scan_perform.scan_perform import *\n"
]
}
],
"source": [
"with model_rbf:\n",
" start = {'z': [1]*n_rbf, 'sigma': 10, 'beta': [0]*n_rbf, 'beta0': 0}\n",
" step1 = BinaryMetropolis(vars=[z])\n",
" step2 = NUTS(vars=[sigma, beta, beta0], scaling=start)\n",
" trace_rbf = sample(2000, step=[step1, step2], start=start)"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"from pymc import traceplot\n",
"\n",
"forestplot(trace_rbf[5000:], vars=['lam_pred'])"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"_ = traceplot(trace_rbf[5000:], vars=['sigma'])"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"from pymc import summary\n",
"summary(trace_rbf, vars=['z'])"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": []
}
],
"metadata": {
"kernelspec": {
"display_name": "Python 3",
"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.4.2"
}
},
"nbformat": 4,
"nbformat_minor": 0
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment