Skip to content

Instantly share code, notes, and snippets.

Show Gist options
  • Save alonsosilvaallende/98a7662a8de782b2ba9816a37527fc7f to your computer and use it in GitHub Desktop.
Save alonsosilvaallende/98a7662a8de782b2ba9816a37527fc7f to your computer and use it in GitHub Desktop.
Copy of Cox_PH_and_RSF-colab.ipynb
Display the source blob
Display the rendered blob
Raw
{
"nbformat": 4,
"nbformat_minor": 0,
"metadata": {
"colab": {
"provenance": [],
"include_colab_link": true
},
"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.8.2"
}
},
"cells": [
{
"cell_type": "markdown",
"metadata": {
"id": "view-in-github",
"colab_type": "text"
},
"source": [
"<a href=\"https://colab.research.google.com/gist/alonsosilvaallende/98a7662a8de782b2ba9816a37527fc7f/copy-of-cox_ph_and_rsf-colab.ipynb\" target=\"_parent\"><img src=\"https://colab.research.google.com/assets/colab-badge.svg\" alt=\"Open In Colab\"/></a>"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "UN3PoUTSb2nT"
},
"source": [
"The objective of this notebook is to compare different models to estimate the survival probability given a set of features/covariables.\n",
"\n",
">[\"Experimental Comparison of Semi-parametric, Parametric, and Machine Learning Models for Time-to-Event Analysis Through the Concordance Index,\"](https://arxiv.org/abs/2003.08820)\n",
"Camila Fernandez, Chung Shue Chen, Pierre Gaillard, Alonso Silva\n",
"\n",
"To perform this analysis we will use [scikit-learn](https://scikit-learn.org/) and [scikit-survival](https://pypi.org/project/scikit-survival/). Finally, we will use [eli5](https://eli5.readthedocs.io/en/latest/index.html) to study feature importances (computed with permutation importance)."
]
},
{
"cell_type": "code",
"source": [
"%pip install --quiet scikit-learn\n",
"%pip install --quiet scikit-survival"
],
"metadata": {
"id": "xMhD09DUq_E4"
},
"execution_count": 5,
"outputs": []
},
{
"cell_type": "code",
"metadata": {
"id": "VoQVEI5p_rga"
},
"source": [
"import numpy as np\n",
"import pandas as pd\n",
"import matplotlib.pyplot as plt"
],
"execution_count": 3,
"outputs": []
},
{
"cell_type": "markdown",
"metadata": {
"id": "SnT6e_JPb2ns"
},
"source": [
"We first download a dataset from scikit-survival."
]
},
{
"cell_type": "code",
"metadata": {
"id": "D0xxNWzI-N3j"
},
"source": [
"from sksurv.datasets import load_gbsg2\n",
"\n",
"X, y = load_gbsg2()"
],
"execution_count": 4,
"outputs": []
},
{
"cell_type": "markdown",
"metadata": {
"id": "IBTo4q_Hb2n0"
},
"source": [
"## An example: German Breast Cancer Study Group 2 (gbcsg)\n",
"\n",
"This dataset contains the following 8 features/covariables:\n",
"\n",
"- age: age (in years),\n",
"- estrec: estrogen receptor (in fmol),\n",
"- horTh: hormonal therapy (yes or no),\n",
"- menostat: menopausal status (premenopausal or postmenopausal),\n",
"- pnodes: number of positive nodes,\n",
"- progrec: progesterone receptor (in fmol),\n",
"- tgrade: tumor grade (I < II < III),\n",
"- tsize: tumor size (in mm).\n",
"\n",
"and the two outputs:\n",
"\n",
"- recurrence free time (in days),\n",
"- censoring indicator (0 - censored, 1 - event).\n",
"\n",
"The dataset has 686 samples and 8 features/covariables.\n",
"\n",
"\n",
"**References**\n",
"\n",
"M. Schumacher, G. Basert, H. Bojar, K. Huebner, M. Olschewski, W. Sauerbrei, C. Schmoor, C. Beyerle, R.L.A. Neumann and H.F. Rauschecker for the German Breast Cancer Study Group (1994), [Randomized 2 x 2 trial evaluating hormonal treatment and the duration of chemotherapy in node-positive breast cancer patients](https://www.ncbi.nlm.nih.gov/pubmed/7931478). Journal of Clinical Oncology, 12, 2086–2093."
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "kAsZ72YYb2n3"
},
"source": [
"Let's take a look at the features/covariates."
]
},
{
"cell_type": "code",
"metadata": {
"id": "_OlmlI6g-X43",
"outputId": "874a8141-c402-4be1-a2db-ada1b9a2975e",
"scrolled": true,
"colab": {
"base_uri": "https://localhost:8080/",
"height": 363
}
},
"source": [
"cols = [\"age\", \"estrec\", \"pnodes\", \"progrec\", \"tsize\"]\n",
"formatdict = {}\n",
"for col in cols: formatdict[col] = \"{:,.0f}\"\n",
"X.head(10).style.hide(axis=\"index\").format(formatdict)"
],
"execution_count": 6,
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
"<pandas.io.formats.style.Styler at 0x7a30d7a54af0>"
],
"text/html": [
"<style type=\"text/css\">\n",
"</style>\n",
"<table id=\"T_f9879\" class=\"dataframe\">\n",
" <thead>\n",
" <tr>\n",
" <th id=\"T_f9879_level0_col0\" class=\"col_heading level0 col0\" >age</th>\n",
" <th id=\"T_f9879_level0_col1\" class=\"col_heading level0 col1\" >estrec</th>\n",
" <th id=\"T_f9879_level0_col2\" class=\"col_heading level0 col2\" >horTh</th>\n",
" <th id=\"T_f9879_level0_col3\" class=\"col_heading level0 col3\" >menostat</th>\n",
" <th id=\"T_f9879_level0_col4\" class=\"col_heading level0 col4\" >pnodes</th>\n",
" <th id=\"T_f9879_level0_col5\" class=\"col_heading level0 col5\" >progrec</th>\n",
" <th id=\"T_f9879_level0_col6\" class=\"col_heading level0 col6\" >tgrade</th>\n",
" <th id=\"T_f9879_level0_col7\" class=\"col_heading level0 col7\" >tsize</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <td id=\"T_f9879_row0_col0\" class=\"data row0 col0\" >70</td>\n",
" <td id=\"T_f9879_row0_col1\" class=\"data row0 col1\" >66</td>\n",
" <td id=\"T_f9879_row0_col2\" class=\"data row0 col2\" >no</td>\n",
" <td id=\"T_f9879_row0_col3\" class=\"data row0 col3\" >Post</td>\n",
" <td id=\"T_f9879_row0_col4\" class=\"data row0 col4\" >3</td>\n",
" <td id=\"T_f9879_row0_col5\" class=\"data row0 col5\" >48</td>\n",
" <td id=\"T_f9879_row0_col6\" class=\"data row0 col6\" >II</td>\n",
" <td id=\"T_f9879_row0_col7\" class=\"data row0 col7\" >21</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_f9879_row1_col0\" class=\"data row1 col0\" >56</td>\n",
" <td id=\"T_f9879_row1_col1\" class=\"data row1 col1\" >77</td>\n",
" <td id=\"T_f9879_row1_col2\" class=\"data row1 col2\" >yes</td>\n",
" <td id=\"T_f9879_row1_col3\" class=\"data row1 col3\" >Post</td>\n",
" <td id=\"T_f9879_row1_col4\" class=\"data row1 col4\" >7</td>\n",
" <td id=\"T_f9879_row1_col5\" class=\"data row1 col5\" >61</td>\n",
" <td id=\"T_f9879_row1_col6\" class=\"data row1 col6\" >II</td>\n",
" <td id=\"T_f9879_row1_col7\" class=\"data row1 col7\" >12</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_f9879_row2_col0\" class=\"data row2 col0\" >58</td>\n",
" <td id=\"T_f9879_row2_col1\" class=\"data row2 col1\" >271</td>\n",
" <td id=\"T_f9879_row2_col2\" class=\"data row2 col2\" >yes</td>\n",
" <td id=\"T_f9879_row2_col3\" class=\"data row2 col3\" >Post</td>\n",
" <td id=\"T_f9879_row2_col4\" class=\"data row2 col4\" >9</td>\n",
" <td id=\"T_f9879_row2_col5\" class=\"data row2 col5\" >52</td>\n",
" <td id=\"T_f9879_row2_col6\" class=\"data row2 col6\" >II</td>\n",
" <td id=\"T_f9879_row2_col7\" class=\"data row2 col7\" >35</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_f9879_row3_col0\" class=\"data row3 col0\" >59</td>\n",
" <td id=\"T_f9879_row3_col1\" class=\"data row3 col1\" >29</td>\n",
" <td id=\"T_f9879_row3_col2\" class=\"data row3 col2\" >yes</td>\n",
" <td id=\"T_f9879_row3_col3\" class=\"data row3 col3\" >Post</td>\n",
" <td id=\"T_f9879_row3_col4\" class=\"data row3 col4\" >4</td>\n",
" <td id=\"T_f9879_row3_col5\" class=\"data row3 col5\" >60</td>\n",
" <td id=\"T_f9879_row3_col6\" class=\"data row3 col6\" >II</td>\n",
" <td id=\"T_f9879_row3_col7\" class=\"data row3 col7\" >17</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_f9879_row4_col0\" class=\"data row4 col0\" >73</td>\n",
" <td id=\"T_f9879_row4_col1\" class=\"data row4 col1\" >65</td>\n",
" <td id=\"T_f9879_row4_col2\" class=\"data row4 col2\" >no</td>\n",
" <td id=\"T_f9879_row4_col3\" class=\"data row4 col3\" >Post</td>\n",
" <td id=\"T_f9879_row4_col4\" class=\"data row4 col4\" >1</td>\n",
" <td id=\"T_f9879_row4_col5\" class=\"data row4 col5\" >26</td>\n",
" <td id=\"T_f9879_row4_col6\" class=\"data row4 col6\" >II</td>\n",
" <td id=\"T_f9879_row4_col7\" class=\"data row4 col7\" >35</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_f9879_row5_col0\" class=\"data row5 col0\" >32</td>\n",
" <td id=\"T_f9879_row5_col1\" class=\"data row5 col1\" >13</td>\n",
" <td id=\"T_f9879_row5_col2\" class=\"data row5 col2\" >no</td>\n",
" <td id=\"T_f9879_row5_col3\" class=\"data row5 col3\" >Pre</td>\n",
" <td id=\"T_f9879_row5_col4\" class=\"data row5 col4\" >24</td>\n",
" <td id=\"T_f9879_row5_col5\" class=\"data row5 col5\" >0</td>\n",
" <td id=\"T_f9879_row5_col6\" class=\"data row5 col6\" >III</td>\n",
" <td id=\"T_f9879_row5_col7\" class=\"data row5 col7\" >57</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_f9879_row6_col0\" class=\"data row6 col0\" >59</td>\n",
" <td id=\"T_f9879_row6_col1\" class=\"data row6 col1\" >0</td>\n",
" <td id=\"T_f9879_row6_col2\" class=\"data row6 col2\" >yes</td>\n",
" <td id=\"T_f9879_row6_col3\" class=\"data row6 col3\" >Post</td>\n",
" <td id=\"T_f9879_row6_col4\" class=\"data row6 col4\" >2</td>\n",
" <td id=\"T_f9879_row6_col5\" class=\"data row6 col5\" >181</td>\n",
" <td id=\"T_f9879_row6_col6\" class=\"data row6 col6\" >II</td>\n",
" <td id=\"T_f9879_row6_col7\" class=\"data row6 col7\" >8</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_f9879_row7_col0\" class=\"data row7 col0\" >65</td>\n",
" <td id=\"T_f9879_row7_col1\" class=\"data row7 col1\" >25</td>\n",
" <td id=\"T_f9879_row7_col2\" class=\"data row7 col2\" >no</td>\n",
" <td id=\"T_f9879_row7_col3\" class=\"data row7 col3\" >Post</td>\n",
" <td id=\"T_f9879_row7_col4\" class=\"data row7 col4\" >1</td>\n",
" <td id=\"T_f9879_row7_col5\" class=\"data row7 col5\" >192</td>\n",
" <td id=\"T_f9879_row7_col6\" class=\"data row7 col6\" >II</td>\n",
" <td id=\"T_f9879_row7_col7\" class=\"data row7 col7\" >16</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_f9879_row8_col0\" class=\"data row8 col0\" >80</td>\n",
" <td id=\"T_f9879_row8_col1\" class=\"data row8 col1\" >59</td>\n",
" <td id=\"T_f9879_row8_col2\" class=\"data row8 col2\" >no</td>\n",
" <td id=\"T_f9879_row8_col3\" class=\"data row8 col3\" >Post</td>\n",
" <td id=\"T_f9879_row8_col4\" class=\"data row8 col4\" >30</td>\n",
" <td id=\"T_f9879_row8_col5\" class=\"data row8 col5\" >0</td>\n",
" <td id=\"T_f9879_row8_col6\" class=\"data row8 col6\" >II</td>\n",
" <td id=\"T_f9879_row8_col7\" class=\"data row8 col7\" >39</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_f9879_row9_col0\" class=\"data row9 col0\" >66</td>\n",
" <td id=\"T_f9879_row9_col1\" class=\"data row9 col1\" >3</td>\n",
" <td id=\"T_f9879_row9_col2\" class=\"data row9 col2\" >no</td>\n",
" <td id=\"T_f9879_row9_col3\" class=\"data row9 col3\" >Post</td>\n",
" <td id=\"T_f9879_row9_col4\" class=\"data row9 col4\" >7</td>\n",
" <td id=\"T_f9879_row9_col5\" class=\"data row9 col5\" >0</td>\n",
" <td id=\"T_f9879_row9_col6\" class=\"data row9 col6\" >II</td>\n",
" <td id=\"T_f9879_row9_col7\" class=\"data row9 col7\" >18</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n"
]
},
"metadata": {},
"execution_count": 6
}
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "zcMjHeAEb2n_"
},
"source": [
"Let's take a look at the output."
]
},
{
"cell_type": "code",
"metadata": {
"id": "h8ltRTa4_WOn",
"outputId": "e8ddf347-88a8-4383-8b32-dcfa34fcc1fa",
"scrolled": true,
"colab": {
"base_uri": "https://localhost:8080/"
}
},
"source": [
"y[:10]"
],
"execution_count": 7,
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
"array([( True, 1814.), ( True, 2018.), ( True, 712.), ( True, 1807.),\n",
" ( True, 772.), ( True, 448.), (False, 2172.), (False, 2161.),\n",
" ( True, 471.), (False, 2014.)],\n",
" dtype=[('cens', '?'), ('time', '<f8')])"
]
},
"metadata": {},
"execution_count": 7
}
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "A5NXlNYob2oH"
},
"source": [
"For the output, scikit-survival uses a numpy nd array, so to show it we do a dataframe."
]
},
{
"cell_type": "code",
"source": [
"df_y = pd.DataFrame(data={'time': y['time'].astype(int), 'event': y['cens']})\n",
"df_y[:10].style.hide(axis=\"index\").highlight_min('event', color='lightgreen')"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 363
},
"id": "AfPvZcjJ-GwQ",
"outputId": "7ee1358d-69bb-4d15-876a-92e708147a24"
},
"execution_count": 8,
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
"<pandas.io.formats.style.Styler at 0x7a30d61bea10>"
],
"text/html": [
"<style type=\"text/css\">\n",
"#T_118da_row6_col1, #T_118da_row7_col1, #T_118da_row9_col1 {\n",
" background-color: lightgreen;\n",
"}\n",
"</style>\n",
"<table id=\"T_118da\" class=\"dataframe\">\n",
" <thead>\n",
" <tr>\n",
" <th id=\"T_118da_level0_col0\" class=\"col_heading level0 col0\" >time</th>\n",
" <th id=\"T_118da_level0_col1\" class=\"col_heading level0 col1\" >event</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <td id=\"T_118da_row0_col0\" class=\"data row0 col0\" >1814</td>\n",
" <td id=\"T_118da_row0_col1\" class=\"data row0 col1\" >True</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_118da_row1_col0\" class=\"data row1 col0\" >2018</td>\n",
" <td id=\"T_118da_row1_col1\" class=\"data row1 col1\" >True</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_118da_row2_col0\" class=\"data row2 col0\" >712</td>\n",
" <td id=\"T_118da_row2_col1\" class=\"data row2 col1\" >True</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_118da_row3_col0\" class=\"data row3 col0\" >1807</td>\n",
" <td id=\"T_118da_row3_col1\" class=\"data row3 col1\" >True</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_118da_row4_col0\" class=\"data row4 col0\" >772</td>\n",
" <td id=\"T_118da_row4_col1\" class=\"data row4 col1\" >True</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_118da_row5_col0\" class=\"data row5 col0\" >448</td>\n",
" <td id=\"T_118da_row5_col1\" class=\"data row5 col1\" >True</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_118da_row6_col0\" class=\"data row6 col0\" >2172</td>\n",
" <td id=\"T_118da_row6_col1\" class=\"data row6 col1\" >False</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_118da_row7_col0\" class=\"data row7 col0\" >2161</td>\n",
" <td id=\"T_118da_row7_col1\" class=\"data row7 col1\" >False</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_118da_row8_col0\" class=\"data row8 col0\" >471</td>\n",
" <td id=\"T_118da_row8_col1\" class=\"data row8 col1\" >True</td>\n",
" </tr>\n",
" <tr>\n",
" <td id=\"T_118da_row9_col0\" class=\"data row9 col0\" >2014</td>\n",
" <td id=\"T_118da_row9_col1\" class=\"data row9 col1\" >False</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n"
]
},
"metadata": {},
"execution_count": 8
}
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "xzW5x7ljb2oP"
},
"source": [
"One of the main challenges of survival analysis is **right censoring**, i.e., by the end of the study, the event of interest (for example, in medicine 'death of a patient' or in this dataset 'recurrence of cancer') has only occurred for a subset of the observations.\n",
"\n",
"The **right censoring** in this dataset is given by the column named 'event' and it's a variable which can take value 'True' if the patient had a recurrence of cancer or 'False' if the patient is recurrence free at the indicated time (right-censored samples)."
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "VmfAR7igb2oW"
},
"source": [
"Let's see how many right-censored samples do we have."
]
},
{
"cell_type": "code",
"metadata": {
"id": "rzS8h1GG_o_A",
"outputId": "d7d49914-42cb-4407-cc43-98aea98545f3",
"colab": {
"base_uri": "https://localhost:8080/"
}
},
"source": [
"print(f'Number of samples: {len(df_y)}')\n",
"print(f'Number of right censored samples: {len(df_y.query(\"event == False\"))}')\n",
"print(f'Percentage of right censored samples: {100*len(df_y.query(\"event == False\"))/len(df_y):.1f}%')"
],
"execution_count": 9,
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"Number of samples: 686\n",
"Number of right censored samples: 387\n",
"Percentage of right censored samples: 56.4%\n"
]
}
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "VtsENFsnQhZx"
},
"source": [
"There are 387 patients (56.4%) who were right censored (recurrence free) at the end of the study.\n",
"\n",
"Let's divide our dataset in training and test sets."
]
},
{
"cell_type": "code",
"source": [
"from sklearn.preprocessing import OneHotEncoder\n",
"from sklearn.preprocessing import OrdinalEncoder"
],
"metadata": {
"id": "PV9SQ8LZ20BL"
},
"execution_count": 10,
"outputs": []
},
{
"cell_type": "code",
"source": [
"X[\"horTh\"] = [1 if X[\"horTh\"].iloc[i] == 'yes' else 0 for i in range(X.shape[0])]"
],
"metadata": {
"id": "MxHGiw0E4-hP"
},
"execution_count": 11,
"outputs": []
},
{
"cell_type": "code",
"source": [
"X[\"menostat\"] = [1 if X[\"menostat\"].iloc[i] == 'Post' else 0 for i in range(X.shape[0])]"
],
"metadata": {
"id": "P_R8Fr4a5JUt"
},
"execution_count": 12,
"outputs": []
},
{
"cell_type": "code",
"source": [
"X[\"tgrade\"] = OrdinalEncoder(categories=[['I', 'II', 'III']]).fit_transform(X[[\"tgrade\"]])"
],
"metadata": {
"id": "b6ABtXNK3Dd9"
},
"execution_count": 13,
"outputs": []
},
{
"cell_type": "code",
"metadata": {
"id": "duYhddUr_1nH",
"outputId": "3789d704-0a2e-42a5-ee2f-f5ad03a7810c",
"colab": {
"base_uri": "https://localhost:8080/"
}
},
"source": [
"from sklearn.model_selection import train_test_split\n",
"\n",
"X_trn, X_test, y_trn, y_test = train_test_split(X, y, random_state=20)\n",
"\n",
"print(f'Number of training samples: {len(y_trn)}')\n",
"print(f'Number of test samples: {len(y_test)}')"
],
"execution_count": 14,
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"Number of training samples: 514\n",
"Number of test samples: 172\n"
]
}
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "3VEOV-vWb2ow"
},
"source": [
"We divide the features/covariates into continuous and categorical."
]
},
{
"cell_type": "code",
"source": [
"X.dtypes"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 335
},
"id": "4OqMuC40mXDb",
"outputId": "717dbdb6-b48e-4a6b-9671-03cc1b05b9f2"
},
"execution_count": 16,
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
"age float64\n",
"estrec float64\n",
"horTh int64\n",
"menostat int64\n",
"pnodes float64\n",
"progrec float64\n",
"tgrade float64\n",
"tsize float64\n",
"dtype: object"
],
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>0</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>age</th>\n",
" <td>float64</td>\n",
" </tr>\n",
" <tr>\n",
" <th>estrec</th>\n",
" <td>float64</td>\n",
" </tr>\n",
" <tr>\n",
" <th>horTh</th>\n",
" <td>int64</td>\n",
" </tr>\n",
" <tr>\n",
" <th>menostat</th>\n",
" <td>int64</td>\n",
" </tr>\n",
" <tr>\n",
" <th>pnodes</th>\n",
" <td>float64</td>\n",
" </tr>\n",
" <tr>\n",
" <th>progrec</th>\n",
" <td>float64</td>\n",
" </tr>\n",
" <tr>\n",
" <th>tgrade</th>\n",
" <td>float64</td>\n",
" </tr>\n",
" <tr>\n",
" <th>tsize</th>\n",
" <td>float64</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div><br><label><b>dtype:</b> object</label>"
]
},
"metadata": {},
"execution_count": 16
}
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "jDjgk9PWb2o3"
},
"source": [
"We use ordinal encoding for categorical features/covariates and standard scaling for continuous features/covariates."
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "N_nodxlEb2o-"
},
"source": [
"# Baseline: Cox Proportional Hazards model"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "KqdChwYJb2o_"
},
"source": [
"Cox Proportional Hazards model assumes that the log-hazard of a subject is a linear function of their $m$ static covariates/features $h_i, i\\in\\{1,\\ldots,m\\}$, and a population-level baseline hazard function $h_0(t)$ that changes over time:\n",
"\\begin{equation}\n",
"h(t|x)=h_0(t)\\exp\\left(\\sum_{i=1}^mh_i(x_i-\\bar{x_i})\\right).\n",
"\\end{equation}\n",
"\n",
"The term *proportional hazards* refers to the assumption of a constant relationship between the dependent variable and the regression coefficients."
]
},
{
"cell_type": "code",
"metadata": {
"id": "77YbwMKvAFHQ",
"outputId": "a60ddcf3-cfca-4d47-b20c-031d48b6e03c",
"colab": {
"base_uri": "https://localhost:8080/",
"height": 80
}
},
"source": [
"from sklearn.pipeline import make_pipeline\n",
"from sksurv.linear_model import CoxPHSurvivalAnalysis\n",
"from sksurv.metrics import concordance_index_censored\n",
"\n",
"cox = CoxPHSurvivalAnalysis()\n",
"cox.fit(X_trn, y_trn)"
],
"execution_count": 17,
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
"CoxPHSurvivalAnalysis()"
],
"text/html": [
"<style>#sk-container-id-1 {\n",
" /* Definition of color scheme common for light and dark mode */\n",
" --sklearn-color-text: black;\n",
" --sklearn-color-line: gray;\n",
" /* Definition of color scheme for unfitted estimators */\n",
" --sklearn-color-unfitted-level-0: #fff5e6;\n",
" --sklearn-color-unfitted-level-1: #f6e4d2;\n",
" --sklearn-color-unfitted-level-2: #ffe0b3;\n",
" --sklearn-color-unfitted-level-3: chocolate;\n",
" /* Definition of color scheme for fitted estimators */\n",
" --sklearn-color-fitted-level-0: #f0f8ff;\n",
" --sklearn-color-fitted-level-1: #d4ebff;\n",
" --sklearn-color-fitted-level-2: #b3dbfd;\n",
" --sklearn-color-fitted-level-3: cornflowerblue;\n",
"\n",
" /* Specific color for light theme */\n",
" --sklearn-color-text-on-default-background: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, black)));\n",
" --sklearn-color-background: var(--sg-background-color, var(--theme-background, var(--jp-layout-color0, white)));\n",
" --sklearn-color-border-box: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, black)));\n",
" --sklearn-color-icon: #696969;\n",
"\n",
" @media (prefers-color-scheme: dark) {\n",
" /* Redefinition of color scheme for dark theme */\n",
" --sklearn-color-text-on-default-background: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, white)));\n",
" --sklearn-color-background: var(--sg-background-color, var(--theme-background, var(--jp-layout-color0, #111)));\n",
" --sklearn-color-border-box: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, white)));\n",
" --sklearn-color-icon: #878787;\n",
" }\n",
"}\n",
"\n",
"#sk-container-id-1 {\n",
" color: var(--sklearn-color-text);\n",
"}\n",
"\n",
"#sk-container-id-1 pre {\n",
" padding: 0;\n",
"}\n",
"\n",
"#sk-container-id-1 input.sk-hidden--visually {\n",
" border: 0;\n",
" clip: rect(1px 1px 1px 1px);\n",
" clip: rect(1px, 1px, 1px, 1px);\n",
" height: 1px;\n",
" margin: -1px;\n",
" overflow: hidden;\n",
" padding: 0;\n",
" position: absolute;\n",
" width: 1px;\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-dashed-wrapped {\n",
" border: 1px dashed var(--sklearn-color-line);\n",
" margin: 0 0.4em 0.5em 0.4em;\n",
" box-sizing: border-box;\n",
" padding-bottom: 0.4em;\n",
" background-color: var(--sklearn-color-background);\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-container {\n",
" /* jupyter's `normalize.less` sets `[hidden] { display: none; }`\n",
" but bootstrap.min.css set `[hidden] { display: none !important; }`\n",
" so we also need the `!important` here to be able to override the\n",
" default hidden behavior on the sphinx rendered scikit-learn.org.\n",
" See: https://github.com/scikit-learn/scikit-learn/issues/21755 */\n",
" display: inline-block !important;\n",
" position: relative;\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-text-repr-fallback {\n",
" display: none;\n",
"}\n",
"\n",
"div.sk-parallel-item,\n",
"div.sk-serial,\n",
"div.sk-item {\n",
" /* draw centered vertical line to link estimators */\n",
" background-image: linear-gradient(var(--sklearn-color-text-on-default-background), var(--sklearn-color-text-on-default-background));\n",
" background-size: 2px 100%;\n",
" background-repeat: no-repeat;\n",
" background-position: center center;\n",
"}\n",
"\n",
"/* Parallel-specific style estimator block */\n",
"\n",
"#sk-container-id-1 div.sk-parallel-item::after {\n",
" content: \"\";\n",
" width: 100%;\n",
" border-bottom: 2px solid var(--sklearn-color-text-on-default-background);\n",
" flex-grow: 1;\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-parallel {\n",
" display: flex;\n",
" align-items: stretch;\n",
" justify-content: center;\n",
" background-color: var(--sklearn-color-background);\n",
" position: relative;\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-parallel-item {\n",
" display: flex;\n",
" flex-direction: column;\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-parallel-item:first-child::after {\n",
" align-self: flex-end;\n",
" width: 50%;\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-parallel-item:last-child::after {\n",
" align-self: flex-start;\n",
" width: 50%;\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-parallel-item:only-child::after {\n",
" width: 0;\n",
"}\n",
"\n",
"/* Serial-specific style estimator block */\n",
"\n",
"#sk-container-id-1 div.sk-serial {\n",
" display: flex;\n",
" flex-direction: column;\n",
" align-items: center;\n",
" background-color: var(--sklearn-color-background);\n",
" padding-right: 1em;\n",
" padding-left: 1em;\n",
"}\n",
"\n",
"\n",
"/* Toggleable style: style used for estimator/Pipeline/ColumnTransformer box that is\n",
"clickable and can be expanded/collapsed.\n",
"- Pipeline and ColumnTransformer use this feature and define the default style\n",
"- Estimators will overwrite some part of the style using the `sk-estimator` class\n",
"*/\n",
"\n",
"/* Pipeline and ColumnTransformer style (default) */\n",
"\n",
"#sk-container-id-1 div.sk-toggleable {\n",
" /* Default theme specific background. It is overwritten whether we have a\n",
" specific estimator or a Pipeline/ColumnTransformer */\n",
" background-color: var(--sklearn-color-background);\n",
"}\n",
"\n",
"/* Toggleable label */\n",
"#sk-container-id-1 label.sk-toggleable__label {\n",
" cursor: pointer;\n",
" display: block;\n",
" width: 100%;\n",
" margin-bottom: 0;\n",
" padding: 0.5em;\n",
" box-sizing: border-box;\n",
" text-align: center;\n",
"}\n",
"\n",
"#sk-container-id-1 label.sk-toggleable__label-arrow:before {\n",
" /* Arrow on the left of the label */\n",
" content: \"▸\";\n",
" float: left;\n",
" margin-right: 0.25em;\n",
" color: var(--sklearn-color-icon);\n",
"}\n",
"\n",
"#sk-container-id-1 label.sk-toggleable__label-arrow:hover:before {\n",
" color: var(--sklearn-color-text);\n",
"}\n",
"\n",
"/* Toggleable content - dropdown */\n",
"\n",
"#sk-container-id-1 div.sk-toggleable__content {\n",
" max-height: 0;\n",
" max-width: 0;\n",
" overflow: hidden;\n",
" text-align: left;\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-0);\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-toggleable__content.fitted {\n",
" /* fitted */\n",
" background-color: var(--sklearn-color-fitted-level-0);\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-toggleable__content pre {\n",
" margin: 0.2em;\n",
" border-radius: 0.25em;\n",
" color: var(--sklearn-color-text);\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-0);\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-toggleable__content.fitted pre {\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-fitted-level-0);\n",
"}\n",
"\n",
"#sk-container-id-1 input.sk-toggleable__control:checked~div.sk-toggleable__content {\n",
" /* Expand drop-down */\n",
" max-height: 200px;\n",
" max-width: 100%;\n",
" overflow: auto;\n",
"}\n",
"\n",
"#sk-container-id-1 input.sk-toggleable__control:checked~label.sk-toggleable__label-arrow:before {\n",
" content: \"▾\";\n",
"}\n",
"\n",
"/* Pipeline/ColumnTransformer-specific style */\n",
"\n",
"#sk-container-id-1 div.sk-label input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
" color: var(--sklearn-color-text);\n",
" background-color: var(--sklearn-color-unfitted-level-2);\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-label.fitted input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
" background-color: var(--sklearn-color-fitted-level-2);\n",
"}\n",
"\n",
"/* Estimator-specific style */\n",
"\n",
"/* Colorize estimator box */\n",
"#sk-container-id-1 div.sk-estimator input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-2);\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-estimator.fitted input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
" /* fitted */\n",
" background-color: var(--sklearn-color-fitted-level-2);\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-label label.sk-toggleable__label,\n",
"#sk-container-id-1 div.sk-label label {\n",
" /* The background is the default theme color */\n",
" color: var(--sklearn-color-text-on-default-background);\n",
"}\n",
"\n",
"/* On hover, darken the color of the background */\n",
"#sk-container-id-1 div.sk-label:hover label.sk-toggleable__label {\n",
" color: var(--sklearn-color-text);\n",
" background-color: var(--sklearn-color-unfitted-level-2);\n",
"}\n",
"\n",
"/* Label box, darken color on hover, fitted */\n",
"#sk-container-id-1 div.sk-label.fitted:hover label.sk-toggleable__label.fitted {\n",
" color: var(--sklearn-color-text);\n",
" background-color: var(--sklearn-color-fitted-level-2);\n",
"}\n",
"\n",
"/* Estimator label */\n",
"\n",
"#sk-container-id-1 div.sk-label label {\n",
" font-family: monospace;\n",
" font-weight: bold;\n",
" display: inline-block;\n",
" line-height: 1.2em;\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-label-container {\n",
" text-align: center;\n",
"}\n",
"\n",
"/* Estimator-specific */\n",
"#sk-container-id-1 div.sk-estimator {\n",
" font-family: monospace;\n",
" border: 1px dotted var(--sklearn-color-border-box);\n",
" border-radius: 0.25em;\n",
" box-sizing: border-box;\n",
" margin-bottom: 0.5em;\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-0);\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-estimator.fitted {\n",
" /* fitted */\n",
" background-color: var(--sklearn-color-fitted-level-0);\n",
"}\n",
"\n",
"/* on hover */\n",
"#sk-container-id-1 div.sk-estimator:hover {\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-2);\n",
"}\n",
"\n",
"#sk-container-id-1 div.sk-estimator.fitted:hover {\n",
" /* fitted */\n",
" background-color: var(--sklearn-color-fitted-level-2);\n",
"}\n",
"\n",
"/* Specification for estimator info (e.g. \"i\" and \"?\") */\n",
"\n",
"/* Common style for \"i\" and \"?\" */\n",
"\n",
".sk-estimator-doc-link,\n",
"a:link.sk-estimator-doc-link,\n",
"a:visited.sk-estimator-doc-link {\n",
" float: right;\n",
" font-size: smaller;\n",
" line-height: 1em;\n",
" font-family: monospace;\n",
" background-color: var(--sklearn-color-background);\n",
" border-radius: 1em;\n",
" height: 1em;\n",
" width: 1em;\n",
" text-decoration: none !important;\n",
" margin-left: 1ex;\n",
" /* unfitted */\n",
" border: var(--sklearn-color-unfitted-level-1) 1pt solid;\n",
" color: var(--sklearn-color-unfitted-level-1);\n",
"}\n",
"\n",
".sk-estimator-doc-link.fitted,\n",
"a:link.sk-estimator-doc-link.fitted,\n",
"a:visited.sk-estimator-doc-link.fitted {\n",
" /* fitted */\n",
" border: var(--sklearn-color-fitted-level-1) 1pt solid;\n",
" color: var(--sklearn-color-fitted-level-1);\n",
"}\n",
"\n",
"/* On hover */\n",
"div.sk-estimator:hover .sk-estimator-doc-link:hover,\n",
".sk-estimator-doc-link:hover,\n",
"div.sk-label-container:hover .sk-estimator-doc-link:hover,\n",
".sk-estimator-doc-link:hover {\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-3);\n",
" color: var(--sklearn-color-background);\n",
" text-decoration: none;\n",
"}\n",
"\n",
"div.sk-estimator.fitted:hover .sk-estimator-doc-link.fitted:hover,\n",
".sk-estimator-doc-link.fitted:hover,\n",
"div.sk-label-container:hover .sk-estimator-doc-link.fitted:hover,\n",
".sk-estimator-doc-link.fitted:hover {\n",
" /* fitted */\n",
" background-color: var(--sklearn-color-fitted-level-3);\n",
" color: var(--sklearn-color-background);\n",
" text-decoration: none;\n",
"}\n",
"\n",
"/* Span, style for the box shown on hovering the info icon */\n",
".sk-estimator-doc-link span {\n",
" display: none;\n",
" z-index: 9999;\n",
" position: relative;\n",
" font-weight: normal;\n",
" right: .2ex;\n",
" padding: .5ex;\n",
" margin: .5ex;\n",
" width: min-content;\n",
" min-width: 20ex;\n",
" max-width: 50ex;\n",
" color: var(--sklearn-color-text);\n",
" box-shadow: 2pt 2pt 4pt #999;\n",
" /* unfitted */\n",
" background: var(--sklearn-color-unfitted-level-0);\n",
" border: .5pt solid var(--sklearn-color-unfitted-level-3);\n",
"}\n",
"\n",
".sk-estimator-doc-link.fitted span {\n",
" /* fitted */\n",
" background: var(--sklearn-color-fitted-level-0);\n",
" border: var(--sklearn-color-fitted-level-3);\n",
"}\n",
"\n",
".sk-estimator-doc-link:hover span {\n",
" display: block;\n",
"}\n",
"\n",
"/* \"?\"-specific style due to the `<a>` HTML tag */\n",
"\n",
"#sk-container-id-1 a.estimator_doc_link {\n",
" float: right;\n",
" font-size: 1rem;\n",
" line-height: 1em;\n",
" font-family: monospace;\n",
" background-color: var(--sklearn-color-background);\n",
" border-radius: 1rem;\n",
" height: 1rem;\n",
" width: 1rem;\n",
" text-decoration: none;\n",
" /* unfitted */\n",
" color: var(--sklearn-color-unfitted-level-1);\n",
" border: var(--sklearn-color-unfitted-level-1) 1pt solid;\n",
"}\n",
"\n",
"#sk-container-id-1 a.estimator_doc_link.fitted {\n",
" /* fitted */\n",
" border: var(--sklearn-color-fitted-level-1) 1pt solid;\n",
" color: var(--sklearn-color-fitted-level-1);\n",
"}\n",
"\n",
"/* On hover */\n",
"#sk-container-id-1 a.estimator_doc_link:hover {\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-3);\n",
" color: var(--sklearn-color-background);\n",
" text-decoration: none;\n",
"}\n",
"\n",
"#sk-container-id-1 a.estimator_doc_link.fitted:hover {\n",
" /* fitted */\n",
" background-color: var(--sklearn-color-fitted-level-3);\n",
"}\n",
"</style><div id=\"sk-container-id-1\" class=\"sk-top-container\"><div class=\"sk-text-repr-fallback\"><pre>CoxPHSurvivalAnalysis()</pre><b>In a Jupyter environment, please rerun this cell to show the HTML representation or trust the notebook. <br />On GitHub, the HTML representation is unable to render, please try loading this page with nbviewer.org.</b></div><div class=\"sk-container\" hidden><div class=\"sk-item\"><div class=\"sk-estimator fitted sk-toggleable\"><input class=\"sk-toggleable__control sk-hidden--visually\" id=\"sk-estimator-id-1\" type=\"checkbox\" checked><label for=\"sk-estimator-id-1\" class=\"sk-toggleable__label fitted sk-toggleable__label-arrow fitted\">&nbsp;CoxPHSurvivalAnalysis<span class=\"sk-estimator-doc-link fitted\">i<span>Fitted</span></span></label><div class=\"sk-toggleable__content fitted\"><pre>CoxPHSurvivalAnalysis()</pre></div> </div></div></div></div>"
]
},
"metadata": {},
"execution_count": 17
}
]
},
{
"cell_type": "code",
"source": [
"ci_cox = concordance_index_censored(y_test[\"cens\"], y_test[\"time\"], cox.predict(X_test))\n",
"print(f'The c-index of Cox is given by {ci_cox[0]:.3f}')"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "oVdrGM0NtWdR",
"outputId": "1387a9ea-0d1d-461c-d7d3-5b726c49e09f"
},
"execution_count": 18,
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"The c-index of Cox is given by 0.665\n"
]
}
]
},
{
"cell_type": "markdown",
"source": [
"Let's now attempt to quantify how a survival curve estimated on a training set performs on a test set.\n",
"\n",
"## Survival model evaluation using the Integrated Brier Score (IBS) and the Concordance Index (C-index)"
],
"metadata": {
"id": "I2wAzNXar551"
}
},
{
"cell_type": "markdown",
"source": [
"The Brier score and the C-index are measures that **assess the quality of a predicted survival curve** on a finite data sample.\n",
"\n",
"- **The Brier score is a proper scoring rule**, meaning that an estimate of the survival curve has minimal Brier score if and only if it matches the true survival probabilities induced by the underlying data generating process. In that respect the **Brier score** assesses both the **calibration** and the **ranking power** of a survival probability estimator.\n",
"\n",
"- On the other hand, the **C-index** only assesses the **ranking power**: it is invariant to a monotonic transform of the survival probabilities. It only focus on the ability of a predictive survival model to identify which individual is likely to fail first out of any pair of two individuals.\n",
"\n",
"\n",
"\n",
"It is comprised between 0 and 1 (lower is better).\n",
"It answers the question \"how close to the real probabilities are our estimates?\"."
],
"metadata": {
"id": "Gap1YWH5sAA1"
}
},
{
"cell_type": "markdown",
"source": [
"<summary>Mathematical formulation</summary>\n",
" \n",
"$$\\mathrm{BS}^c(t) = \\frac{1}{n} \\sum_{i=1}^n I(d_i \\leq t \\land \\delta_i = 1)\n",
" \\frac{(0 - \\hat{S}(t | \\mathbf{x}_i))^2}{\\hat{G}(d_i)} + I(d_i > t)\n",
" \\frac{(1 - \\hat{S}(t | \\mathbf{x}_i))^2}{\\hat{G}(t)}$$\n",
" \n",
"In the survival analysis context, the Brier Score can be seen as the Mean Squared Error (MSE) between our probability $\\hat{S}(t)$ and our target label $\\delta_i \\in {0, 1}$, weighted by the inverse probability of censoring $\\frac{1}{\\hat{G}(t)}$. In practice we estimate $\\hat{G}(t)$ using a variant of the Kaplan-Estimator with swapped event indicator.\n",
"\n",
"- When no event or censoring has happened at $t$ yet, i.e. $I(d_i > t)$, we penalize a low probability of survival with $(1 - \\hat{S}(t|\\mathbf{x}_i))^2$.\n",
"- Conversely, when an individual has experienced an event before $t$, i.e. $I(d_i \\leq t \\land \\delta_i = 1)$, we penalize a high probability of survival with $(0 - \\hat{S}(t|\\mathbf{x}_i))^2$."
],
"metadata": {
"id": "3bmwqNQisHup"
}
},
{
"cell_type": "markdown",
"source": [
"![BrierScore.svg](data:image/svg+xml;base64,<svg width="456" height="278" viewBox="0 0 456 278" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect width="456" height="278" fill="white"/>
<path d="M39.5 57.5C39.5 57.5 201 57.5 230.5 152.25C260 247 421.5 247 421.5 247" stroke="#1D26F9" stroke-width="2"/>
<path d="M39.5 9.99895L36.6132 14.9989H42.3868L39.5 9.99895ZM40 248.001L40 14.4989H39L39 248.001H40Z" fill="black"/>
<path d="M435 248L430 245.113V250.887L435 248ZM39 248.5L430.5 248.5V247.5L39 247.5V248.5Z" fill="black"/>
<path d="M40 57.5H231" stroke="black" stroke-width="2" stroke-dasharray="6 6"/>
<path d="M317 87L367 87" stroke="black" stroke-width="2" stroke-dasharray="6 6"/>
<line x1="230" y1="247" x2="423.01" y2="247" stroke="black" stroke-width="2" stroke-dasharray="6 6"/>
<path d="M230.5 248.01L230.5 152.255L230.5 56.5" stroke="black" stroke-width="2" stroke-dasharray="6 6"/>
<path d="M31.8496 261.747C32.5195 261.747 32.9798 261.38 33.2305 260.646C33.4811 259.913 33.6064 258.851 33.6064 257.461C33.6064 256.354 33.5312 255.469 33.3809 254.809C33.0983 253.578 32.5697 252.963 31.7949 252.963C31.0202 252.963 30.4893 253.596 30.2021 254.863C30.0518 255.538 29.9766 256.426 29.9766 257.529C29.9766 258.564 30.054 259.391 30.209 260.011C30.5007 261.168 31.0475 261.747 31.8496 261.747ZM31.8291 252.594C32.8773 252.594 33.6908 253.143 34.2695 254.241C34.7298 255.13 34.96 256.151 34.96 257.304C34.96 258.211 34.8187 259.065 34.5361 259.867C34.0029 261.376 33.0801 262.13 31.7676 262.13C30.8698 262.13 30.1315 261.722 29.5527 260.906C28.9329 260.036 28.623 258.853 28.623 257.358C28.623 256.183 28.8304 255.171 29.2451 254.323C29.8057 253.17 30.667 252.594 31.8291 252.594Z" fill="black"/>
<path d="M28.5508 51.9492C28.5664 51.9688 28.5742 51.9844 28.5742 51.9961C28.5781 52.0039 28.5801 52.0254 28.5801 52.0605V59.1152C28.5801 59.416 28.6602 59.6074 28.8203 59.6895C28.9805 59.7715 29.2793 59.8203 29.7168 59.8359V60H26.4121V59.8242C26.8848 59.8008 27.1934 59.7363 27.3379 59.6309C27.4824 59.5254 27.5547 59.2969 27.5547 58.9453V53.5195C27.5547 53.332 27.5312 53.1895 27.4844 53.0918C27.4375 52.9941 27.3359 52.9453 27.1797 52.9453C27.0781 52.9453 26.9453 52.9746 26.7812 53.0332C26.6211 53.0879 26.4707 53.1465 26.3301 53.209V53.0449L28.4805 51.9492H28.5508Z" fill="black"/>
<path d="M429.172 264.42C429.172 264.373 429.175 264.32 429.181 264.262C429.187 264.197 429.198 264.133 429.216 264.068L430.868 257.925H429.532C429.532 257.767 429.544 257.667 429.567 257.626C429.591 257.585 429.649 257.544 429.743 257.503C430.335 257.251 430.792 257.008 431.114 256.773C431.442 256.539 431.888 256.088 432.45 255.42L432.591 255.253C432.608 255.229 432.629 255.212 432.652 255.2C432.682 255.183 432.711 255.174 432.74 255.174C432.799 255.186 432.84 255.197 432.863 255.209C432.881 255.25 432.89 255.288 432.89 255.323C432.896 255.353 432.896 255.385 432.89 255.42L432.389 257.336H433.821L433.716 257.925H432.222L430.64 263.84C430.61 263.945 430.619 264.048 430.666 264.147C430.713 264.241 430.792 264.288 430.903 264.288C431.056 264.288 431.27 264.136 431.545 263.831C431.703 263.667 431.97 263.342 432.345 262.855L432.573 262.987L432.45 263.172C431.946 263.928 431.501 264.455 431.114 264.754C430.733 265.047 430.37 265.193 430.024 265.193C429.726 265.193 429.509 265.114 429.374 264.956C429.239 264.798 429.172 264.619 429.172 264.42Z" fill="black"/>
<line x1="317" y1="65" x2="367" y2="65" stroke="#1D26F9" stroke-width="2"/>
<path d="M202 104L205.753 97.5H198.247L202 104ZM202 62L198.247 68.5H205.753L202 62ZM202.65 98.15V67.85H201.35V98.15H202.65Z" fill="#FF0000"/>
<path d="M258 243L261.753 236.5H254.247L258 243ZM258 201L254.247 207.5H261.753L258 201ZM258.65 237.15V206.85H257.35V237.15H258.65Z" fill="#FF0000"/>
<rect x="224" y="254" width="12.1017" height="17" fill="url(#pattern0)"/>
<rect x="262" y="175" width="83" height="19.9763" fill="url(#pattern1)"/>
<rect x="106" y="104" width="83" height="18.5658" fill="url(#pattern2)"/>
<rect x="373" y="51" width="27" height="21.3488" fill="url(#pattern3)"/>
<rect x="7" y="14.6915" width="25" height="16.7553" fill="url(#pattern4)"/>
<rect x="373" y="78" width="27" height="18.0957" fill="url(#pattern5)"/>
<path d="M403.312 83.4355C403.312 83.2676 403.371 83.123 403.488 83.002C403.605 82.8809 403.75 82.8203 403.922 82.8203C404.09 82.8203 404.232 82.8809 404.35 83.002C404.471 83.1191 404.531 83.2637 404.531 83.4355C404.531 83.6035 404.471 83.748 404.35 83.8691C404.232 83.9863 404.09 84.0449 403.922 84.0449C403.75 84.0449 403.605 83.9863 403.488 83.8691C403.371 83.748 403.312 83.6035 403.312 83.4355ZM402.562 90.8359C402.98 90.7969 403.244 90.7266 403.354 90.625C403.463 90.5195 403.518 90.2383 403.518 89.7812V86.9863C403.518 86.7324 403.5 86.5566 403.465 86.459C403.406 86.2988 403.283 86.2188 403.096 86.2188C403.053 86.2188 403.01 86.2227 402.967 86.2305C402.928 86.2383 402.811 86.2695 402.615 86.3242V86.1426L402.867 86.0605C403.551 85.8379 404.027 85.6699 404.297 85.5566C404.406 85.5098 404.477 85.4863 404.508 85.4863C404.516 85.5137 404.52 85.543 404.52 85.5742V89.7812C404.52 90.2266 404.572 90.5059 404.678 90.6191C404.787 90.7324 405.031 90.8047 405.41 90.8359V91H402.562V90.8359ZM408.51 85.4629C408.795 85.4629 409.057 85.5254 409.295 85.6504C409.451 85.7324 409.602 85.8457 409.746 85.9902V84.127C409.746 83.8887 409.719 83.7246 409.664 83.6348C409.613 83.5449 409.488 83.5 409.289 83.5C409.242 83.5 409.201 83.502 409.166 83.5059C409.131 83.5098 409.053 83.5176 408.932 83.5293V83.3359L409.412 83.2129C409.588 83.166 409.764 83.1172 409.939 83.0664C410.115 83.0156 410.27 82.9668 410.402 82.9199C410.465 82.9004 410.568 82.8633 410.713 82.8086L410.748 82.8203L410.736 83.4355C410.732 83.6582 410.729 83.8887 410.725 84.127C410.721 84.3613 410.719 84.5938 410.719 84.8242L410.707 89.6113C410.707 89.8652 410.738 90.043 410.801 90.1445C410.863 90.2461 411.029 90.2969 411.299 90.2969C411.342 90.2969 411.385 90.2969 411.428 90.2969C411.471 90.293 411.514 90.2871 411.557 90.2793V90.4727C411.533 90.4805 411.25 90.5781 410.707 90.7656L409.787 91.1113L409.746 91.0586V90.3379C409.527 90.5762 409.338 90.7461 409.178 90.8477C408.893 91.0234 408.562 91.1113 408.188 91.1113C407.523 91.1113 406.984 90.8555 406.57 90.3438C406.16 89.8281 405.955 89.2324 405.955 88.5566C405.955 87.709 406.201 86.9824 406.693 86.377C407.189 85.7676 407.795 85.4629 408.51 85.4629ZM408.727 90.4785C409.031 90.4785 409.277 90.3887 409.465 90.209C409.652 90.0293 409.746 89.8594 409.746 89.6992V87.1855C409.746 86.6777 409.609 86.3203 409.336 86.1133C409.066 85.9023 408.803 85.7969 408.545 85.7969C408.053 85.7969 407.67 86.0156 407.396 86.4531C407.123 86.8867 406.986 87.4219 406.986 88.0586C406.986 88.6875 407.131 89.248 407.42 89.7402C407.713 90.2324 408.148 90.4785 408.727 90.4785ZM414.416 85.5039C414.967 85.5039 415.449 85.6953 415.863 86.0781C416.277 86.457 416.484 86.9961 416.484 87.6953H412.764C412.803 88.6016 413.008 89.2617 413.379 89.6758C413.75 90.0898 414.189 90.2969 414.697 90.2969C415.107 90.2969 415.453 90.1895 415.734 89.9746C416.016 89.7598 416.275 89.4551 416.514 89.0605L416.719 89.1309C416.559 89.627 416.258 90.0859 415.816 90.5078C415.379 90.9297 414.842 91.1406 414.205 91.1406C413.471 91.1406 412.902 90.8633 412.5 90.3086C412.102 89.7539 411.902 89.1152 411.902 88.3926C411.902 87.6074 412.135 86.9297 412.6 86.3594C413.064 85.7891 413.67 85.5039 414.416 85.5039ZM414.076 85.9316C413.631 85.9316 413.291 86.1289 413.057 86.5234C412.932 86.7344 412.842 87 412.787 87.3203H415.26C415.217 86.9297 415.143 86.6387 415.037 86.4473C414.846 86.1035 414.525 85.9316 414.076 85.9316ZM420.439 87.7539C419.99 87.9023 419.619 88.0664 419.326 88.2461C418.764 88.5938 418.482 88.9883 418.482 89.4297C418.482 89.7852 418.6 90.0469 418.834 90.2148C418.986 90.3242 419.156 90.3789 419.344 90.3789C419.602 90.3789 419.848 90.3066 420.082 90.1621C420.32 90.0176 420.439 89.834 420.439 89.6113V87.7539ZM417.439 89.834C417.439 89.2676 417.723 88.7949 418.289 88.416C418.648 88.1816 419.365 87.8633 420.439 87.4609V86.9629C420.439 86.5645 420.4 86.2871 420.322 86.1309C420.189 85.8691 419.914 85.7383 419.496 85.7383C419.297 85.7383 419.107 85.7891 418.928 85.8906C418.748 85.9961 418.658 86.1406 418.658 86.3242C418.658 86.3711 418.668 86.4512 418.688 86.5645C418.707 86.6738 418.717 86.7441 418.717 86.7754C418.717 86.9941 418.645 87.1465 418.5 87.2324C418.418 87.2832 418.32 87.3086 418.207 87.3086C418.031 87.3086 417.896 87.252 417.803 87.1387C417.709 87.0215 417.662 86.8926 417.662 86.752C417.662 86.4785 417.83 86.1934 418.166 85.8965C418.506 85.5957 419.002 85.4453 419.654 85.4453C420.412 85.4453 420.926 85.6914 421.195 86.1836C421.34 86.4531 421.412 86.8457 421.412 87.3613V89.7109C421.412 89.9375 421.428 90.0938 421.459 90.1797C421.51 90.332 421.615 90.4082 421.775 90.4082C421.865 90.4082 421.939 90.3945 421.998 90.3672C422.057 90.3398 422.158 90.2734 422.303 90.168V90.4727C422.178 90.625 422.043 90.75 421.898 90.8477C421.68 90.9961 421.457 91.0703 421.23 91.0703C420.965 91.0703 420.771 90.9844 420.65 90.8125C420.533 90.6406 420.469 90.4355 420.457 90.1973C420.16 90.4551 419.906 90.6465 419.695 90.7715C419.34 90.9824 419.002 91.0879 418.682 91.0879C418.346 91.0879 418.055 90.9707 417.809 90.7363C417.562 90.498 417.439 90.1973 417.439 89.834ZM422.578 90.8359C422.941 90.8008 423.188 90.7285 423.316 90.6191C423.445 90.5059 423.51 90.2871 423.51 89.9629V84.2383C423.51 83.9805 423.488 83.8027 423.445 83.7051C423.367 83.541 423.209 83.459 422.971 83.459C422.916 83.459 422.855 83.4648 422.789 83.4766C422.727 83.4883 422.646 83.5059 422.549 83.5293V83.3359C423.076 83.1953 423.711 83.0078 424.453 82.7734C424.48 82.7734 424.496 82.7852 424.5 82.8086C424.508 82.832 424.512 82.8828 424.512 82.9609V89.9863C424.512 90.3262 424.57 90.5469 424.688 90.6484C424.805 90.7461 425.047 90.8086 425.414 90.8359V91H422.578V90.8359Z" fill="black"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_1_28" transform="scale(0.0119048 0.00847458)"/>
</pattern>
<pattern id="pattern1" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image1_1_28" transform="scale(0.00169492 0.00704225)"/>
</pattern>
<pattern id="pattern2" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image2_1_28" transform="matrix(0.00172414 0 0 0.00770791 0 -0.00101418)"/>
</pattern>
<pattern id="pattern3" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image3_1_28" transform="scale(0.00581395 0.00735294)"/>
</pattern>
<pattern id="pattern4" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image4_1_28" transform="scale(0.00531915 0.00793651)"/>
</pattern>
<pattern id="pattern5" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image4_1_28" transform="scale(0.00531915 0.00793651)"/>
</pattern>
<image id="image0_1_28" width="84" height="118" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFQAAAB2CAYAAABWD7T8AAAMamlDQ1BJQ0MgUHJvZmlsZQAASImVVwdYU8kWnluSkJDQAhGQEnoTRHqREkKLICAdbIQkkFBiTAgqdkRUcO0iihVdFVF0LYAsKmIvi2LviwUFZV3URVFU3oQEdN1Xvne+b+7898yZ/5TM5M4AoNnLlUhyUC0AcsV50tiwIGZySiqT9AIgAAMk4AtMuDyZhBUTEwmgDPZ/l/e3oDWU644Krn+O/1fR4QtkPACQCRCn82W8XIibAMA38iTSPACICr3FtDyJAs+DWFcKA4R4jQJnKvFuBU5X4sYBm/hYNsRXAVCjcrnSTAA0HkA9M5+XCXk0PkPsLOaLxABojoDYnyfk8iFWxD4iN3eKApdDbAvtJRDDeIBX+necmX/jTx/i53Izh7AyrwFRCxbJJDncGf9naf635ObIB31Yw0YVSsNjFfnDGt7JnhKhwFSIu8TpUdGKWkPcK+Ir6w4AShHKwxOU9qgRT8aG9QMMiJ353OAIiI0gDhXnREWq9OkZolAOxHC1oNNFeZx4iPUhXiyQhcSpbLZKp8SqfKG1GVI2S6U/z5UO+FX4eiTPTmCp+N8KBRwVP6ZRIIxPgpgCsWW+KDEKYg2InWTZcREqm9EFQnbUoI1UHquI3xLiWIE4LEjJj+VnSENjVfYlubLBfLGtQhEnSoUP5gnjw5X1wU7zuAPxw1ywqwIxK2GQRyBLjhzMhS8IDlHmjnUIxAlxKp5eSV5QrHIuTpHkxKjscXNBTphCbw6xmyw/TjUXT8yDi1PJj2dI8mLilXHiBVncMTHKePAVIBKwQTBgAjls6WAKyAKilq66LvimHAkFXCAFmUAAHFWawRlJAyNi+IwDBeAPiARANjQvaGBUAPKh/suQVvl0BBkDo/kDM7LBc4hzQQTIge/ygVniIW+J4BnUiP7hnQsbD8abA5ti/N/rB7XfNCyoiVRp5IMemZqDlsQQYjAxnBhKtMMNcX/cF4+Ez0DYXHAv3Hswj2/2hOeEVsITwk1CG+HuZFGh9Icox4I2yB+qqkX697XArSGnOx6E+0F2yIwzcEPgiLtBPyw8AHp2h1q2Km5FVZg/cP8tg+9+DZUd2ZmMkoeRA8m2P87UsNdwH2JR1Pr7+ihjTR+qN3to5Ef/7O+qz4d9xI+W2GLsEHYOO4ldwBqxOsDETmD12GXsmAIPra5nA6tr0FvsQDzZkEf0D39clU9FJWXO1c6dzp+VY3mC6XmKjceeIpkhFWUK85gs+HUQMDlintMIpouziysAim+N8u/rHWPgG4IwLn7TFT4EwC+lv7+/8ZsuEu7fwx1w+3d909lUA0A7DsD5hTy5NF+pwxUPAvyX0IQ7zQCYAAtgC/NxAR7wmxYIQsAYEA3iQQqYBKsshOtcCqaBWWA+KAalYAVYCzaALWA72A32gYOgDjSCk+AsuASugpvgPlw97eAV6AbvQR+CICSEhtARA8QUsUIcEBfEC/FHQpBIJBZJQdKQTESMyJFZyAKkFFmFbEC2IVXIL8hR5CRyAWlF7iKPkU7kLfIJxVAqqosao9boSNQLZaERaDw6Ec1Ep6IFaBG6DC1HK9G9aC16Er2E3kTb0FdoDwYwdYyBmWGOmBfGxqKxVCwDk2JzsBKsDKvEarAG+Dtfx9qwLuwjTsTpOBN3hCs4HE/AefhUfA6+FN+A78Zr8dP4dfwx3o1/JdAIRgQHgg+BQ0gmZBKmEYoJZYSdhCOEM3AvtRPeE4lEBtGG6An3YgoxiziTuJS4ibif2ERsJT4l9pBIJAOSA8mPFE3ikvJIxaT1pL2kE6RrpHZSr5q6mqmai1qoWqqaWK1QrUxtj9pxtWtqL9T6yFpkK7IPOZrMJ88gLyfvIDeQr5DbyX0UbYoNxY8ST8mizKeUU2ooZygPKO/U1dXN1b3Vx6mL1Oepl6sfUD+v/lj9I1WHak9lUydQ5dRl1F3UJupd6jsajWZNC6Sl0vJoy2hVtFO0R7ReDbqGkwZHg68xV6NCo1bjmsZrTbKmlSZLc5JmgWaZ5iHNK5pdWmQtay22FldrjlaF1lGt21o92nTtUdrR2rnaS7X3aF/Q7tAh6VjrhOjwdYp0tuuc0nlKx+gWdDadR19A30E/Q2/XJera6HJ0s3RLdffptuh26+nouekl6k3Xq9A7ptfGwBjWDA4jh7GccZBxi/FpmPEw1jDBsCXDaoZdG/ZBf7h+oL5Av0R/v/5N/U8GTIMQg2yDlQZ1Bg8NcUN7w3GG0ww3G54x7BquO9x3OG94yfCDw+8ZoUb2RrFGM422G1026jE2MQ4zlhivNz5l3GXCMAk0yTJZY3LcpNOUbupvKjJdY3rC9CVTj8li5jDLmaeZ3WZGZuFmcrNtZi1mfeY25gnmheb7zR9aUCy8LDIs1lg0W3RbmlqOtZxlWW15z4ps5WUltFpndc7qg7WNdZL1Ius66w4bfRuOTYFNtc0DW5ptgO1U20rbG3ZEOy+7bLtNdlftUXt3e6F9hf0VB9TBw0HksMmhdQRhhPcI8YjKEbcdqY4sx3zHasfHTgynSKdCpzqn1yMtR6aOXDny3Mivzu7OOc47nO+P0hk1ZlThqIZRb13sXXguFS43XGmuoa5zXetd37g5uAncNrvdcae7j3Vf5N7s/sXD00PqUePR6Wnpmea50fO2l65XjNdSr/PeBO8g77nejd4ffTx88nwO+vzp6+ib7bvHt2O0zWjB6B2jn/qZ+3H9tvm1+TP90/y3+rcFmAVwAyoDngRaBPIDdwa+YNmxslh7Wa+DnIOkQUeCPrB92LPZTcFYcFhwSXBLiE5IQsiGkEeh5qGZodWh3WHuYTPDmsIJ4RHhK8Nvc4w5PE4Vp3uM55jZY05HUCPiIjZEPIm0j5RGNoxFx44Zu3rsgyirKHFUXTSI5kSvjn4YYxMzNebXccRxMeMqxj2PHRU7K/ZcHD1uctyeuPfxQfHL4+8n2CbIE5oTNRMnJFYlfkgKTlqV1JY8Mnl28qUUwxRRSn0qKTUxdWdqz/iQ8WvHt09wn1A84dZEm4nTJ16YZDgpZ9KxyZqTuZMPpRHSktL2pH3mRnMruT3pnPSN6d08Nm8d7xU/kL+G3ynwE6wSvMjwy1iV0ZHpl7k6s1MYICwTdonYog2iN1nhWVuyPmRHZ+/K7s9Jytmfq5ablntUrCPOFp+eYjJl+pRWiYOkWNI21Wfq2qnd0gjpThkimyirz9OFh/rLclv5QvnjfP/8ivzeaYnTDk3Xni6efnmG/YwlM14UhBb8PBOfyZvZPMts1vxZj2ezZm+bg8xJn9M812Ju0dz2eWHzds+nzM+e/1uhc+Gqwr8WJC1oKDIumlf0dGHYwupijWJp8e1Fvou2LMYXixa3LHFdsn7J1xJ+ycVS59Ky0s9LeUsv/jTqp/Kf+pdlLGtZ7rF88wriCvGKWysDVu5epb2qYNXT1WNX165hrilZ89fayWsvlLmVbVlHWSdf11YeWV6/3nL9ivWfNwg33KwIqti/0Wjjko0fNvE3XdscuLlmi/GW0i2ftoq23tkWtq220rqybDtxe/725zsSd5z72evnqp2GO0t3ftkl3tW2O3b36SrPqqo9RnuWV6PV8urOvRP2Xt0XvK++xrFm237G/tID4ID8wMtf0n65dTDiYPMhr0M1h60ObzxCP1JSi9TOqO2uE9a11afUtx4dc7S5wbfhyK9Ov+5qNGusOKZ3bPlxyvGi4/0nCk70NEmauk5mnnzaPLn5/qnkUzdOjzvdcibizPmzoWdPnWOdO3He73zjBZ8LRy96Xay75HGp9rL75SO/uf92pMWjpfaK55X6q95XG1pHtx6/FnDt5PXg62dvcG5cuhl1s/VWwq07tyfcbrvDv9NxN+fum3v59/ruz3tAeFDyUOth2SOjR5W/2/2+v82j7djj4MeXn8Q9uf+U9/TVM9mzz+1Fz2nPy16YvqjqcOlo7AztvPpy/Mv2V5JXfV3Ff2j/sfG17evDfwb+ebk7ubv9jfRN/9ul7wze7frL7a/mnpieR+9z3/d9KOk16N390evjuU9Jn170TftM+lz+xe5Lw9eIrw/6c/v7JVwpd+AogMGGZmQA8HYXPCekAECH9zbKeOVdcEAQ5f11AIH/hJX3xQHxAKAGdopjPLsJgAOwWc+D3PBdcYSPDwSoq+tQU4ksw9VFyUWFNyFCb3//O2MASA0AfJH29/dt6u//sgMGexeApqnKO6hCiPDOsNVfgW7qJ28DP4jyfvpdjj/2QBGBG/ix/xcHLJA+I+gi8gAAAIplWElmTU0AKgAAAAgABAEaAAUAAAABAAAAPgEbAAUAAAABAAAARgEoAAMAAAABAAIAAIdpAAQAAAABAAAATgAAAAAAAACQAAAAAQAAAJAAAAABAAOShgAHAAAAEgAAAHigAgAEAAAAAQAAAFSgAwAEAAAAAQAAAHYAAAAAQVNDSUkAAABTY3JlZW5zaG90FQE5qAAAAAlwSFlzAAAWJQAAFiUBSVIk8AAAAdVpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IlhNUCBDb3JlIDYuMC4wIj4KICAgPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4KICAgICAgPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIKICAgICAgICAgICAgeG1sbnM6ZXhpZj0iaHR0cDovL25zLmFkb2JlLmNvbS9leGlmLzEuMC8iPgogICAgICAgICA8ZXhpZjpQaXhlbFlEaW1lbnNpb24+MTE4PC9leGlmOlBpeGVsWURpbWVuc2lvbj4KICAgICAgICAgPGV4aWY6UGl4ZWxYRGltZW5zaW9uPjg0PC9leGlmOlBpeGVsWERpbWVuc2lvbj4KICAgICAgICAgPGV4aWY6VXNlckNvbW1lbnQ+U2NyZWVuc2hvdDwvZXhpZjpVc2VyQ29tbWVudD4KICAgICAgPC9yZGY6RGVzY3JpcHRpb24+CiAgIDwvcmRmOlJERj4KPC94OnhtcG1ldGE+Cq2ySFAAAAAcaURPVAAAAAIAAAAAAAAAOwAAACgAAAA7AAAAOwAABbPi/8ljAAAFf0lEQVR4AeycWSh9XRTAl7/iQWYZEiXEgyfyYCqzouRZGTKLIg/ImOHFkCeZyVyGByEiQ8mDmeTBkFkhJA8i4f996xR9dPc+d9j3nnO+znq596y1zr57/+yz9trDoff3XwFZmBHQk4EyY8kVJANlyxNkoDJQxgQYFyf3UBkoYwKMi5N7qAyUMQHGxck9VAbKmADj4uQeKgNlTIBxcXIPlYEyJsC4uP9tD/38/IQ/f/4wxsVfnKSBvr29weXlJZydncHp6SmcnJzA0dER7O/vQ0xMDFRVVfETYOwhCaD39/dwcXHBAUNox8fHcHBwwOlIPDIyMiA/P59k1ppetECbmppgcXGR623Pz88qA+jq6oLAwECV79P0BtECLSwshOHhYbXbt7OzAyYmJmrfr+6NogWKQFZXV8HR0RHMzMzg9fUVdnd3oaOjA/h6rIeHB4yPj6vLRKP7RAuU1KqRkREoKCggmTm9UPETf1xyQKempiA7O5sKVKj4KUmgNTU10NraSgW6vb0NpqamVB9tGSXXQyMjI7mRnwREyPiJdZIU0MfHR/Dy8iKx5PRCxk/JAZ2bm4O0tDQq0M7OTggKCqL6aNMoqR5aXV0NOODQRMj4ifWSFNCIiAhurk4CKnT8lBTQh4cH8Pb2JrHk9Onp6bw5KrUABkbJ9NCZmRnIzMykNlno+ImVkwzQyspK6O7upgLd2tripqlUJy0bJQM0JCSEW/Mk8XB3dwecRQktkgB6e3sLPj4+VFaYTuEKldAiCaDKzN9xFSo4OFhontKIoWVlZdDf30+FJYb4iRWURA/FlXfcAiGJWOKnJIDe3NyAr68viSWnT0lJgaKiIqqProyi76ETExOQk5ND5dHe3g6YBYhBdAIU98gPDw9hbW2N2/K9u7sDnPno6emBvb092NnZcZ84qFhZWf3gUlpaCgMDAz90vy82NzfB3Nz8t1qQa60Cvbq64gYTBMK3D/TV+ujoaMjLy+P2klCHjzs+9iQRU/zEOmoFKAKora2FsbExEgeq3tLSEoaGhsDQ0BACAgKovsnJyVBcXEz10aWRKdCPjw8YHByE8vJyjduAUPGgAt+GXFtbG4SGhmr8e6wKYAb05eWFe1RxEYMm+IjGxcVxSbi1tTXgcRo8SoOHGrBX/1eMjIx4Q4WY4ifWnQnQp6cnwNQFG0eT3NxcyMrKAn19fYVumJwnJCTwQvy62dXVFfj+gF++uvrUGCjGS4SAh7RIYmtrC42NjeDp6Uly+dY3NDRwvt8KypekpCQoKSmheOjepBFQhBgbG8ulQKSq4yo6jvLGxsYklx/66+tr8PPz+6EjXeB2clhYGMksiF5toJhL4pYu5pMkwYFlcnISbGxsSC4K9XxLdV83bWxsgIWFxdelKD7VAoqjOQ4sKysr1EZMT0+Dm5sb1UeRMT4+HpaXlxWZvnVijJ9YObWA1tXVQXNz83fjFH3p6enhzSEV3Ye6xMREWFpaIpk5vRjjJ1ZMZaDz8/OQmpqq1cbi3B3n8DRpaWmB8PBwmosgNpWA4hJaVFQUNa3BuLmwsKD0IKSo1cr00PX1dcDfEpuoBFSZ2IbpEQ5WmgjO5/f29ohFiDV+YoWVBoozGZw308Tf3x96e3tpLkrZcP+dlj2INX5i45QC+v7+DnhqA9+0oMns7Cy4uLjQXHht+E96nJ2dqX44IGJ9xChKAe3r6+Nd8MAG8o38ygA4Pz/nPeyF66q/102VKVsXPrxAcZ6OjzLfeubo6KhSU0u+RvGt0Ds5OQFmGmIVXqD19fWAr7jQBM9s4tl3FlJRUQGYw5IEMwDcBdWW4KQF34UyMDAABwcHld/GowLFNy9wgODrnSzXJPlOKGszfv5+IQLfQMGsBdcjlJV/AAAA///T9NmZAAAIBklEQVTtWwdoFksQnmABe0RsWEBUVOyIFRGVqDEqtkiw94YKFjRij4qJRk3sGBM1ghixi13sHbGgqNgrRsQKFrC99757nNx/W6/kPeFuILn/ZmZn777bm52Z3Yv66x8iAe3Zs4cmTJggkP7LLleuHJ05c4by5csn1dMRfvr0ierVqydVvXTpEpUuXVqq40Z47tw56t+/P9O0VKlSdOjQIcJRh6JkgPbs2ZOuXbsmtTNq1CiaMmWKVEdXeOLECRo6dKhQvUqVKnTs2DGh3Itg5MiRdPToUa6JpKQkLtg8ZSGgt27doi5duvDaRPAwiuvWrRvBc3siuynYHDhwIM2ePduteWm71q1b07Nnz7g6o0ePpsmTJ3NldqYQ0JkzZ9LmzZvt+hHneN3xqkRFRUXw3Zy8fPmSWrZsKW26evVqio2Nleq4FQ4aNIhOnz7Nbe4Z0J8/f1KDBg3o8+fP3A5M5rhx45Q+1tRVHZcvX07p6elStYsXL1KZMmWkOm6FmzZtojlz5nCb79y508CDK7QxuSP05s2b1LVrV5sqe7pr1y6qX78+K3DI+fHjBzVv3pzevn0rbJmX/hOd/vr1ixYsWEDr16+PuIZFixZRfHx8BE92wgV07dq1tHDhQlk7Q3b37l0qUKCAUk+lcOTIEcLkJqMBAwYIR5CsnVPZx48f6fbt28Z91ahRg4oVK+bIBBfQPn36EF4vGTVu3Ji2bt0qU9GWyfyXaWTVqlXUsWNH8/SPPTKAfvnyherUqaO84LFjx9LEiROVeiqFO3fuUKdOnVRqdOHCBSpbtqxS7/9WYAC9evWqls/IysqiNm3aeLp+5BR9+/ZVvg157T893YStMQPowYMHacyYMTY19vTkyZNUuXJlVuCAc/jwYUJIoqL/yn+qrkNHzgC6YcMGmjdvnrLtjRs3qGjRoko9kQJCsnbt2tGrV69EKr/5K1eupLi4uN/nefUDE9KLFy/o+fPnxl+PHj20U07zmhhAU1JSKCMjw5QLj48ePRLKdARIV7dv366j6pv/hItBaAbAANzTp0+N7Ojhw4d07949Ju5etmyZVrZovQkG0PHjx9PevXutOsxvZEjnz59n+LoMnaKLaQtuBe7FD9JJHqz9IAssX768laX8zQCKmXv37t3ShkWKFCEE/24IsauT8Kdfv340d+5cpqsHDx5QoUKFqEKFCoxMxDh+/DghI6pevbqRLu/bt0/octw+SAbQ+fPnM9kC7wLdlNHwiiHrkGVE9r54/vP9+/fUvn17I/jGw3ebjp46dYoGDx5s79I4R/ShM5fYGzOAogCxePFiux5zvmXLFmratCnDFzFyc3MJ5UCdSchqA64FLsYk1BlGjBhBKPWBduzYQQ0bNjTFjo7Xr18nTDw8gnvo3LkzTyTlMYDm5OTQtGnTpI0gbNWqFW3cuFGpBwVkXcOHD49w+giF8PrJiPfaoTaZnZ1tNBs2bJjWtYr6wOSLSZhHbhMJBlBVkdfauWoW/PbtGyEBSE1NtTajbt26UUJCAvXu3TuCbz+xvnYoXqC/FStWGGqo7G/bts1TLUGU8npJJBhAER86KRijqIE0tHDhwr/xwFIGbhbuw+4vUVVCrAs5aq4ywpuCUfjhwwdDd//+/YY6JsUDBw5QpUqVZM2lMjzsmjVrcnW8JBIMoOhBVTnnXQX8WHR0NCGmE1W+URVHkQOzs04IA+Bw01euXInoEoVvPBgvBJu9evXimvBSiOECijrnpEmTuJ25ZXbo0MF4ZQsWLGiYQCik64OtfWZmZlLbtm2tLFe/ZZOvmwjGvAguoAhLGjVqZOp4PuK1TUxMjFgZxQPDg3NCbmdeXh/wz5h47OTFf8IWF1AI1qxZw0wm4DshvLJLliwxYkZ7Oyw3qGZ5axvY6d69u5Xl+vfXr1+pdu3a3PaYqGbNmsWV6TCFgGJZAk/x8uXLOnYYHdQ4MamIUjfEsdOnT2fa2RkYMQjua9WqZRe5PscrLYowMJDgntySEFAYxJNEKooymy4hPkVJThX0I5po1qxZRGxq7wMPFA8Fk5ifhNArLS2NaxIDSHdTA8+AFFA0QIXm7NmztG7dOuPIM4IZHhMFlnirVq3KU+HykIrigdk3U2B0YxdHkyZNuO28MkVLPMjxnQwe3nUoAbU2QnD9+vVrevPmjRF3Iof2UhM1bWPZ5fHjx4YtFDvy589vinw/yvznkCFDaMaMGZ76dASop57+kMYy/4lUNCYmxtOVBg5QTHBLly7lgoZgv2TJklyZLjNwgIriT2RkSGe9UqAAleXvKAlOnTrVK57iwN6z5T/QAKIJ1GR55MeyOOwGaoQi9EtOTubhaYRuJUqU4MqcMAMFqKiKhp0yqoVJXVADAyhiaOwU5G3RtO/CRqyKhMZa4w0BtSGAVVIs7PEIWxhRqwUBTBSYnzx5YlTDKlasaPB1/wVmhGJ1VLS5DYt1xYsXJxSEsA0Je+2dfqxgAh4YQEUFbTN///79u7GP3vSlbjcTBwZQLAqKSpGYrLAJ4v79+8ZAQyaFhUQ3FBhAsUHYvmDIAwxfmeBrE7cUGEBbtGih3GSBZRqMVi8UGEBVnwkh4Idb8EqBARRf4GH3ip1QFMHiX7Vq1ewiV+eBARToIHRCRf7du3fG7musMqD+6ceXLCb6gQLUvOm8PIaA+oxuCGgIqM8I+GwuHKEhoD4j4LO5cISGgPqMgM/mwhEaAuozAj6bC0doCKjPCPhsLhyhIaA+I+Czub8BIXrU+VtRk5YAAAAASUVORK5CYII="/>
<image id="image1_1_28" width="590" height="142" xlink:href="data:image/png;base64,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"/>
<image id="image2_1_28" width="580" height="130" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAkQAAACCCAYAAACnztfaAAAMamlDQ1BJQ0MgUHJvZmlsZQAASImVVwdYU8kWnluSkJDQAhGQEnoTRHqREkKLICAdbIQkkFBiTAgqdkRUcO0iihVdFVF0LYAsKmIvi2LviwUFZV3URVFU3oQEdN1Xvne+b+7898yZ/5TM5M4AoNnLlUhyUC0AcsV50tiwIGZySiqT9AIgAAMk4AtMuDyZhBUTEwmgDPZ/l/e3oDWU644Krn+O/1fR4QtkPACQCRCn82W8XIibAMA38iTSPACICr3FtDyJAs+DWFcKA4R4jQJnKvFuBU5X4sYBm/hYNsRXAVCjcrnSTAA0HkA9M5+XCXk0PkPsLOaLxABojoDYnyfk8iFWxD4iN3eKApdDbAvtJRDDeIBX+necmX/jTx/i53Izh7AyrwFRCxbJJDncGf9naf635ObIB31Yw0YVSsNjFfnDGt7JnhKhwFSIu8TpUdGKWkPcK+Ir6w4AShHKwxOU9qgRT8aG9QMMiJ353OAIiI0gDhXnREWq9OkZolAOxHC1oNNFeZx4iPUhXiyQhcSpbLZKp8SqfKG1GVI2S6U/z5UO+FX4eiTPTmCp+N8KBRwVP6ZRIIxPgpgCsWW+KDEKYg2InWTZcREqm9EFQnbUoI1UHquI3xLiWIE4LEjJj+VnSENjVfYlubLBfLGtQhEnSoUP5gnjw5X1wU7zuAPxw1ywqwIxK2GQRyBLjhzMhS8IDlHmjnUIxAlxKp5eSV5QrHIuTpHkxKjscXNBTphCbw6xmyw/TjUXT8yDi1PJj2dI8mLilXHiBVncMTHKePAVIBKwQTBgAjls6WAKyAKilq66LvimHAkFXCAFmUAAHFWawRlJAyNi+IwDBeAPiARANjQvaGBUAPKh/suQVvl0BBkDo/kDM7LBc4hzQQTIge/ygVniIW+J4BnUiP7hnQsbD8abA5ti/N/rB7XfNCyoiVRp5IMemZqDlsQQYjAxnBhKtMMNcX/cF4+Ez0DYXHAv3Hswj2/2hOeEVsITwk1CG+HuZFGh9Icox4I2yB+qqkX697XArSGnOx6E+0F2yIwzcEPgiLtBPyw8AHp2h1q2Km5FVZg/cP8tg+9+DZUd2ZmMkoeRA8m2P87UsNdwH2JR1Pr7+ihjTR+qN3to5Ef/7O+qz4d9xI+W2GLsEHYOO4ldwBqxOsDETmD12GXsmAIPra5nA6tr0FvsQDzZkEf0D39clU9FJWXO1c6dzp+VY3mC6XmKjceeIpkhFWUK85gs+HUQMDlintMIpouziysAim+N8u/rHWPgG4IwLn7TFT4EwC+lv7+/8ZsuEu7fwx1w+3d909lUA0A7DsD5hTy5NF+pwxUPAvyX0IQ7zQCYAAtgC/NxAR7wmxYIQsAYEA3iQQqYBKsshOtcCqaBWWA+KAalYAVYCzaALWA72A32gYOgDjSCk+AsuASugpvgPlw97eAV6AbvQR+CICSEhtARA8QUsUIcEBfEC/FHQpBIJBZJQdKQTESMyJFZyAKkFFmFbEC2IVXIL8hR5CRyAWlF7iKPkU7kLfIJxVAqqosao9boSNQLZaERaDw6Ec1Ep6IFaBG6DC1HK9G9aC16Er2E3kTb0FdoDwYwdYyBmWGOmBfGxqKxVCwDk2JzsBKsDKvEarAG+Dtfx9qwLuwjTsTpOBN3hCs4HE/AefhUfA6+FN+A78Zr8dP4dfwx3o1/JdAIRgQHgg+BQ0gmZBKmEYoJZYSdhCOEM3AvtRPeE4lEBtGG6An3YgoxiziTuJS4ibif2ERsJT4l9pBIJAOSA8mPFE3ikvJIxaT1pL2kE6RrpHZSr5q6mqmai1qoWqqaWK1QrUxtj9pxtWtqL9T6yFpkK7IPOZrMJ88gLyfvIDeQr5DbyX0UbYoNxY8ST8mizKeUU2ooZygPKO/U1dXN1b3Vx6mL1Oepl6sfUD+v/lj9I1WHak9lUydQ5dRl1F3UJupd6jsajWZNC6Sl0vJoy2hVtFO0R7ReDbqGkwZHg68xV6NCo1bjmsZrTbKmlSZLc5JmgWaZ5iHNK5pdWmQtay22FldrjlaF1lGt21o92nTtUdrR2rnaS7X3aF/Q7tAh6VjrhOjwdYp0tuuc0nlKx+gWdDadR19A30E/Q2/XJera6HJ0s3RLdffptuh26+nouekl6k3Xq9A7ptfGwBjWDA4jh7GccZBxi/FpmPEw1jDBsCXDaoZdG/ZBf7h+oL5Av0R/v/5N/U8GTIMQg2yDlQZ1Bg8NcUN7w3GG0ww3G54x7BquO9x3OG94yfCDw+8ZoUb2RrFGM422G1026jE2MQ4zlhivNz5l3GXCMAk0yTJZY3LcpNOUbupvKjJdY3rC9CVTj8li5jDLmaeZ3WZGZuFmcrNtZi1mfeY25gnmheb7zR9aUCy8LDIs1lg0W3RbmlqOtZxlWW15z4ps5WUltFpndc7qg7WNdZL1Ius66w4bfRuOTYFNtc0DW5ptgO1U20rbG3ZEOy+7bLtNdlftUXt3e6F9hf0VB9TBw0HksMmhdQRhhPcI8YjKEbcdqY4sx3zHasfHTgynSKdCpzqn1yMtR6aOXDny3Mivzu7OOc47nO+P0hk1ZlThqIZRb13sXXguFS43XGmuoa5zXetd37g5uAncNrvdcae7j3Vf5N7s/sXD00PqUePR6Wnpmea50fO2l65XjNdSr/PeBO8g77nejd4ffTx88nwO+vzp6+ib7bvHt2O0zWjB6B2jn/qZ+3H9tvm1+TP90/y3+rcFmAVwAyoDngRaBPIDdwa+YNmxslh7Wa+DnIOkQUeCPrB92LPZTcFYcFhwSXBLiE5IQsiGkEeh5qGZodWh3WHuYTPDmsIJ4RHhK8Nvc4w5PE4Vp3uM55jZY05HUCPiIjZEPIm0j5RGNoxFx44Zu3rsgyirKHFUXTSI5kSvjn4YYxMzNebXccRxMeMqxj2PHRU7K/ZcHD1uctyeuPfxQfHL4+8n2CbIE5oTNRMnJFYlfkgKTlqV1JY8Mnl28qUUwxRRSn0qKTUxdWdqz/iQ8WvHt09wn1A84dZEm4nTJ16YZDgpZ9KxyZqTuZMPpRHSktL2pH3mRnMruT3pnPSN6d08Nm8d7xU/kL+G3ynwE6wSvMjwy1iV0ZHpl7k6s1MYICwTdonYog2iN1nhWVuyPmRHZ+/K7s9Jytmfq5ablntUrCPOFp+eYjJl+pRWiYOkWNI21Wfq2qnd0gjpThkimyirz9OFh/rLclv5QvnjfP/8ivzeaYnTDk3Xni6efnmG/YwlM14UhBb8PBOfyZvZPMts1vxZj2ezZm+bg8xJn9M812Ju0dz2eWHzds+nzM+e/1uhc+Gqwr8WJC1oKDIumlf0dGHYwupijWJp8e1Fvou2LMYXixa3LHFdsn7J1xJ+ycVS59Ky0s9LeUsv/jTqp/Kf+pdlLGtZ7rF88wriCvGKWysDVu5epb2qYNXT1WNX165hrilZ89fayWsvlLmVbVlHWSdf11YeWV6/3nL9ivWfNwg33KwIqti/0Wjjko0fNvE3XdscuLlmi/GW0i2ftoq23tkWtq220rqybDtxe/725zsSd5z72evnqp2GO0t3ftkl3tW2O3b36SrPqqo9RnuWV6PV8urOvRP2Xt0XvK++xrFm237G/tID4ID8wMtf0n65dTDiYPMhr0M1h60ObzxCP1JSi9TOqO2uE9a11afUtx4dc7S5wbfhyK9Ov+5qNGusOKZ3bPlxyvGi4/0nCk70NEmauk5mnnzaPLn5/qnkUzdOjzvdcibizPmzoWdPnWOdO3He73zjBZ8LRy96Xay75HGp9rL75SO/uf92pMWjpfaK55X6q95XG1pHtx6/FnDt5PXg62dvcG5cuhl1s/VWwq07tyfcbrvDv9NxN+fum3v59/ruz3tAeFDyUOth2SOjR5W/2/2+v82j7djj4MeXn8Q9uf+U9/TVM9mzz+1Fz2nPy16YvqjqcOlo7AztvPpy/Mv2V5JXfV3Ff2j/sfG17evDfwb+ebk7ubv9jfRN/9ul7wze7frL7a/mnpieR+9z3/d9KOk16N390evjuU9Jn170TftM+lz+xe5Lw9eIrw/6c/v7JVwpd+AogMGGZmQA8HYXPCekAECH9zbKeOVdcEAQ5f11AIH/hJX3xQHxAKAGdopjPLsJgAOwWc+D3PBdcYSPDwSoq+tQU4ksw9VFyUWFNyFCb3//O2MASA0AfJH29/dt6u//sgMGexeApqnKO6hCiPDOsNVfgW7qJ28DP4jyfvpdjj/2QBGBG/ix/xcHLJA+I+gi8gAAAIplWElmTU0AKgAAAAgABAEaAAUAAAABAAAAPgEbAAUAAAABAAAARgEoAAMAAAABAAIAAIdpAAQAAAABAAAATgAAAAAAAACQAAAAAQAAAJAAAAABAAOShgAHAAAAEgAAAHigAgAEAAAAAQAAAkSgAwAEAAAAAQAAAIIAAAAAQVNDSUkAAABTY3JlZW5zaG90pv7SnwAAAAlwSFlzAAAWJQAAFiUBSVIk8AAAAdZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IlhNUCBDb3JlIDYuMC4wIj4KICAgPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4KICAgICAgPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIKICAgICAgICAgICAgeG1sbnM6ZXhpZj0iaHR0cDovL25zLmFkb2JlLmNvbS9leGlmLzEuMC8iPgogICAgICAgICA8ZXhpZjpQaXhlbFlEaW1lbnNpb24+MTMwPC9leGlmOlBpeGVsWURpbWVuc2lvbj4KICAgICAgICAgPGV4aWY6UGl4ZWxYRGltZW5zaW9uPjU4MDwvZXhpZjpQaXhlbFhEaW1lbnNpb24+CiAgICAgICAgIDxleGlmOlVzZXJDb21tZW50PlNjcmVlbnNob3Q8L2V4aWY6VXNlckNvbW1lbnQ+CiAgICAgIDwvcmRmOkRlc2NyaXB0aW9uPgogICA8L3JkZjpSREY+CjwveDp4bXBtZXRhPgp1iFblAAAAHGlET1QAAAACAAAAAAAAAEEAAAAoAAAAQQAAAEEAABuMAK97jgAAG1hJREFUeAHsnQn4DdX/x49SpKSkRyQRUUQppUVSydJiiSKlZEultCrRoiSERIWEFClaUEgKlYSEaLEkpadSUqFFUv1/r3ma73/u3Nm3O5fP53m+z71z5sw5n3nP986853M+S6F//ydKRBAQBAQBQUAQEAQEgT0YgUJCiPbgqy+nvscjMGnSJLV06VJLHMqXL6+6d+9uuU8aBQFBQBDY3RAQQrS7XVE5H0HAIwKLFi1Sbdu2dezdr18/1aZNG8c+slMQEAQEgd0BASFEu8NVlHMQBHwisGXLFtW4cWPFp5vMnDlTHXPMMW7dZL8gIAgIAnmNgBCivL58orwg4B+Bf/75R3Xq1EnNnz/f08EVK1ZU06dPV/vvv7+n/tJJEBAEBIF8REAIUT5eNdFZEAiBwKhRo9SAAQN8jdC8eXM1ZMgQX8dIZ0FAEBAE8gkBIUT5dLVEV0EgJALLli1TrVq1CjTKQw89pFq3bh3oWDlIEBAEBIG0IyCEKO1XSPQTBCJC4JdfflHnn3++2rRpU+ARxZ8oMHRyoCAgCKQcASFEKb9Aop4gEAUCpBvr2rWrmjNnTqjhxJ8oFHxysCAgCKQYASFEKb44opogEBUC48ePV3369LEdDodp+hxyyCGqQ4cOasOGDbZ9W7RooQYPHmy7X3YIAoKAIJCPCAghyserJjoLAj4QWLVqlWrWrJntEVh9xo0bp0jEiGzdulXdcMMNasGCBbbH4JR9ySWX2O6XHYKAICAI5BsCQojy7YqJvoKADwS2bdummjZtqjZu3Gh5VN26ddXw4cNViRIlMvbv2rVLsyhNnDgxo924MWvWLFW1alVjk3wXBAQBQSBvERBClLeXThQXBNwRwNIzY8YMy46XXXaZRnoKFy5suZ/GsWPHqr59+1rux7L06quvqmLFilnul0ZBQBAQBPIJASFE+XS1RFdBwAcC1Cnr1auX5RE9e/ZUnTt3ttxnbpw3b57q2LGjuVnbbtmypXr44Yct90mjICAICAL5hIAQony6WqKrIOARgdWrV2sh9lbdR44cqRo2bGi1y7aN8XC2tgrZHzhwYODcRrYTyg5BQBAQBBJGQAhRwoDLdIJA3Aj8/vvv6qKLLsqKFCOCDOfp4447LpAKP/zwg+rSpYtauXJl1vGzZ89WRx99dFa7NAgCgoAgYIcAudFWrFihfvzxR/XTTz8ptvfbbz9VpkwZdeihh6qyZcuqypUrq0KFCtkNEWm7EKJI4ZTBBIHcI3D77berl156KUMRirOOGTNGu9Fk7PC58ccff6gePXpk+SWJP5FPIKW7ILCHIsA9ZPLkyeq1115TH374oSsKRL+SXZ+XvCOPPNK1f5gOQojCoCfHCgIpQ+DFF1/UCItRrXPPPVcNHTo0suKsFIclMu3RRx81TqPdtFg+ExEEBAFBwIwA940pU6aoQYMGqS1btph3e9q+9tprVffu3dW+++7rqb/fTkKI/CIm/QWBlCKwfft2dfzxx2doh98PDtR77713RnsUG0SYcXMyCm3Vq1c3Nsl3QUAQ2MMRwCp05513alGpYaHA2s3LWBxL9EKIwl4dOV4QSAkClOf4888/M7QpWrRoxnbUGzt37lS8+ekS93z6PPIpCAgC+YEA96S2bduq5cuXR6YwmfXJg1auXLnIxmQgIUSRwimDCQKCgCAgCAgCgoCOAEtkTzzxhL4Z2SeWInwlccKOSoQQRYWkjCMICAKCgCAgCAgCBQjYlQ3CwnPSSSepChUqqMMPP1wRGbtu3Tr12WefZUXHFgxm8aVNmzaqX79+FnuCNQkhCoabHCUICAKCgCAgCAgCNgiwnE5kGETHKPgdkhTWLsM9/kZPPvlkVtCGcQzj9/fff1+VLl3a2BT4uxCiwNDJgYKAICAICAKCgCBghQCRrcOGDSvYhRM0qT+8+v2sX79e3X333WrRokUFY1h9ueWWW1S3bt2sdvluE0LkGzI5QBAQBAQBQUAQEATsEGAJzJgAliUy8g75zSP0999/K5bFnPIVkXB2yZIlkSRvFEJkd0WlXRAQBAQBQUAQEAR8IzB37lzVqVOnguMoEl2/fv2CbT9f1q5dqxo3bux4CISoVKlSjn287BRC5AUl6SMICAKCgCAgCAgCnhBgqWvixIla32uuuUbdcccdno6z6/TII49oyWDt9k+dOlXVrFnTbrfndiFEnqGSjoKAICAICAKCgCDghAB5yerUqaNlo2apbMGCBapEiRJOh7ju+/XXXx0Jz+OPP66aNGniOo5bByFEbgjJfkFAEBAEBAFBQBDwhMDHH3+smjZtqvW97bbb1HXXXefpOLdOp59+utq0aZNlt759+2rJHy13+mgUQuQDLOkqCAgCgkCcCPz1119q4cKFllMccMABWu4Wy53SKAikBIHHHntMDRkyRNNm6dKlqmTJkpFoRqj+W2+9ZTnWiBEjVKNGjSz3+WkUQuQHLekrCAgCgkCMCJB/pX///pYzkJl35syZlvukURBICwLz5s3Tqtnz/2qudRhGx4cfflhBfKxk2rRpqkaNGla7fLXlhBDt2LFDq76N+YtcBbkSEjrBZkkgxWdUyZ1ydT4yryBghwDJzqgQHUeRV0JskSJFisQyvt05Gdupk9SnTx917733qlq1ahl35dV3ilbyZyVCiKxQyW0boeTjx49XvXv3ziqsnKRmX3zxhaISPMtTzZo1S3LqxOYaN26ceuCBByzn++CDDxTh92ElcULE+iKsccOGDZruEyZMUKwNJimAh9e6MeHT66+/rqpUqZKkGjKXIBAZApASSAH/219++aX66aef1I8//qg2b96sOTfqE3HTIFV+mTJltBcAXgJ40JJG/8ADD9S7ef5cs2ZNgTNjLird6y8zvNAgnMeUKVM865+2jkKI0nZF7PXZuHFjRig50VQ33nhjpLW17Gf//z3k6iEj9OrVq7XGs88+W+FTw298dxKW4fTfufm8SOJYqFAhc7Pv7cQI0a5duzRzF0TEKNy8uIklITwwmB+vd7MIITIjIttpR4C3QkgI/89Oicu8ngeWlXr16qlTTjlFnXjiiZrFx+1Ywml1AsINGStUUsJ8ZKnVHwTMy8OAbLj5KkKI8ufK8eIBEfntt98KlK5YsaIaPXq0Ouqoowra4v7CS8Gll16qVq5cmTEVepx77rkZbfm8ceutt6pXXnkl6xQ4R841CkmEEMHeOBnzBXv++ee1m28UJ+I0BvOyNDd//nzbbkKIbKGRHSlDACvrqFGj1IwZM2LV7IILLlANGzZUdevWVQcffHDWXOT+gJAgp512WkHekayOETfwRgzpMfvaoO/gwYMTJWURn5q2XCZLZlGjGt94X331lbrqqqsU1iKjJE1GsBCz8mJ2Or7pppu0shZ77bWXUb28/N66dWvNAm5WHr+7Bg0amJsDbcdKiP7991/17LPPqvvuuy9DOXITQIaqV6+e0R71xieffKIRIfM/idU8QoisUJG2NCHAzZeEZ1YWzrj1JOkZS2vUI4IcLV68uMAyxNw333yzuuGGG+JWQ3vw8HJltohdfvnl2n0mDh+p2E/KMIFYiAxg5MlXlqeJgGIFwihJkxFeFHjW6gkRdV2woLDcVLx4cb0p7z7hEliut2zZkqE7LgD4AhcuXDijPehGbITI7uIcdthh6rnnnlMVKlQIqrPrcZjQubHMnj3bta/eQQiRjoR8phEBoouCFDCEyFSqVEmrIVS2bFn1559/ajcV/Isw+UdFrrgJYyWKU7CMXXbZZRlLFMyHIykkKQofgjj19zK2ECIvKKWvD0ELWEvNzxzICFbLIP55Qc9y5MiRauDAgRmHs5SHVbly5coZ7fmysWzZMtWqVassdXEkv/3227PagzbEQoi46XKDMoeIclG4cUKK4pB169Zp1XWDLCUIIYrjisiYYREgL82DDz6onnnmGc9D8dbUrl07hYnZLXKSDLC8Yb355psZFh/Pk/3XEbJSrFgxv4d57k8ARNu2bbP69+rVS3Xs2DGrPV8bhBDl65VTCiMAzsxEnRkFyypGgIMOOsjYHOt3fAvNIe+szEyaNCmj6GqsSkQ4OJYvq3vgO++8o8qVKxfZTJETIm6weNtzkzUKN2kuUhxkCOdSvM/xaQgqQoiCIifHxYUAZmKcll988UVPU/DbuuuuuzS/nyDOzSzJkevD/CLjNjlWqDC/Pbfx33jjDdW1a9esbkkt02VNHGODEKIYwU1gaLvfLJXfcR8JW8LCzylw3+jRo0fGIZAigiAgafkiGFhq166dZRm+8847VZcuXSI9jUgJEWup7du3V7wtGoWL8PLLL2v+B8b2sN+5gVPDxOsDw2k+IURO6Mi+XCAwfPhwLSrSy9yY5gcNGhTJDfe9997TCIgxesZJB8iK+cbr1N/PPm7eVoUh8Rmyy0niZ/y09RVClLYr4l8frLr4FGG9MAovDpCiJH15rO4hPI9feumlvEkzM2fOHM3IYsQSQjd9+vTIfIf0sSMjRN9884268sorC/IL6RPw+cILL6iTTz7Z2BT6+1NPPaX69euXMU758uW1pFTVqlXT2CR9jCG5GZ1NG0KITIDIZk4RmDVrlrr++us96UCoOZEWUToU87th2c3sxGilEBFf6BC1WPlCMAfkj31Rnm/UugcdTwhRUOTSdRwrJYTCm58/pJh5+umnFaQkCcFixbIyQUxGYX5C2NPuU8QyZMuWLbMi1CFDWN2ilkgI0c8//6wIebUqvBZVFVrziePAhpmeZYI2bdpodUyqVq2a0W3r1q1aOJ6Xm7oQogzoZCOHCBBCe9ZZZ3kiI7wEsBQdx1snFtgLL7wwy1RthoaIL6uwfHM/P9tjx47V/DHMx/CWjT9GnP5K5jmT3BZClCTa8c71/fffqxYtWmQ9F0899VTNz2ifffaJV4H/RodUsLRESQ2j4MbCM5RErWkVfI6JrDUKLjlWVmNjn6DfQxMiwL766qsto1UIOyRzZxzCxYXlsrbolGNhwIABmne9mw5CiNwQkv1JIfDEE09oy19e5iOChZtuXGLlnGmcizB8c2SNcX+Q7/gfsiRmFn7v/O5LlSpl3pX4NsuJ+DAceeSRkUa4CSFK/FLGOiEWovPPPz9rjg4dOmjlPrJ2xNTASxZ6mPMl8YIxefLkVObuglCaI1fjJpOhCRHhfZivzQLQ+PZElR/APL7Xba9LD0KIvCIq/eJE4JdfftGyRHuZgzc8/H2COFB7GV/vQ7QKxMhKSEpH/bCohKX3xo0bW1qlokzAFlZf3TeDa0C5lKhECFFUSKZnHP1/xawRgUBWZMncL6ptu0hNXF2I4kqbkNfMGDFOlDq+yHE6pociRE65UXCEIv9JrsXubdOslxAiMyKynQsEMGHr2Z/d5j/vvPM8WT/dxnHbTxSnXSbYKG/q5HIhVYA5KAP9LrnkEoW1Nw1CDieSxCFY57DSRSVCiKJCMj3j4GTN0jNpYcxCuosky3yw/GRO3IhO/N9RhiQtgiXYmE4D6zCFdLHIximBCZGdKRBlYZuwzjQIN9emTZu6qiKEyBUi6ZAAAiQZ5H/Ri3DDwGEyCWEusw8C82KhiqqIJAnWiH4xC36CLMvF4SdlnsvLtvGh8tBDD2kkzstxXvoIIfKCUv71WbVqlWUVepaccW5Oyidu+/bt6pxzzrH0T+Q3hj65Fl7AmjVrlmElZrWJ+opxSyBChLMyCpvXI1GWaDKSPzn59cR9UsbxhRAZ0ZDvaUaAfBvHHnusZxXjdC40K0EdQPwejAJRWbhwobEp8HeSrtmZ7SdMmKBOP/30wGNHeaAZh6gfIkKIorxa6RrLzr2EoCBzxHScmpv/h/W5WJLCxSTuJXh9PqtPArSwuhq5RZLWq0CEyFjh2nxSSVavN89ttS2EyAoVaUsjAkR1+QlfJ7IT/4QkBCfiGjVqZEwV1TIWJUR4a7USCstaZai16ht3Gzdrit3qUauY8T/66KNIX/6EEMV9FXM3/rZt29QJJ5xgqQCW0Vq1alnui6PRrlBqHMkOveq/c+dOLdWH0Scv6dUm34SIgql2a41JVrz2CrIQIq9ISb9cI7B06VItd4lXPXij81K42Ot4bv2aN2+ekQ+EN16r+kJu45j3U4/ILlItjhxm5vm9bGO9w0JmzMDfqFEjNWLECC+He+4jhMgzVHnZ0S7qmZw6LJ0llVvL7KNjBBOrL9bfJMUqw3cuMtH7JkSEwxpvCkbQWCqrU6eOsSnn34UQ5fwSiAIeEfAaEWkcjsCGpNLwU6eJ/EC6ROEQytsgb6tWQogtOYdyLaQWIYWIMeIFnYiuI8ouShFCFCWa6Rvr22+/VVg9rYSahRQvTkL++ecfRVDGhg0bsqbD4MH/YZJCvkJjcEKS/pHG8/RFiJxYJb5DvM2lTYQQpe2KiD52CLjl/LE6Lkk/Iqpl65FeLBetXLkyVIV5bspYnfiNWgnRMOY8JFb94mwjQqh3796WhW+nTZuWtYwYVhchRGERTP/xFD7HGmQWflOU+4g6yal5Hn3briwO+5P87ZFFmxqMupDhm2CFQoUK6U2JfXomRLt27dKyQVsxSrQdPXq0llI/Mc09TiSEyCNQ0i3nCHhNEWFWFCdJMlbHLSRww8cAicJ/yYkAYvXyW2Q26vMneISoPzuL+Nq1ayPPsyaEKOqrmL7xnNxOrrjiCnX//fcnovSOHTu0ICirmoUsx1NUOe4lPPM9gLxM/AbintcOYM+EyCqFtnHQTz/9VBUtWtTYlIrvQohScRlECQ8IfP3111rJDg9dM7pgRaFoZNyRnca8Y9y0uXkHFXIO1atXr8BB2TwOxWKtKtyb+8WxjT8DD4M+ffpklV3Q50N3alJFLUKIokY0neNRj8/OuAABL126dCKK47RsF7RAwmWCCOIS84pT/fr1tSTPuYxy80SIYJCs51sxScAiz8/QoUPjwi3UuEKIQsEnByeMgNON0kmVJPwPWCLC0RHhza569epOKjnuw6KMWdxOICS5KDy5fPlyLQSa+mxOEhdhi4MQLVmyJKselNO5Bd1HhKRuQdTHwBGd7ONhhJQLUWZDD6NLVMfaheAzPuWu8FlLQsykxDgnhWhZVotDzFmzmQtitt9++8UxnecxPREikiJxA7ATai+Rbj+NIoQojVdFdLJDYNiwYYFfLuJe98dHsGfPnprqZN0NatbGSfnMM8+0tb4kHT3HCZEMbsiQIZ6X6eKKfouDEDk99Oz+D4O0W5UxgcxYFf32Mz6+NSQ23J3ETAiM58b5Ll68OJFkjdQ4c6oaT6kMu1QBRp39fCdVhbH+IvOTa+zAAw/0M0xWX3wS27dvrxluCP4IUuLDEyFq2bKl4s3JTvhn5SKmUYQQpfGqiE52CFDLDLJgZ421O05vj+MGpo+Nbps3b9YSt4VJoU9263bt2unDZn3GWRRan4ycJ8uWLdOcWEldYFVWQe9r9YmOdtmFuSkHreEohCgb7d2REOGsX7Vq1eyT/a8lCYuvPrldFnr2Rx1xtmbNGi1Vh35/4+UH30TIdFjBbQBLIv8vpDApUqSI7yFdCRE3CvJt2Elca+l28/ltF0LkFzHpn2sExowZo7ghBhFuBkRthFnOCjKvn2OcisUyTpxJ6sgnBJmxy3vk5zys+oJ/mGSNcRAinMOxEuF8P336dCu1A7fxbDjjjDNU2bJl1aGHHpoVdcfLMqHm/H3++efa/PrD0G1SHOsJDa9du7b2kuDWP9/2m4uXGvUnSAKiHtQKaxzL7bubfzCRb+XKlXMbxnU/iWfJW6YnNiXXEb/1KEr/GB3Vu3TpkrV066rcfx1cCZFdIil9gm7dunkuRqkfk+SnEKIk0Za5okCA6A8yN4dZahg3blwgB+0o9Hcag2zP+As4Cb9ZO+uL03Fe9jnVYPRyvFufsG/UcRAio84QlLZt2wa2QBrHCpKYk4ch7hX6Q9E4nv6dFC64aLj9n+j98/XTjYgkVbIGq02TJk1sYeQFhr8wwr3s4osvLrin8eKAH2KFChXCDKsdy+oVtVN1oh2mnI4jIWKtn/VDfSIrzaOsdm01ftg2IURhEZTjc4GAORw1iA4kUuThlyZxewjE7T9ExWycVuOS/v37+8o2btYjbkLEfCtWrNAeTua5/W4HvffzP4kPjZVAhDp37pyIZcRq/iTb8BNySsTI0us999wTu0puNRTD/iYhv+QWMkbV8cJWrVq1QOeGrxBWz++++04R6DF16tSCccI6gjsSIi9kYs6cOapSpUoFCqXti5dzQGepdp+2Kyf68HAgoCGMYD6minwSpncvepJIknuGncQdscrc6BCXsDQVxr8qCULEuRuTbAbFIkipJqqt42ht9ZIdNpVD0PPI1XH44zlVdsCvBtIUdzoNzt8tunXu3LmBrDkQF0gfltkkhMAIkr0GFUdC5MWXIUy0SVCl/RwnhMgPWtI3TQiQq4cft1+HX/M5sERBWvxch7SS3LVKlSpm9TK2yVjbqVOnjLaoN8gzxJ9ZaCO9iNNyDqHlpAywk7APr6QIEdZ/qqy7pRewO0+93e+yjt35JeFIr+ucpk8KJluRQ13HOLKh62MbP538mehHtnZSKPgRItgobRP2f8zrnCzDkWIizH3OkRBhssOhyk6ozotTVJpFCFGar47o5oYA4eDNmjVzvGm6jcH+mjVrag9yHF9zJaz1E7HqJOPHj8+ZAy1YN2jQwEk9Le0ASzpxiR1hYL6os3evX79ec1oOcy5+ipLa3YtxnKZIblgyGeY8cnWs0/IhOkXhv+Pl3Fj+xLpiJ36XoliGwxLrxB/s5graDvkKm6/KlhDh2Om2xhfWgTDoifs5zu5HaB5DlszMiMh2WhDwQiS86EpUB8VSo3Bk9DKfuQ/5ygYNGmRuztgO4xCZMVCADWNpErvD44yAY84kCRHzkY0Y5+gw4sV6gBWE5VCjHwlz4p+CD0jx4sXDqJC3x5INnZcAOwnrv2M3rrmd5x9lapyE5TsvL1RYH7E4MWaSEjZZLLraEiLi+HGEchJMaPwY0ixCiNJ8dUQ3rwi8++67kVRWx6yMYzMWo6Tl8ssvt60LpuvCfadkyZL6ZqKfLNu4haUTkbPPPvvEplfShIhlTIhKWB+Pt99+Wx1xxBG2uFhhy/8iS0JHHXWU7XG7+w63jO2cv1ciEgYrL472XhMwO2XhDqOj07FYKt1+u07H6/tsCdGkSZNUr1699H6Wnzh95qrekKVCFo1CiCxAkaa8RMAtoaGfk8pFWL6bvwT658onEf8hSKKTP0fdunVt6z75wd6pb9KECF2MOVycdHPah4M1pResnPfxM7KKlsJHFZ+sPVncqkCAjV8/rSB4kiPI7Vp4Xb4jFU/ShZkpA9S6desgp55xzP8BAAD//0ANXw8AAB3eSURBVO2dBdgUVdvHD3a+oIIYYIOBit2diNiJiondgIrdYqHYgYmJXQgGtmIjipjY3d36fu9vvmtwn3lmzjkzc+bM7O59X9dz7bNzzpz4z+7Of+5s89//iYqRU045RV122WUxLf8eOv3009WWW27574EK/jd+/Hi18cYbG1c2atQo1bVrV2M/6SAIlIkAn+fevXurn3/+OfcyBg8erDbbbLPc49gM8N1336mlllpK23WWWWZRzz33nLZPUY1vv/22Wm+99bTDDxgwQO2zzz7aPnkbzznnHMVfnCy00ELq3nvvjWvKfezMM89UF154Ya5xDjvsMLXnnnu2GGPs2LFqiy22aHGMN/369VP77bdfq+PNdmD06NFq99131277qKOOUrvuuqu2T95Gm+/n2muvrYYOHZp3qkqf3yaJEO22227q4Ycf1i7+8ssvV2uuuaa2T9mNQojKvgIyv2sEPvjgA7XjjjsqXvPKaaedprbaaqu8wxjPHzdunJF8Lbroouquu+4yjlVEhxtuuEEdeeSR2qFvvPFGtdxyy2n75G0sixD99ttvasMNN1Tvvvturi3cfvvtqnv37sEYX331ldpggw3U119/3WLM9ddfX11wwQVqsskma3G8Gd+8+OKLRqUChPKMM84oFJ6///5bdenSRTtHmQ8s2oU5bEwkRCuttJL67LPPtFPdcccdavHFF9f2KbtRCFHZV0DmLwIBbjI8tLz88su5h7/iiivUGmuskXsc3QB33nmnOvjgg3VdgocrHrLKkP3331+NGDFCO/Wrr76qpp12Wm2fvI1lESLW/cILL+Qmx3PNNVdAaqeffnrVp08f9fTTT7eAZN5551V8FmaYYYYWx5v1zTvvvKPWWWcd7fYhKvfdd5+2j4vGxRZbzKh5RoMLMWpUiSVEv/76q+rWrZtxz/fff79aYIEFjP3K7CCEqEz0Ze4iEfjll18CkvHAAw/knoabFD+IRYnuRh/OiWl7yJAh4Vtvr//880+g1dCZIZdddlk1fPjwwtekw6lIk1m4seOPP15dffXV4dtMrz169FCdOnVq5XIBSbr77rvVPPPMk2ncRjzpm2++Ucsss4xxaz7IOJq7t956S7uW6667Tq244oraPvXcGEuIPvnkE7XKKqsY94VJbe655zb2K7ODEKIy0Ze5i0YAVfegQYMUWp48ws3qwQcfVB07dswzTOK5mKMwS+kEf0T8En3Lm2++qbiJ6+TAAw9U/BUtZRMiSOG6665rtA5kwcGHJjLLuso8B1PlIossYlyCj3stpnO0hDqpB79h3fpNbbGEyMbBkIGfeOIJNcccc5jmKLVdCFGp8MvknhC45ppr1LHHHptrNp4QL7roolxjJJ180EEHGf2DcBY/+eSTk4Yo7DhPvUcffbR2fPBdeeWVtX1cNJZNiNjDo48+qnbZZRcX25k0hg+H9EmT1dE/Nr47bAffOnzsipTtt99ejRkzRjuFDwdv7QIKbowlRPglbLrppsapsQ/POuusxn5ldmhGQkSkB856jSw80Z944omNvMXUe+MpEr+iPEKkkUlbkmV8myANHMWPO+64LMPnOodoJ1P01iuvvKLQohUtVSBE7PHQQw9Vt9xyi5Pt8nk6//zzxYk6Ac355psvoeXfwz5MVTvvvLN67LHH/p005j8ebA444ICYlsY4FEuIIDrbbbedcYeo12aaaSZjvzI7NCMhsvmClXlNXMxNRMx5553nYqiGGoMwZ4iFzh9Gt2EcJvFJateuna5b6rZtttnGGFIPaTJFeqWe2HACT+hLLLGEFi8CRwgg8SFVIUTffvutWm211bS42OABieR+4oNM2qynin1sfq8vvvhiY1qIvHsj/J80ADoh/B8tUaNKLCF66KGHVN++fY17RpNU9WgBIUTGy1iXHYQQJV82HDC33XbbzDczngB5EnQpPXv2VK+//rp2yL322ivQTGg7OW5kTaxNJz7XVRVCBB7kZsubdwkihOayffv2Ooi9tZF278MPP1QEDhHxNtVUU3mbO2kiG0Lkw3dn7733NkazleXnl4Sd6+OxhOiee+6xUov58HzPu2EhRHkRrOb5Qoj014Vokc033zwTKUJLxFP95JNPrp8kRSth/aa8SYS+m0LzU0xp1dXG98pnvrUqESIAtLlJmoCuyncV7em+++47yWEcsobZ3cY9xLTHPO024e74uLn264qumaABogB1gsP9JZdcoutS122x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"/>
<image id="image3_1_28" width="172" height="136" xlink:href="data:image/png;base64,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ddNNN6m11lqron58ND7rrLPUyy+/bOyqbdu26p577jGW+yjgr9P9fZzbe++91dKlS43DwN+4ceOM5aussoqxrNKCVq1aqV9++cXYzRNPPKGoo6N6NReXusAy8Oeff66OOuooK6M6BqPndtppp9JEb7jhhtGizI7/+OMPte2221rHO//889Ull1xirZNWIXN9yCGHWLvv27evOuecc6x10io8+eST1dtvv23s/qKLLlJ8dJSZwDL4Bx98oLp27arjI9G5jTfeWE2ePFk1a9YsUTtfld9//311/PHHW7sbMmSIOumkk6x10ip86KGH1JVXXmnt/tFHH1W77rqrtU5ahQMGDFD33XefsfvmzZurF198UVueqcDCwWuvvaZOO+00LTNJTjZo0EA98MADihU3a7rjjjvUjTfeaB32zjvvVO3bt7fWSauwd+/e6sknn7R2/8knn6jVV1/dWietQlSR66+/3tr9O++8o3RP0cwFFi7feOMN1a1bNyvD0sIJEyaogw46SFrdSz0eV0899ZS1r0ceeUTttttu1jppFKLhcRPbdMT9999fTZw4MY3hRX0yN5dffrm17v3336/23XffWJ2qCCxczJ07t/TItE1sjFvDCTZiXbp0MZT6P92hQwf18ccfWztmQ7bFFltY66RRuHDhQufK3qdPH3XuueemMbyoTx73Lv35mmuuUWeeeWasv6oJLJwsWrRIde/evfQd4yzhieHDh6vjjjsuYavk1f/++2+19dZbOxvOmjVLNWzY0FnPd4UpU6aoq6++2trt1KlT1Z577mmtk2bhzJkz1bHHHmsdgr3ODTfcEKtTVYGFG0wvmIhmz54dYy7pifHjx6s2bdokbZao/pIlS9QBBxzgbPPZZ5+pevXqOev5rnDBBReop59+2trtvHnzqmoalFgxWBSee+652HVUXWDh6Ndff1UXX3yxev7552MMJj1hs+El7UtX/80331Snnnqqrqj2HBvCOXPm1B5n9eOff/5RO++8s1V/3WOPPdSDDz6YFUvacX744QfVunVrbVn4pO7GyoXAwiSPWnaOrJKVEMLywgsvqI022qiSboxt2WyZbIRBo/XXX1+99957wWFm359++qnCuWIjm43T1s5n2W+//aa23357Z5e6fUBuBDbgftKkSeq6664LDsv6Puyww9SYMWPKautqhP531VVXWathJ2Yl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"/>
<image id="image4_1_28" width="188" height="126" xlink:href="data:image/png;base64,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"/>
</defs>
</svg>
)"
],
"metadata": {
"id": "CmP1ahaXsy_c"
}
},
{
"cell_type": "code",
"source": [
"times = np.arange(365, 1826)"
],
"metadata": {
"id": "zoUFRn2yqLPF"
},
"execution_count": 45,
"outputs": []
},
{
"cell_type": "code",
"source": [
"survs = cox.predict_survival_function(X_test)"
],
"metadata": {
"id": "06i_zOUBqMUt"
},
"execution_count": 46,
"outputs": []
},
{
"cell_type": "code",
"source": [
"preds = np.asarray([[fn(t) for t in times] for fn in survs])"
],
"metadata": {
"id": "prIyWOtMqe7s"
},
"execution_count": 47,
"outputs": []
},
{
"cell_type": "code",
"source": [
"from sksurv.metrics import integrated_brier_score\n",
"\n",
"integrated_brier_score(y_trn, y_test, preds, times)"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "Qyvn1TexqkoO",
"outputId": "8300b953-9390-465e-9397-cc232bd65c39"
},
"execution_count": 48,
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
"0.17509710701666106"
]
},
"metadata": {},
"execution_count": 48
}
]
},
{
"cell_type": "code",
"source": [
"!pip install -q eli5"
],
"metadata": {
"id": "yU-3yjgDr3N7",
"colab": {
"base_uri": "https://localhost:8080/"
},
"outputId": "2e0d458d-504f-4a1a-ba12-9fd44c68bd9e"
},
"execution_count": 34,
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"\u001b[?25l \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m0.0/216.2 kB\u001b[0m \u001b[31m?\u001b[0m eta \u001b[36m-:--:--\u001b[0m\r\u001b[2K \u001b[91m━━━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[91m╸\u001b[0m\u001b[90m━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m122.9/216.2 kB\u001b[0m \u001b[31m3.4 MB/s\u001b[0m eta \u001b[36m0:00:01\u001b[0m\r\u001b[2K \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m216.2/216.2 kB\u001b[0m \u001b[31m3.7 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
"\u001b[?25h Preparing metadata (setup.py) ... \u001b[?25l\u001b[?25hdone\n",
" Building wheel for eli5 (setup.py) ... \u001b[?25l\u001b[?25hdone\n"
]
}
]
},
{
"cell_type": "code",
"source": [
"from eli5.sklearn import PermutationImportance"
],
"metadata": {
"id": "k6mzeqdNr7ZB",
"colab": {
"base_uri": "https://localhost:8080/",
"height": 478
},
"outputId": "16fa075b-d501-48c2-f4e5-c8fafeeba9ad"
},
"execution_count": 35,
"outputs": [
{
"output_type": "error",
"ename": "ImportError",
"evalue": "cannot import name 'if_delegate_has_method' from 'sklearn.utils.metaestimators' (/usr/local/lib/python3.10/dist-packages/sklearn/utils/metaestimators.py)",
"traceback": [
"\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
"\u001b[0;31mImportError\u001b[0m Traceback (most recent call last)",
"\u001b[0;32m<ipython-input-35-bd1ee3945164>\u001b[0m in \u001b[0;36m<cell line: 1>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0;32mfrom\u001b[0m \u001b[0meli5\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msklearn\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mPermutationImportance\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
"\u001b[0;32m/usr/local/lib/python3.10/dist-packages/eli5/__init__.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m 11\u001b[0m )\n\u001b[1;32m 12\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0;34m.\u001b[0m\u001b[0mexplain\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mexplain_weights\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mexplain_prediction\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 13\u001b[0;31m \u001b[0;32mfrom\u001b[0m \u001b[0;34m.\u001b[0m\u001b[0msklearn\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mexplain_weights_sklearn\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mexplain_prediction_sklearn\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 14\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0;34m.\u001b[0m\u001b[0mtransform\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mtransform_feature_names\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 15\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m/usr/local/lib/python3.10/dist-packages/eli5/sklearn/__init__.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m 1\u001b[0m \u001b[0;31m# -*- coding: utf-8 -*-\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 2\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0m__future__\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mabsolute_import\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 3\u001b[0;31m from .explain_weights import (\n\u001b[0m\u001b[1;32m 4\u001b[0m \u001b[0mexplain_weights_sklearn\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 5\u001b[0m \u001b[0mexplain_linear_classifier_weights\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m/usr/local/lib/python3.10/dist-packages/eli5/sklearn/explain_weights.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m 76\u001b[0m \u001b[0mget_feature_importance_explanation\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 77\u001b[0m )\n\u001b[0;32m---> 78\u001b[0;31m \u001b[0;32mfrom\u001b[0m \u001b[0;34m.\u001b[0m\u001b[0mpermutation_importance\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mPermutationImportance\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 79\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 80\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m/usr/local/lib/python3.10/dist-packages/eli5/sklearn/permutation_importance.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m 5\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mnumpy\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 6\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0msklearn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmodel_selection\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mcheck_cv\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 7\u001b[0;31m \u001b[0;32mfrom\u001b[0m \u001b[0msklearn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mutils\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmetaestimators\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mif_delegate_has_method\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 8\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0msklearn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mutils\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mcheck_array\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcheck_random_state\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 9\u001b[0m from sklearn.base import (\n",
"\u001b[0;31mImportError\u001b[0m: cannot import name 'if_delegate_has_method' from 'sklearn.utils.metaestimators' (/usr/local/lib/python3.10/dist-packages/sklearn/utils/metaestimators.py)",
"",
"\u001b[0;31m---------------------------------------------------------------------------\u001b[0;32m\nNOTE: If your import is failing due to a missing package, you can\nmanually install dependencies using either !pip or !apt.\n\nTo view examples of installing some common dependencies, click the\n\"Open Examples\" button below.\n\u001b[0;31m---------------------------------------------------------------------------\u001b[0m\n"
],
"errorDetails": {
"actions": [
{
"action": "open_url",
"actionText": "Open Examples",
"url": "/notebooks/snippets/importing_libraries.ipynb"
}
]
}
}
]
},
{
"cell_type": "code",
"source": [
"perm = PermutationImportance(\n",
" cox, n_iter=100, random_state=42).fit(X_trn,y_trn)"
],
"metadata": {
"id": "WYW6dDDvsBNe"
},
"execution_count": null,
"outputs": []
},
{
"cell_type": "code",
"source": [
"data = perm.results_\n",
"data = pd.DataFrame(data, columns=X_trn.columns)\n",
"meds = data.median()\n",
"meds = meds.sort_values(ascending=False)\n",
"data = data[meds.index]"
],
"metadata": {
"id": "n5aKc--PsMHm"
},
"execution_count": null,
"outputs": []
},
{
"cell_type": "code",
"source": [
"fig, ax = plt.subplots(figsize=(10,7))\n",
"data.boxplot(ax=ax)\n",
"ax.set_title('Feature Importances')\n",
"plt.show()"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 622
},
"id": "oBbnA1ZMsQeY",
"outputId": "40006cd2-965b-4c1b-8f84-1f1f9b88ce90"
},
"execution_count": null,
"outputs": [
{
"output_type": "display_data",
"data": {
"text/plain": [
"<Figure size 1000x700 with 1 Axes>"
],
"image/png": "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73f6fvHixSorK9OIESOcxhsZGanWrVs7jddV9957r+P/devWVdu2bRUSEqIRI0Y4lrdt21Z169bVd999V+Hx9913n9OZnQceeEC+vr765JNPJEn//e9/debMGY0fP17e3v/78ThmzBiFh4dr6dKlTv0FBAQoOTm5yuMPCAhw9FtaWqrjx48rNDRUbdu2rbQ+ycnJ8vf3d3zfs2dPSXLs25YtW5Sdna3x48dXONtWfqbrhx9+0GeffaYRI0bop59+ctTj+PHjGjBggHbt2qWDBw9KOntMt2/frl27dlV5nwDA0/ExOQC4DHTp0qXSCRTKfzH99a9/XenjwsPDHf//4YcfNG3aNL3//vs6cuSIU7uTJ0/W4Gj/59yPou3atUvGGLVu3brS9j8PI64IDAxUo0aNnJbVqVNHV1xxheMX/58vr+xaoHPHFBoaqiZNmmjv3r2SpH379kk6G6h+zt/fXy1btnSsL9esWTOnsHIxZWVlmjNnjubOnavs7GyVlpY61jVo0KBC+yuvvNLp+3r16kmSY9/27Nkj6cKzDu7evVvGGD3xxBN64oknKm1z5MgRNWvWTE8//bSGDBmiNm3aqEOHDrrhhht055136pprrqnyPgKApyEMAcBlrKysTNLZ64YiIyMrrPf1/d/b+IgRI7Ru3TpNmjRJcXFxCg0NVVlZmW644QZHPxdybqgo9/Nf2s/187NR5eP18vLSp59+Kh8fnwrtQ0NDLzqOylTW14WWm/9//ZI7nbvvF/Pcc8/piSee0N13363p06erfv368vb21vjx4yutT03sW3m/EydO1IABAypt06pVK0lSr169tGfPHv3rX//S8uXL9X//93/605/+pPnz5zudlQOA2oQwBACXsauuukqS1LhxY/Xt2/e87X788Uelp6dr2rRpevLJJx3LK/vI0/lCT/mZh3NnTjv3jMjFxmuMUXR0tNq0aVPlx10Ku3btUp8+fRzf5+fnKycnRzfeeKMkqUWLFpKkrKwstWzZ0tHuzJkzys7OvuDx/7nzHd9FixapT58++utf/+q0/MSJE46JLFxR/tzYtm3becdWvh9+fn5VGn/9+vWVnJys5ORk5efnq1evXnrqqacIQwBqLa4ZAoDL2IABAxQeHq7nnntOxcXFFdaXzwBXfhbh3LMGs2fPrvCY8nsBnRt6wsPD1bBhQ61evdpp+dy5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ANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANgSYQgAAACALRGGAAAAANiSr9UD8CTZxwpUUFTilr73HC1wfPX1dU9ZQgJ8Fd0wxC19AwAAAJ6mWr91v/baa3rppZeUm5urjh076pVXXlGXLl3O2/7DDz/UE088ob1796p169Z64YUXdOONNzrW5+fn69FHH1VqaqqOHz+u6Oho/eEPf9D9999fneG5RfaxAvV5eaXbtzNh0Va39r9iYm8CEQAAAKBqhKEPPvhAKSkpmj9/vrp27arZs2drwIABysrKUuPGjSu0X7dunUaOHKkZM2Zo8ODBWrhwoZKSkrR582Z16NBBkpSSkqLPPvtMf//73xUVFaXly5fr97//vZo2baqbb775l+9lDSg/IzT71ji1ahxa8/2fKtKSles1uHeCQoICarz/3UfyNf6Dr9x2ZgsAAADwNC6HoVmzZmnMmDFKTk6WJM2fP19Lly7VG2+8oUcffbRC+zlz5uiGG27QpEmTJEnTp09XWlqaXn31Vc2fP1/S2cA0evRo9e7dW5J033336S9/+Ys2btx42YShcq0ah6pDszo13m9xcbFyG0mdWtSTn59fjfcPAAAAwJlLEyicOXNGGRkZ6tu37/868PZW3759tX79+kofs379eqf2kjRgwACn9t27d9fHH3+sgwcPyhijFStWaOfOnerfv78rwwMAAACAKnPpzNCxY8dUWlqqiIgIp+URERHKzMys9DG5ubmVts/N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hBrUu3dvPfTQQxo/frzq1auniIgIvf766yooKFBycrLCwsLUqlUrffrpp47HbNu2TQMHDlRoaKgiIiJ055136tixY059/uEPfzjva0S6+Ovk66+/Vp8+fRQWFqbw8HDFx8dr06ZNWrlypZKTk3Xy5MkKZ07feecdde7cWWFhYYqMjNTtt9+uI0eOSDr7M6hPnz6SpHr16snLy0t33XWXew7qZWDZsmXq0aOH43ecwYMHa8+ePY7169atU1xcnAIDA9W5c2elpqZWOHN6sTp7HIOLSkxMNKGhoWbcuHEmMzPT/P3vfzfBwcFmwYIFxhhjWrRoYcLDw83LL79sdu/ebXbv3m02bdpkvL29zdNPP22ysrLMm2++aYKCgsybb77p6Ldv374mLi7ObNiwwWRkZJjExEQTFBRk/vSnPznaSDKNGzc2b7zxhtmzZ4/Zt2+fWb16tQkPDzdvvfWW2bNnj1m+fLmJiooyTz31lDHGmNLSUtOtWzdz9dVXm+XLl5s9e/aYf//73+aTTz65lIfNLapSi/r165vXXnvN7Nq1y8yYMcN4e3ubzMxMY4wx+fn5pkmTJmbo0KFm69atJj093URHR5vRo0c7tvHCCy+YevXqmY8++sh8++235p577jFhYWFmyJAhjjbPPPOMiYmJMcuWLTN79uwxb775pgkICDArV640xhjz4IMPmri4OPPll1+a7Oxsk5aWZj7++ONLdpysdOLECZOQkGDGjBljcnJyTE5Ojrn//vvPezyys7ONJLNlyxbH48sfl5OTY8aNG2caN25scnJyjDHG3HvvvaZ79+5m9erVZvfu3eall14yAQEBZufOnVbtsiUqO867d+82fn5+ZuLEiSYzM9O89957plmzZkaS+fHHH40xxrz55pvGz8/PdO/e3axdu9ZkZmaagoICk56ebt555x2zY8cOx/M+IiLC5OXlGWPOvq906NDBXH/99earr74yq1atMr/61a+MJPPPf/7TGGPMmTNnTLt27czdd99tvvnmG/Ptt9+a22+/3bRt29YUFRVZdKQuncTERBMeHm6eeuops3PnTvP2228bLy8vs3z5clNaWmri4uJMjx49zKZNm8yGDRtMfHy8SUxMdDx+6tSpJiQkxNxwww1m8+bN5uuvv3bq/8033zR16tSpsN0VK1YYSaZr165m5cqVZvv27aZnz56me/fubt7jy8uF3pcv9J68ceNGI8n897//NTk5Oeb48ePGGGNGjx5tQkNDzZ133mm2bdtmtm3bVqXn+Ny5c01gYKCZPXu2ycrKMhs3bnT6ue4pEhMTTVhYmJk+fbrZuXOnmT59uvHx8TEDBw40CxYsMDt37jQPPPCAadCggSkoKDA//vijadSokZk8ebLZsWOH2bx5s+nXr5/p06ePU5/ne40YY6r0Orn66qvNb3/7W7Njxw6zc+dO849//MN89dVXpqioyMyePduEh4c73hN/+uknY4wxf/3rX80nn3xi9uzZY9avX28SEhLMwIEDjTHGlJSUmI8++shIMllZWSYnJ8ecOHHi0h3oS2zRokXmo48+Mrt27TJbtmwxN910k4mNjTWlpaXm5MmTpn79+ua3v/2t2b59u/nkk09MmzZtnH5GV6XOnoYwVAWJiYmmXbt2pqyszLHskUceMe3atTPGnP0FPCkpyekxt99+u+nXr5/TskmTJpn27dsbY4zZsWOHkWS+/PJLx/pdu3YZSRXC0Pjx4536uf76681zzz3ntOydd94xTZo0McYY85///Md4e3ubrKysau7x5asqtfjtb3/rWFdWVmYaN25s5s2bZ4wxZsGCBaZevXomPz/f0Wbp0qXG29vb5ObmGmOMadKkiXnxxRcd64uLi80VV1zhCEOnT582wcHBZt26dU5ju+eee8zIkSONMcbcdNNNJjk5uQb33LMkJiaacePGOb6/0PE4Nwz93EcffWQCAwPN559/bowxZt++fcbHx8ccPHjQqd31119vJk+eXGPj9xTnHudHHnnEdOjQwanNY489ViEMSTJfffXVBfsuLS01YWFh5t///rcx5uz7iq+vr9Ox//TTT53C0DvvvGPatm3r9PosKioyQUFB5j//+c8v2FPPkJiYaHr06OG07NprrzWPPPKIWb58ufHx8TH79+93rNu+fbuRZDZu3GiMORuG/Pz8zJEjRyrt/2Jh6L///a9j2dKlS40kc+rUqRrYs8vfxd6Xq/MeNHr0aBMREeEU5KvyHG/atKl57LHHamjPrHPu87mkpMSEhISYO++807EsJyfHSDLr168306dPN/3793fq48CBA46QUVmfxvzvNWKMqdLrJCwszLz11luVjvl8r5Fzffnll0aSIyyVv4bK3yft5OjRo0aS2bp1q5k3b55p0KCB0/vG66+/7vT6qEqdPQ0fk6uibt26ycvLy/F9QkKCdu3apdLSUklS586dndrv2LFD1113ndOy6667zvGYrKws+fr6qlOnTo71rVq1Ur169Sps+9y+v/76az399NMKDQ11/BszZoxycnJUWFior776SldccYXatGnzi/f7cnSxWlxzzTWOdeUfKSk/Hb5jxw517NhRISEhjjbXXXedysrKlJWVpZMnTyonJ0ddu3Z1rPf19XWqwe7du1VYWKh+/fo51eBvf/ub41TzAw88oPfff19xcXF6+OGHtW7dOvccDA9RneOxZcsW3XnnnXr11Vcdr6WtW7eqtLRUbdq0cTr2q1atcjrNb1dZWVm69tprnZZ16dKlQjt/f3+n14kkHT58WGPGjFHr1q1Vp04dhYeHKz8/X/v375d09rXTvHlzNW3a1PGYhIQEpz6+/vpr7d69W2FhYY7a1K9fX6dPn7ZNfc49rk2aNNGRI0ccx6958+aOde3bt1fdunW1Y8cOx7IWLVqoUaNGv3jbTZo0kSTHe19td7H35eq+J8fGxjpdJ3Sx5/iRI0d06NAhXX/99e7a1Uvq588pHx8fNWjQQLGxsY5lERERks4+z77++mutWLHC6fjHxMRIktPr/3yvEUlVep2kpKTo3nvvVd++ffX8889X6b0lIyNDN910k6688kqFhYUpMTFRkhzvb3aya9cujRw5Ui1btlR4eLiioqIknT0WWVlZuuaaaxQYGOhof+7PkKrW2ZMwgUIN+fkv1+7uOz8/X9OmTdPQoUMrtA0MDFRQUJDbxuIJzp1gwsvLS2VlZTXWf/n1RUuXLlWzZs2c1gUEBEiSBg4cqH379umTTz5RWlqarr/+ej344IN6+eWXa2wcnsTV45Gbm6ubb75Z9957r+655x7H8vz8fPn4+CgjI0M+Pj5Oj/n5tRO4sKCgIKc/KEjS6NGjdfz4cc2ZM0ctWrRQQECAEhISdObMmSr3m5+fr/j4eL377rsV1lX3F3xP80vff37Jz5Kfb7u8vjX53nc5u9j7cvPmzav1nlzZz98LPcdr20QklT2fz/c8y8/P10033aQXXnihQj/l4fx8fbryPH3qqad0++23a+nSpfr00081depUvf/++7rlllsqbV9QUKABAwZowIABevfdd9WoUSPt379fAwYMcOn9rba46aab1KJFC73++utq2rSpysrK1KFDhyofi6rW2ZMQhqroiy++cPp+w4YNat26dYVfyMq1a9dOa9eudVq2du1atWnTRj4+Pmrbtq1KSkq0ZcsWxcfHSzr7l60ff/zxomPp1KmTsrKy1KpVq0rXX3PNNfr++++1c+fOWnl2yNVa/Fy7du301ltvqaCgwPFDbu3atfL29lbbtm1Vp04dNWnSRF988YV69eolSSopKVFGRobjLN7PLzov/+tSZRo1aqTRo0dr9OjR6tmzpyZNmmSbMOTv7+84U1euqsfj9OnTGjJkiGJiYjRr1iyndb/61a9UWlqqI0eOqGfPnm7dB09w7nFu27atPvnkE6c2X375ZZX6Wrt2rebOnasbb7xR0tmLxH9+QWy7du104MAB5eTkOH7gbdiwwamPTp066YMPPlDjxo0VHh5erX2qrcqP34EDBxx/9f7222914sQJtW/f3uLReb6qvC+f7z2o/MzPue9ZlanKczwqKkrp6emOi/LtolOnTvroo48UFRUlX9/q/XpZ1ddJmzZt1KZNG/3xj3/UyJEj9eabb+qWW26p9GdPZmamjh8/rueff97R57kzMLryHPBkx48fV1ZWll5//XXHz9DPP//csb5t27b6+9//rqKiIscfd8/9GVITdb7c1K4/YbjR/v37lZKSoqysLL333nt65ZVXNG7cuPO2nzBhgtLT0zV9+nTt3LlTb7/9tl599VVNnDhRkhQTE6O+ffvqvvvu08aNG7Vlyxbdd999lf7F9lxPPvmk/va3v2natGnavn27duzYoffff1+PP/64JCkxMVG9evXSb37zG6WlpSk7O1uffvqpli1bVnMHxEKu1uLn7rjjDgUGBmr06NHatm2bVqxYoYceekh33nmn43T/uHHj9Pzzzys1NVWZmZn6/e9/73TvgbCwME2cOFF//OMf9fbbb2vPnj3avHmzXnnlFb399tuSztboX//6l3bv3q3t27dryZIlateuXY0fi8tVVFSUvvjiC+3du1fHjh1z6Xj87ne/04EDB/TnP/9ZR48eVW5urnJzc3XmzBm1adNGd9xxh0aNGqXFixcrOztbGzdu1IwZM7R06dJLvJfWO/c4jxkzRpmZmXrkkUe0c+dO/eMf/9Bbb70lSRd9X2ndurXeeecd7dixQ1988YXuuOMOp7PMffv2VZs2bTR69Gh9/fXXWrNmjR577DGnPu644w41bNhQQ4YM0Zo1a5Sdna2VK1fqD3/4g77//vsa339P0rdvX8XGxuqOO+7Q5s2btXHjRo0aNUqJiYkVPgoN113sfflC70GNGzdWUFCQli1bpsOHD+vkyZPn3U5VnuNPPfWUZs6cqT//+c/atWuXYxy13YMPPqgffvhBI0eO1Jdffqk9e/boP//5j5KTk6scMi72Ojl16pTGjh2rlStXat++fVq7dq2+/PJLRy2joqKUn5+v9PR0HTt2TIWFhbryyivl7++vV155Rd99950+/vhjTZ8+3Wm7LVq0kJeXl5YsWaKjR486zTBbm9SrV08NGjTQggULtHv3bn322WdKSUlxrL/99ttVVlam++67Tzt27NB//vMfxx8ty3+G1ESdLztWX7TkCRITE83vf/97c//995vw8HBTr149M2XKFMcFlC1atKh0pphFixaZ9u3bGz8/P3PllVeal156yWn9oUOHzMCBA01AQIBp0aKFWbhwoWncuLGZP3++o41+dnHyzy1btsx0797dBAUFmfDwcNOlSxfHjGrGGHP8+HGTnJxsGjRoYAIDA02HDh3MkiVLauaAWKg6tejYsaOZOnWq4/tvvvnG9OnTxwQGBpr69eubMWPGOC6iNObshAnjxo0z4eHhpm7duiYlJcWMGjXKaTa5srIyM3v2bNO2bVvj5+dnGjVqZAYMGGBWrVpljDl7gWG7du1MUFCQqV+/vhkyZIj57rvv3HZcLjdZWVmmW7duJigoyEi64PE49+LlFi1aGEkV/q1YscIYc3bGsieffNJERUUZPz8/06RJE3PLLbeYb775xqK9tc65xzk7O9v861//Mq1atTIBAQGmd+/eZt68eU4X0p/vAuPNmzebzp07m8DAQNO6dWvz4YcfVng9ZWVlmR49ehh/f3/Tpk0bs2zZsgrvUTk5OWbUqFGmYcOGJiAgwLRs2dKMGTPGnDx50s1Hw3rnTmhhjDFDhgxxzFa5b98+c/PNN5uQkBATFhZmhg8f7pi4xZizEyh07NjxvP1fbAKFn1/8vWXLFsdzwi4u9L58sffk119/3TRv3tx4e3s7Zi4bPXq00/t+uao8x+fPn+8YR5MmTcxDDz3k7t2vcZU9nyv7Gfvz94CdO3eaW265xdStW9cEBQWZmJgYM378eMfP6Iu9Roy58OukqKjI3HbbbaZ58+bG39/fNG3a1IwdO9bpgv/777/fNGjQwEhy/OxfuHChiYqKMgEBASYhIcF8/PHHFSbNePrpp01kZKTx8vJyGk9tk5aWZtq1a2cCAgLMNddcY1auXOlUw7Vr15prrrnG+Pv7m/j4eLNw4UIjyTErrzEXr7On8TLmnBuooILevXsrLi7O6f4/7vD999+refPm+u9//1trLr6saZeqFkBt8eyzz2r+/Pk6cOCA1UMBAHiYd99913H/ptp6TXrt+LCfh/rss8+Un5+v2NhY5eTk6OGHH1ZUVJTjWhUAcNXcuXN17bXXqkGDBlq7dq1eeuklj7zhIwDg0vvb3/6mli1bqlmzZvr666/1yCOPaMSIEbU2CEmEIUsVFxdrypQp+u677xQWFqbu3bvr3XffrTDTCgBU1a5du/TMM8/ohx9+0JVXXqkJEyZo8uTJVg8LAOABcnNz9eSTTyo3N1dNmjTR8OHD9eyzz1o9LLfiY3IAAAAAbInZ5AAAAADYEmEIAAAAgC0RhgAAAADYEmEIAAAAgC0RhgAAAADYEmEIAAAAgC0RhgAAAADYEmEIAAAAgC0RhgAAAADY0v8Dk569txFQdSYAAAAASUVORK5CYII=\n"
},
"metadata": {}
}
]
},
{
"cell_type": "code",
"source": [
"!pip install -q shap\n",
"import shap\n",
"explainer = shap.Explainer(cox.predict, X_trn)\n",
"shap_values = explainer(X_test[:100])\n",
"shap.plots.waterfall(shap_values[0])"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 540
},
"id": "J03T1z80N8fg",
"outputId": "965e2a52-46dd-471c-84c7-33a7ade8f894"
},
"execution_count": 36,
"outputs": [
{
"output_type": "display_data",
"data": {
"text/plain": [
"<Figure size 800x550 with 3 Axes>"
],
"image/png": "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iKg5Y7JA1MDOnDkDQD9Z6NOnDwDg1KlTBsnCb7/9hldeeQXvvPMO5s+fj8TERHz++ed47bXXjE6Ijo6OxsyZM2uMoT7mLAQEBCAuLg4XL15EeHg4AO0n/vHx8fDy8tLNv1CpVCgqKoKNjU2d95Bwc3PDgw8+aFB+8uRJVFZWom/fvnBycqrxGsnJycjMzETv3r1rHJpFREREtWOyQNTA4uLi4OfnpzeUKCAgAGFhYdizZ4/efgqnT5/GzJkzMXPmTLz22msAgJdeeglffvml0d6F06dPIycnR7cRWXXqY86Cl5cXAgICcOLECZSWlsLZ2RkJCQkoLCzEoEGDdPUyMjLw+++/o2vXrujevbveNc6dO4eKigrdEKNr167phjaFhYXBxsYGbdu2NWj77NmzAGBwLC0tDdHR0bq9FjIyMhAfH49WrVohLCzsvp4vERERMVkganBxcXFGhxrNmTMHb7zxBkpLS2Fra4uUlBSMHTsWXbp0werVq3X1fH19MWfOHHz99dcGvQsbN25E69atMXTo0EZ5LoMHD4aDgwMSExNRUVEBNzc3jBgxAj4+PiadHxcXp7d529WrV3H16lUAQFBQkMEeDrWxt7eHIAiIi4tDZWUlHB0d0aNHD3Tq1MnovAsiIiKqG0GsbgcmImpQ+fn5CAgIwIcffojHH3+8zueXl5ejbdu2eOWVV/Dcc881QIRERETU3PGjNyKJODs746WXXsLy5cuh0WjqfP53330HS0tL3W7QRERERPWNPQtERERERGQUexaIiIiIiMgoJgtERERERGQUkwUiIiIiIjKKyQIRERERERnFZIGIiIiIiIxiskAkIwUFBRg8eDAKCgqkDoWIiIiIyQKRnBQUFODAgQNMFoiIiEgWmCwQEREREZFRTBaIiIiIiMgoJgtERERERGQUkwUiGXFyckKfPn3g5OQkdShEREREEERRFKUOgohuKyoqgoODg9RhEBEREbFngUhusrKypA6BiIiICACTBSLZycvLkzoEIiIiIgBMFohkx8LCQuoQiIiIiABwzgIREREREVWDPQtEMnPmzBmpQyAiIiICwGSBSHbY2UdERERywWSBSGbc3d2lDoGIiIgIAJMFItnhhmxEREQkF0wWiGTmypUrUodAREREBIDJAhERERERVYNLpxLJTEFBAYciERERkSywZ4FIZriDMxEREckF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\n"
},
"metadata": {}
}
]
},
{
"cell_type": "code",
"source": [
"X.describe().transpose().round(2).drop(columns=\"count\")"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 300
},
"id": "-s0v-Yx5N_3o",
"outputId": "c8a734c0-6b6a-472e-a7d1-c38e84cbe06c"
},
"execution_count": null,
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
" mean std min 25% 50% 75% max\n",
"age 53.05 10.12 21.0 46.0 53.0 61.00 80.0\n",
"estrec 96.25 153.08 0.0 8.0 36.0 114.00 1144.0\n",
"horTh 0.36 0.48 0.0 0.0 0.0 1.00 1.0\n",
"menostat 0.58 0.49 0.0 0.0 1.0 1.00 1.0\n",
"pnodes 5.01 5.48 1.0 1.0 3.0 7.00 51.0\n",
"progrec 110.00 202.33 0.0 7.0 32.5 131.75 2380.0\n",
"tgrade 1.12 0.58 0.0 1.0 1.0 1.00 2.0\n",
"tsize 29.33 14.30 3.0 20.0 25.0 35.00 120.0"
],
"text/html": [
"\n",
" <div id=\"df-7378cec5-644d-4560-a5ae-03cbfae13f92\" class=\"colab-df-container\">\n",
" <div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>mean</th>\n",
" <th>std</th>\n",
" <th>min</th>\n",
" <th>25%</th>\n",
" <th>50%</th>\n",
" <th>75%</th>\n",
" <th>max</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>age</th>\n",
" <td>53.05</td>\n",
" <td>10.12</td>\n",
" <td>21.0</td>\n",
" <td>46.0</td>\n",
" <td>53.0</td>\n",
" <td>61.00</td>\n",
" <td>80.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>estrec</th>\n",
" <td>96.25</td>\n",
" <td>153.08</td>\n",
" <td>0.0</td>\n",
" <td>8.0</td>\n",
" <td>36.0</td>\n",
" <td>114.00</td>\n",
" <td>1144.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>horTh</th>\n",
" <td>0.36</td>\n",
" <td>0.48</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>1.00</td>\n",
" <td>1.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>menostat</th>\n",
" <td>0.58</td>\n",
" <td>0.49</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>1.0</td>\n",
" <td>1.00</td>\n",
" <td>1.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>pnodes</th>\n",
" <td>5.01</td>\n",
" <td>5.48</td>\n",
" <td>1.0</td>\n",
" <td>1.0</td>\n",
" <td>3.0</td>\n",
" <td>7.00</td>\n",
" <td>51.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>progrec</th>\n",
" <td>110.00</td>\n",
" <td>202.33</td>\n",
" <td>0.0</td>\n",
" <td>7.0</td>\n",
" <td>32.5</td>\n",
" <td>131.75</td>\n",
" <td>2380.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>tgrade</th>\n",
" <td>1.12</td>\n",
" <td>0.58</td>\n",
" <td>0.0</td>\n",
" <td>1.0</td>\n",
" <td>1.0</td>\n",
" <td>1.00</td>\n",
" <td>2.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>tsize</th>\n",
" <td>29.33</td>\n",
" <td>14.30</td>\n",
" <td>3.0</td>\n",
" <td>20.0</td>\n",
" <td>25.0</td>\n",
" <td>35.00</td>\n",
" <td>120.0</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>\n",
" <div class=\"colab-df-buttons\">\n",
"\n",
" <div class=\"colab-df-container\">\n",
" <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-7378cec5-644d-4560-a5ae-03cbfae13f92')\"\n",
" title=\"Convert this dataframe to an interactive table.\"\n",
" style=\"display:none;\">\n",
"\n",
" <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\">\n",
" <path d=\"M120-120v-720h720v720H120Zm60-500h600v-160H180v160Zm220 220h160v-160H400v160Zm0 220h160v-160H400v160ZM180-400h160v-160H180v160Zm440 0h160v-160H620v160ZM180-180h160v-160H180v160Zm440 0h160v-160H620v160Z\"/>\n",
" </svg>\n",
" </button>\n",
"\n",
" <style>\n",
" .colab-df-container {\n",
" display:flex;\n",
" gap: 12px;\n",
" }\n",
"\n",
" .colab-df-convert {\n",
" background-color: #E8F0FE;\n",
" border: none;\n",
" border-radius: 50%;\n",
" cursor: pointer;\n",
" display: none;\n",
" fill: #1967D2;\n",
" height: 32px;\n",
" padding: 0 0 0 0;\n",
" width: 32px;\n",
" }\n",
"\n",
" .colab-df-convert:hover {\n",
" background-color: #E2EBFA;\n",
" box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n",
" fill: #174EA6;\n",
" }\n",
"\n",
" .colab-df-buttons div {\n",
" margin-bottom: 4px;\n",
" }\n",
"\n",
" [theme=dark] .colab-df-convert {\n",
" background-color: #3B4455;\n",
" fill: #D2E3FC;\n",
" }\n",
"\n",
" [theme=dark] .colab-df-convert:hover {\n",
" background-color: #434B5C;\n",
" box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n",
" filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n",
" fill: #FFFFFF;\n",
" }\n",
" </style>\n",
"\n",
" <script>\n",
" const buttonEl =\n",
" document.querySelector('#df-7378cec5-644d-4560-a5ae-03cbfae13f92 button.colab-df-convert');\n",
" buttonEl.style.display =\n",
" google.colab.kernel.accessAllowed ? 'block' : 'none';\n",
"\n",
" async function convertToInteractive(key) {\n",
" const element = document.querySelector('#df-7378cec5-644d-4560-a5ae-03cbfae13f92');\n",
" const dataTable =\n",
" await google.colab.kernel.invokeFunction('convertToInteractive',\n",
" [key], {});\n",
" if (!dataTable) return;\n",
"\n",
" const docLinkHtml = 'Like what you see? Visit the ' +\n",
" '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n",
" + ' to learn more about interactive tables.';\n",
" element.innerHTML = '';\n",
" dataTable['output_type'] = 'display_data';\n",
" await google.colab.output.renderOutput(dataTable, element);\n",
" const docLink = document.createElement('div');\n",
" docLink.innerHTML = docLinkHtml;\n",
" element.appendChild(docLink);\n",
" }\n",
" </script>\n",
" </div>\n",
"\n",
"\n",
"<div id=\"df-9bc6fdae-b63e-4b3e-8a71-b5762d0a65e4\">\n",
" <button class=\"colab-df-quickchart\" onclick=\"quickchart('df-9bc6fdae-b63e-4b3e-8a71-b5762d0a65e4')\"\n",
" title=\"Suggest charts.\"\n",
" style=\"display:none;\">\n",
"\n",
"<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n",
" width=\"24px\">\n",
" <g>\n",
" <path d=\"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z\"/>\n",
" </g>\n",
"</svg>\n",
" </button>\n",
"\n",
"<style>\n",
" .colab-df-quickchart {\n",
" --bg-color: #E8F0FE;\n",
" --fill-color: #1967D2;\n",
" --hover-bg-color: #E2EBFA;\n",
" --hover-fill-color: #174EA6;\n",
" --disabled-fill-color: #AAA;\n",
" --disabled-bg-color: #DDD;\n",
" }\n",
"\n",
" [theme=dark] .colab-df-quickchart {\n",
" --bg-color: #3B4455;\n",
" --fill-color: #D2E3FC;\n",
" --hover-bg-color: #434B5C;\n",
" --hover-fill-color: #FFFFFF;\n",
" --disabled-bg-color: #3B4455;\n",
" --disabled-fill-color: #666;\n",
" }\n",
"\n",
" .colab-df-quickchart {\n",
" background-color: var(--bg-color);\n",
" border: none;\n",
" border-radius: 50%;\n",
" cursor: pointer;\n",
" display: none;\n",
" fill: var(--fill-color);\n",
" height: 32px;\n",
" padding: 0;\n",
" width: 32px;\n",
" }\n",
"\n",
" .colab-df-quickchart:hover {\n",
" background-color: var(--hover-bg-color);\n",
" box-shadow: 0 1px 2px rgba(60, 64, 67, 0.3), 0 1px 3px 1px rgba(60, 64, 67, 0.15);\n",
" fill: var(--button-hover-fill-color);\n",
" }\n",
"\n",
" .colab-df-quickchart-complete:disabled,\n",
" .colab-df-quickchart-complete:disabled:hover {\n",
" background-color: var(--disabled-bg-color);\n",
" fill: var(--disabled-fill-color);\n",
" box-shadow: none;\n",
" }\n",
"\n",
" .colab-df-spinner {\n",
" border: 2px solid var(--fill-color);\n",
" border-color: transparent;\n",
" border-bottom-color: var(--fill-color);\n",
" animation:\n",
" spin 1s steps(1) infinite;\n",
" }\n",
"\n",
" @keyframes spin {\n",
" 0% {\n",
" border-color: transparent;\n",
" border-bottom-color: var(--fill-color);\n",
" border-left-color: var(--fill-color);\n",
" }\n",
" 20% {\n",
" border-color: transparent;\n",
" border-left-color: var(--fill-color);\n",
" border-top-color: var(--fill-color);\n",
" }\n",
" 30% {\n",
" border-color: transparent;\n",
" border-left-color: var(--fill-color);\n",
" border-top-color: var(--fill-color);\n",
" border-right-color: var(--fill-color);\n",
" }\n",
" 40% {\n",
" border-color: transparent;\n",
" border-right-color: var(--fill-color);\n",
" border-top-color: var(--fill-color);\n",
" }\n",
" 60% {\n",
" border-color: transparent;\n",
" border-right-color: var(--fill-color);\n",
" }\n",
" 80% {\n",
" border-color: transparent;\n",
" border-right-color: var(--fill-color);\n",
" border-bottom-color: var(--fill-color);\n",
" }\n",
" 90% {\n",
" border-color: transparent;\n",
" border-bottom-color: var(--fill-color);\n",
" }\n",
" }\n",
"</style>\n",
"\n",
" <script>\n",
" async function quickchart(key) {\n",
" const quickchartButtonEl =\n",
" document.querySelector('#' + key + ' button');\n",
" quickchartButtonEl.disabled = true; // To prevent multiple clicks.\n",
" quickchartButtonEl.classList.add('colab-df-spinner');\n",
" try {\n",
" const charts = await google.colab.kernel.invokeFunction(\n",
" 'suggestCharts', [key], {});\n",
" } catch (error) {\n",
" console.error('Error during call to suggestCharts:', error);\n",
" }\n",
" quickchartButtonEl.classList.remove('colab-df-spinner');\n",
" quickchartButtonEl.classList.add('colab-df-quickchart-complete');\n",
" }\n",
" (() => {\n",
" let quickchartButtonEl =\n",
" document.querySelector('#df-9bc6fdae-b63e-4b3e-8a71-b5762d0a65e4 button');\n",
" quickchartButtonEl.style.display =\n",
" google.colab.kernel.accessAllowed ? 'block' : 'none';\n",
" })();\n",
" </script>\n",
"</div>\n",
" </div>\n",
" </div>\n"
]
},
"metadata": {},
"execution_count": 26
}
]
},
{
"cell_type": "code",
"source": [
"shap.plots.beeswarm(shap_values)"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 453
},
"id": "0kbYd1wAODT9",
"outputId": "212ab8e2-adc6-45bf-e75e-c78d3c2eec7a"
},
"execution_count": null,
"outputs": [
{
"output_type": "display_data",
"data": {
"text/plain": [
"<Figure size 800x470 with 2 Axes>"
],
"image/png": "iVBORw0KGgoAAAANSUhEUgAAAtcAAAG0CAYAAAD5Bgs0AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACIV0lEQVR4nOzdd3gU1dvG8e/spvfQQ+8dpAlYiA0QaVLtgOhLE8Xe/SnYsYGiFAvVDoIUQUFFioAoRVEUEKSFmoSQXnZ33j9CNmx2E0JI5/5c11wwZ2bOObObZJ8988wZwzRNExERERERuWCWku6AiIiIiEh5oeBaRERERKSQKLgWERERESkkCq5FRERERAqJgmsRERERkUKi4FpEREREpJAouBYRERERKSQKrkVEREREComCaxERERGRQqLgWkRERESKxPjx4wkKCjrntv3792MYBgsWLDiv+gt6XFHyKukOiIiIiMjFLSIigo0bN9K4ceOS7soFU3AtIiIiIiXK19eXzp07l3Q3CoXSQkRERESkRHlK70hPT2fcuHFUqFCBsLAwRo0axaeffophGOzfv9/l+NTUVO69917Cw8OJiIjgkUcewWazFfNZZFJwLSIiIiJFymazuS0OhyPPY5544glmzJjB448/zhdffIHD4eCJJ57wuO/TTz+NxWLhyy+/ZPTo0bz55pt8+OGHRXEq56S0EBEREREpMklJSXh7e3vcFhgY6LE8NjaWadOm8cwzz/D4448DcP3119O1a1cOHTrktn+nTp145513AOjWrRurV69mwYIFjB49upDOIv8UXIuIiBSyjIwMZs2aBcDw4cNzDSxEyiRjgHuZuTDX3f39/Vm7dq1b+fvvv8+nn37q8ZgdO3aQmppK3759XcpvvPFGfvjhB7f9u3fv7rLevHlzfvzxx1z7VJQUXIuIiIjIeTDOa2+LxUKHDh3cypctW5brMUePHgWgcuXKLuVVqlTxuH9YWJjLuo+PD6mpqefVz8KinGsRERERKVUiIiIAOHnypEv5iRMnSqI750XBtYiIiIicB8PDUrhatmyJn58fixcvdin/+uuvC72twqa0EBERERE5D4UfTOdUsWJFxowZw0svvYSfnx9t2rRh/vz57N69G8hMNSmtSm/PRERERKQUKvqRa4BXX32VkSNH8sorrzB48GAyMjKcU/GFhoYWSZuFwTBN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X375hVdffZWoqCjuv//+Qn7VREQkv8r8BWyjzJ+BlHFKA8lbqUsLadSoEa1btwagU6dO9OzZk549e9K6dWvmzJnD8ePHee6553j00UcZNGgQL730El27diUuLs5jffv27eP111/noYceon///vTv3x/IHHlevHgxDz30EDfddBO33XYbU6ZM4YYbbmDx4sVER0c765g7dy5Hjhzh6aef5vHHH2fw4MG88sorXHvttW7tRkdH88Ybb9C9e3dmzpzJ0KFDGTx4MG+88Qa33HILn3zyCYcPHy6S164gYmNjXb4gJCYmkpCQ4FxPT08nJsb1GurRo0fzXD927BimmT20ojbUhtpQGyXVhsdh3rPigsJpI+8mT5w4UchtmGX2/VAbhddGyTI8LJLFMM9+90uJpUuXMmHCBKZPn06HDh2c5YMGDSIxMZHly5djsWR/L4iNjaV79+60a9fOLS2kcePGfPrpp3m2l5GRQXJyMqZpsmHDBp599lneeustIiMjARg8eDDx8fEsX77cJV0kOjqaHj16uLT7+eef88YbbzB16lQaN27s0s6uXbsYO3YsTz31FAMGDCj4CyQiIvlivGFzK/O2QPpDhXPh9qOGCz00CkN39mHWrFkADB8+HG9v74I1YHj4rDAAh4d2RYrJFmOaW1l7c0wJ9KR0KnVpIXk5cuQILVq0cAmsASpUqEBwcLDHY2rXru2x3GazMXv2bJYvX86hQ4fI+R0jPj7e+f+oqCiaN2/uloddqVIlt3b3798PwD333JPrecTGxua6TUREilhRTxainGuRi1qZCq4Lws/Pz2P5pEmT+OKLL+jWrRt33XUX4eHheHl58c8//zBlyhS3YDu/so6bMGEClSpV8rhPjRo1ClS3iIhcuDD/oq2/yFOiLboELyVL3+/yViqDayOXv0wREREcOnQIh8PhlhZydu5Sfixfvpx27drxyiuvuJQfOnTIbd8aNWpw6NAh7Ha7W1pIznZr1aoFQFhYGJ06dTqvPomISOEK8obEDNey4S2LNjgt8mRLa6m7XUouMrqhMW+l8jfU3z9zWOHs1AyAyMhIoqOj+e6771zK582bd95tWCwWt9HplJQUj/nZV111FTExMXzzzTcu5XPmzHHbt1u3bvj4+DBjxgxSU1PdticmJpKenn7e/RURkfP3RW8L1rPigMbhMOGKUvnR55mnQLqZ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DG1K5QcuKaZei1yYsviExssuu4zLLrsMgKSkJAYOHFhkWQQKrkVERArI28vAaoWc9yxara7Bh0+oD+1eau+6U7Mwwvorp1rKnrKYc3225557rkjrV3AtIiJSQBkZpltgDZBhU8alSGmX9byT06dP43C4XoIyDMPlIYHnQ8G1iIhIAfn4eB659vEu2yN7Inkp6yPXsbGx9OrVi82bN2OaJoZhOKfny/r/hQTX5XqeaxERkaKUluZ55Nrm/jwYkXKjrM9z/eijj/LHH3/w6aefsm/fPkzT5LvvvmP37t2MHj2aNm3acOTIkQLXr+BaRESkgPz9LTRr4utSZhhwSUvfXI4QkZK2fPlyRo0axc0330xwcDCQ+RDAhg0b8t5771G3bl0eeOCBAtev4FpEROQCjB1RieZnAuywUCtj7q5IzRre5zhKpOwq6yPXcXFxtGjRAoCgoCAAEhMTndu7d+/Od999V+D6lXMtIiJyASpX8uK5J6uRlubA29vAYjHIOOvpiyLlTVkLpnOqXr06x44dA8DX15cqVarw+++/c+ONNwIQFRWFcQHnqOBaRESkEPj66mKwSFkQGRnJqlWrePrppwG4+eabee2117BarTgcDiZPnsz1119f4PoVXIuIiIhIvpX1keuHHnqIVatWkZaWhq+vL+PHj+evv/5yzg4SGRnJlClTCly/gmsRERERyTezbMfWtGrVilatWjnXw8PD+f7774mLi8NqtTpvciwoBdciIiIikm9lfeQ6N2FhYYVSjxLEREREROSicvDgQUaPHk2TJk2oUKECa9euBSA6Oppx48axbdu2AtetkWsRERERybeyPnK9c+dOunTpgsPhoFOnTvz777/Yzjz5qVKlSqxfv56kpCQ++uijAtWv4FpERERE8s1RxoPrxx57jLCwMDZt2oRhGFSpUsVle69evfjiiy8KXL/SQkRERIqA4TBpvOEw1junwOSlkJxW0l0SEWDt2rWMGTOGypUre5zPunbt2kRFRRW4fo1ci4iIFCLTNAHo/t4W6vwZnVn46Xp4fyX89U7m89FFyjCTsv0z7HA4CAgIyHX7yZMn8fX1LXD9GrkWEREpBNO326kwxYbXW3Z6fpZB0N4U1x3+joKlv5VM50QKUVl//Hm7du345ptvPG6z2Wx8/vnndO7cucD1K7gWERG5QD8ecDDme5NTaeAw4fsTPvS+6wn3HT9ZU/ydEylkZT24fvLJJ/n2228ZM2YMf/75JwDHjx/n+++/p3v37vz999888YSH3998UlqIiIjIBXpqncOtbFOdxu47xiYVQ29EJC833HADs2fP5v777+f9998H4I477sA0TUJCQpg7dy6RkZEFrl/BtYiIyAX6Jza/e7oH4SJlTVkbqfZkyJAhDBgwgJUrV/Lvv//icDho0KAB119/vZ7QKCIiUtLs+Y2ZLcrGlLKvLD7+/KmnnuKWW26hdevWzrLAwED69+9f6G3pt1xERORCeQg2uu/a7l5oFnlPRMSDV1991ZlfDRATE4PVauXHH38s9LY0ci0iInKBzBxBs48tg48/f7dkOiNSxMr6Q2SymDl/cQuJgmsREZFC1vREFJWTEkq6GyJFojzkXBclpYWIiIgUsv8qVCHRp+APoRApzcr6VHxFTSPX5zBjxgyaNGnC1VdffUH1fPrppwQHB9OnT5/C6ZiIiJRaCX4BvHZVX55fNd91g6Gka5GSsn//frZu3QrA6dOnAdizZw9hYWEe92/Xrl2B2jHMoko4KSc6dOhA7969GT9+/AXV06dPHyIiIpzzKYqISPkRNNlGks21zNtmI/3J21wLu10CK58rvo6JFIFH+u9wK3tjUasS6En+WSwWjBwj7KZpupWdXW632wvUlkauRURELpCnq+IZVquHPTXPtZR9ZXEqvlmzZhVbW+cdXC9dupQJEyYwdepUfv/9dxYvXsypU6do2LAhjzzyCK1atWLLli1MnTqVXbt2ERgYyODBg/m///s/l3p27tzJzJkz2bZtG8nJyURERNCrVy+GDRuGl1d2t0aOHMnRo0eZOXMmkyZNYuPGjaSnp9O2bVseffRR6tSp41JvXFwcM2bMYO3atcTExFCxYkUiIyMZNWqUy7B/Wloas2fP5rvvvuP48eN4e3tTtWpVLr/8cu6//36OHDlC3759AVi2bBnLli1zHvvbb78BsHLlSlasWMHu3buJjY0lICCANm3aMHr0aBo1auTcv0OHDgAcPXrU+X+AJUuWUL169fN9C0REpLTxcA24SmKce6GhW51ESsKwYcOKra0Cj1y/++672O12brnlFmw2Gx9//DH33nsvEyZM4IUXXqB///7ccMMNrFq1iunTp1O9enV69uwJwPr163n00UepVasWd9xxByEhIezYsYMZM2awe/duJk6c6NJWSkoKI0aMoFWrVowdO5aoqCg+//xzHn74Yb744gusZ0YHEhMTueuuuzh06BB9+/aladOm7Nq1iwULFvDrr78yZ84cAgMDAZg4cSJLliyhV69e3H777djtdg4dOsSvv/4KQHh4OM8//zzPPvssbdu29TjJ+JdffkloaCj9+/enUqVKHD58mEWLFnH33Xfz8ccfU7t2bQCef/553nrrLcLCwrjrrrucx4eHhxf05RcRkVLE00hehtXb055F3heRomZ6mthdnAocXNvtdmbPno23d+Yfj3r16vHwww/z+OOPM2vWLJo3bw7AjTfeSO/evZk/fz49e/YkLS2NF154gZYtWzJt2jTnKPXAgQNp1KgRkyZN4rfffnMZ4Y2Li2PIkCEu3zrCw8N555132Lx5M5dddhkAc+bM4eDBgzz++OMMHjzYuW/jxo157bXXmDt3LmPGjAHgp59+4vLLL2fChAkez8/f35+ePXvy7LPPUqNGDecXg7NNmTIFf39/l7JevXpx22238emnn/LEE08A0LNnT6ZNm0aFChU81iMiImWbp1DDYxit2FrKgfIyz3VRKfD1qUGDBjkDa4C2bdsC0LJlS2dgDeDt7U2LFi04ePAgAL/88gsxMTH06dOHxMRE4uLinMsVV1zh3MelkxYLt9xyi0vZpZdeCuCsFzID5vDwcLdR5gEDBhAeHs7q1audZUFBQezbt49///23oC+BM7A2TdN5LuHh4dSpU8flKUClWWxsLGlpac71xMREEhKy52ZNT08nJibG5ZijR4/muX7s2DGXidnVhtpQG2qj3LfhIWgeuel798LSfh5qo8y0IaXXec8WcnbOdceOHV22dejQgRtuuIEXXnjBpXz8+PEsW7aM3377jTlz5jBlypQ82+jbty/PPvsskJlzHRUVxTfffOOyT1ZO9MiRIxk5ciQAV1xxBc2aNePDDz90q/Puu+/mn3/+4eeffwYyA/HnnnuOpKQkatSoQYcOHejSpQuRkZFYLNnfOfKaLeSff/5h+vTpbNmyhZSUFJdtNWrUYPHixc51zRYiIlJ+BU+2kXjWbCFVEuI4+sIoLDk/Yru1hpXji7VvIoXt/kE73creXtDcw54XpwKnhZwdgJ7N6vHu6GxZsfz9999P48aNPe5TuXLlfLV1dn3n6+qrr2bJkiX8/PPPbN26lc2bN7N4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adOmOeseOHAgjRo1YtKkSfz222906NCh+E5URESKTFK6yckzs+zVPJ1Exbh4l8A6iwOfzP9s3qPgWso2ZYXk6aK+odHb29sZ/NpsNuLj44mLi6Njx44A/PnnnwCsW7cOq9XKrbfe6nJ8v379CApyzZ/75ZdfiImJoU+fPiQmJhIXF+dcrrjiCuc+pUVsbCxpaWnO9cTERBISEpzr6enpxMS43pxz9OjRPNePHTuGaWbP96o21IbaUBvluY34mGNU8s/8f1RoALGhwSThxyGq8R81iCcQAAvpmfs3rloqz0NtlK02SpYmus6LYZ797l+E5s+fz1dffcW+fftwOBwu20aNGsWIESMYOHAgqampfPON+9O1brvtNhISEpw513PmzGHKlCl5ttm3b1+effbZwjsJEREpUT8ecHDdfDsWB/xvxa90WbML46xP1zocpg5/4DWsC8weV3IdFSkExjPJbmXmi5piMstFnRby8ccfM3nyZDp37swtt9xCpUqV8Pb25uTJk4wfP94t2M6PrO8q999/P40bN/a4T+XKlS+o3yIiUrpcW8fCxpscPDvhMPX3R7sE1gBHqYS/TyuqK7CW8kAD1Xm6qIPr5cuXU716dd555x0sluwMmQ0bNrjsV716dTZv3kxycjIBAdnfzGw2G0eOHCE4ONhZVrt2bQD8/f3p1KlTEZ+BiIiUFuk2qHU6GavNfWDGjjem/aK+UCzliYLrPF3UOddWqxXDMFzyomw2G7Nnz3bZr0uXLtjtdj777DOX8kWLFpGYmOhSdtlll1GhQgVmz57N6dOn3dpMTU0lKSmp8E5CRERKhcvrWPm3QjAnqoWQM4wOI4HgnrVLpF8ihU8513m5qEeur7vuOt59913GjRvHNddcQ1JSEt99953bPNT9+vVj4cKFTJs2jcOHDzun4vv++++pVasWdrvdua+/vz8TJkzgkUceYeDAgfTt25datWqRkJDA/v37Wb16Na+//rpmCxERKWe8rAZdWvuzPrUedodB4z1H8U3LIMRMwt/LJPiroSXdRREpBhd1cD1kyBBM02Tx4sW8+eabVKxYkW7dutG3b18GDx7s3M/Hx4dp06bx9ttvs2bNGlatWkXLli2ZOnUqL774IqmpqS71XnbZZcyZM4c5c+awYsUKTp06RUhICDVr1uT222+nUaNGxX2qIiJSDHbuTCPZ14fv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5ZVXEhgYSEREBC+88ILHur7++muuuOIKAgMDCQoK4oorrmDx4sUe9/3ggw9o2rQpvr6+NGzYkMmTJ+easnD69Gkef/xxGjZsiK+vL5UrV+bWW291ew/PV35f57zuWzAMgzvvvBPI/LmtV68ekDkIkPWeZ/2unf379dlnn9G6dWv8/PyoXbs248ePx2azudSd39/T/PysGYbB9ddfz7fffktiYuJ5vlIiZYNGrkUKqEGDBuzatYuFCxcyYMCAfB1jt9tzzalOS0vL9biPPvqIevXq0aVLFwzDoG3btsycOZP/+7//y3d/9+zZA0ClSpVy3eeWW27hwQcfZO7cufTt29dl2w8//EBUVJQz3QQyP0xjY2MZOnQoNWvWJCoqig8//JDrrruO1atX55m6UhBDhgzhs88+Y9CgQQwfPpy0tDQ++eQTunXrxsKFC936nNOWLVtITEykY8eO59Xue++9x6lTp/i///s//Pz8eOedd+jfvz/z589nxIgR3HrrrfTr14+VK1cyZcoUqlSpwjPPPONSR1JSEldffTWdOnXilVdeYc+ePUydOpVNmzaxbds255ex9PR0Xn/9dQYOHMiNN95IYGAgv/76Kx999BHr1693S+t5+umnefnll2nevDkPPvggERER7N27l6+++ornn3+eyMhInnrqKV5++WVGjhzpfE+qVq2a5zkfOHCAjh07cvr0ae655x4aNWrETz/9xCuvvMLPP//MDz/8gJeX60fIsGHD8Pb25pFHHiE9PZ3JkyfTr18/du/e7TE48+SJJ57Abrdz//33k56ezptvvkn37t2ZO3cud999NyNHjuT222/nyy+/5Nlnn6VevXouV2mmTp3K2LFjadq0Kc8++yyQ+XPar18/ZsyYwciRI537Tp48mQcffJBLLrmEl19+meTkZN544w2qVKni1q/Tp09z+eWXc/DgQe666y5atGjB0aNHmTp1Kp06deK3336jTp06+TrHC32dz6VZs2ZMmjSJBx98kP79+zv/PgUFBbnst2TJEvbt28fYsWOpVq0aS5YsYcKECRw4cIBZs2ad97nk92ftsssuY8aMGaxfv54ePXqcdzsipZ4pIgWyYcMG09vb2wTMRo0amcOHDzenTp1q7ty50+P+derUMYFzLidPnnQ5LioqyrRareZzzz3nLJs8ebIJeGwLMLt3726ePHnSPHny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\n"
},
"metadata": {}
}
]
},
{
"cell_type": "code",
"metadata": {
"id": "ZNHQ-bkWALNy",
"outputId": "16d9b6fb-f5dd-4c20-8896-6171641412b0",
"colab": {
"base_uri": "https://localhost:8080/"
}
},
"source": [
"from scipy.stats import reciprocal\n",
"from sklearn.model_selection import RandomizedSearchCV\n",
"\n",
"param_distributions = {\n",
" 'alpha': reciprocal(0.1, 100),\n",
"}\n",
"\n",
"model_random_search = RandomizedSearchCV(\n",
" cox, param_distributions=param_distributions, n_iter=50, n_jobs=-1, cv=3, random_state=42)\n",
"model_random_search.fit(X_trn, y_trn)\n",
"\n",
"print(\n",
" f\"The c-index of Cox using a {model_random_search.__class__.__name__} is \"\n",
" f\"{model_random_search.score(X_test, y_test):.3f}\")\n",
"print(\n",
" f\"The best set of parameters is: {model_random_search.best_params_}\"\n",
")"
],
"execution_count": null,
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"The c-index of Cox using a RandomizedSearchCV is 0.660\n",
"The best set of parameters is: {'alpha': 39.67605077052987}\n"
]
}
]
},
{
"cell_type": "code",
"metadata": {
"id": "MrhAveCQAdxF",
"outputId": "7d7474e5-2f54-425a-84ec-5b7f2b701f0e",
"colab": {
"base_uri": "https://localhost:8080/"
}
},
"source": [
"alpha = model_random_search.best_params_['alpha']\n",
"cox_best = make_pipeline(CoxPHSurvivalAnalysis(alpha=alpha))\n",
"cox_best.fit(X_trn, y_trn)\n",
"\n",
"ci_cox = concordance_index_censored(y_test[\"cens\"], y_test[\"time\"], cox_best.predict(X_test))\n",
"print(f'The c-index of Cox is given by {ci_cox[0]:.3f}')"
],
"execution_count": null,
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"The c-index of Cox is given by 0.660\n"
]
}
]
},
{
"cell_type": "code",
"source": [
"from sksurv.ensemble import RandomSurvivalForest"
],
"metadata": {
"id": "s34_kkDKKzw5"
},
"execution_count": 37,
"outputs": []
},
{
"cell_type": "code",
"source": [
"rsf = RandomSurvivalForest(\n",
" n_estimators=100, min_samples_leaf=15, n_jobs=-1, random_state=20\n",
")\n",
"rsf.fit(X_trn, y_trn)"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 80
},
"id": "vU06jwE7Kuec",
"outputId": "0c61ad2e-539b-4b21-ad9d-881ce7042b9d"
},
"execution_count": 38,
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
"RandomSurvivalForest(min_samples_leaf=15, n_jobs=-1, random_state=20)"
],
"text/html": [
"<style>#sk-container-id-2 {\n",
" /* Definition of color scheme common for light and dark mode */\n",
" --sklearn-color-text: black;\n",
" --sklearn-color-line: gray;\n",
" /* Definition of color scheme for unfitted estimators */\n",
" --sklearn-color-unfitted-level-0: #fff5e6;\n",
" --sklearn-color-unfitted-level-1: #f6e4d2;\n",
" --sklearn-color-unfitted-level-2: #ffe0b3;\n",
" --sklearn-color-unfitted-level-3: chocolate;\n",
" /* Definition of color scheme for fitted estimators */\n",
" --sklearn-color-fitted-level-0: #f0f8ff;\n",
" --sklearn-color-fitted-level-1: #d4ebff;\n",
" --sklearn-color-fitted-level-2: #b3dbfd;\n",
" --sklearn-color-fitted-level-3: cornflowerblue;\n",
"\n",
" /* Specific color for light theme */\n",
" --sklearn-color-text-on-default-background: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, black)));\n",
" --sklearn-color-background: var(--sg-background-color, var(--theme-background, var(--jp-layout-color0, white)));\n",
" --sklearn-color-border-box: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, black)));\n",
" --sklearn-color-icon: #696969;\n",
"\n",
" @media (prefers-color-scheme: dark) {\n",
" /* Redefinition of color scheme for dark theme */\n",
" --sklearn-color-text-on-default-background: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, white)));\n",
" --sklearn-color-background: var(--sg-background-color, var(--theme-background, var(--jp-layout-color0, #111)));\n",
" --sklearn-color-border-box: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, white)));\n",
" --sklearn-color-icon: #878787;\n",
" }\n",
"}\n",
"\n",
"#sk-container-id-2 {\n",
" color: var(--sklearn-color-text);\n",
"}\n",
"\n",
"#sk-container-id-2 pre {\n",
" padding: 0;\n",
"}\n",
"\n",
"#sk-container-id-2 input.sk-hidden--visually {\n",
" border: 0;\n",
" clip: rect(1px 1px 1px 1px);\n",
" clip: rect(1px, 1px, 1px, 1px);\n",
" height: 1px;\n",
" margin: -1px;\n",
" overflow: hidden;\n",
" padding: 0;\n",
" position: absolute;\n",
" width: 1px;\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-dashed-wrapped {\n",
" border: 1px dashed var(--sklearn-color-line);\n",
" margin: 0 0.4em 0.5em 0.4em;\n",
" box-sizing: border-box;\n",
" padding-bottom: 0.4em;\n",
" background-color: var(--sklearn-color-background);\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-container {\n",
" /* jupyter's `normalize.less` sets `[hidden] { display: none; }`\n",
" but bootstrap.min.css set `[hidden] { display: none !important; }`\n",
" so we also need the `!important` here to be able to override the\n",
" default hidden behavior on the sphinx rendered scikit-learn.org.\n",
" See: https://github.com/scikit-learn/scikit-learn/issues/21755 */\n",
" display: inline-block !important;\n",
" position: relative;\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-text-repr-fallback {\n",
" display: none;\n",
"}\n",
"\n",
"div.sk-parallel-item,\n",
"div.sk-serial,\n",
"div.sk-item {\n",
" /* draw centered vertical line to link estimators */\n",
" background-image: linear-gradient(var(--sklearn-color-text-on-default-background), var(--sklearn-color-text-on-default-background));\n",
" background-size: 2px 100%;\n",
" background-repeat: no-repeat;\n",
" background-position: center center;\n",
"}\n",
"\n",
"/* Parallel-specific style estimator block */\n",
"\n",
"#sk-container-id-2 div.sk-parallel-item::after {\n",
" content: \"\";\n",
" width: 100%;\n",
" border-bottom: 2px solid var(--sklearn-color-text-on-default-background);\n",
" flex-grow: 1;\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-parallel {\n",
" display: flex;\n",
" align-items: stretch;\n",
" justify-content: center;\n",
" background-color: var(--sklearn-color-background);\n",
" position: relative;\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-parallel-item {\n",
" display: flex;\n",
" flex-direction: column;\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-parallel-item:first-child::after {\n",
" align-self: flex-end;\n",
" width: 50%;\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-parallel-item:last-child::after {\n",
" align-self: flex-start;\n",
" width: 50%;\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-parallel-item:only-child::after {\n",
" width: 0;\n",
"}\n",
"\n",
"/* Serial-specific style estimator block */\n",
"\n",
"#sk-container-id-2 div.sk-serial {\n",
" display: flex;\n",
" flex-direction: column;\n",
" align-items: center;\n",
" background-color: var(--sklearn-color-background);\n",
" padding-right: 1em;\n",
" padding-left: 1em;\n",
"}\n",
"\n",
"\n",
"/* Toggleable style: style used for estimator/Pipeline/ColumnTransformer box that is\n",
"clickable and can be expanded/collapsed.\n",
"- Pipeline and ColumnTransformer use this feature and define the default style\n",
"- Estimators will overwrite some part of the style using the `sk-estimator` class\n",
"*/\n",
"\n",
"/* Pipeline and ColumnTransformer style (default) */\n",
"\n",
"#sk-container-id-2 div.sk-toggleable {\n",
" /* Default theme specific background. It is overwritten whether we have a\n",
" specific estimator or a Pipeline/ColumnTransformer */\n",
" background-color: var(--sklearn-color-background);\n",
"}\n",
"\n",
"/* Toggleable label */\n",
"#sk-container-id-2 label.sk-toggleable__label {\n",
" cursor: pointer;\n",
" display: block;\n",
" width: 100%;\n",
" margin-bottom: 0;\n",
" padding: 0.5em;\n",
" box-sizing: border-box;\n",
" text-align: center;\n",
"}\n",
"\n",
"#sk-container-id-2 label.sk-toggleable__label-arrow:before {\n",
" /* Arrow on the left of the label */\n",
" content: \"▸\";\n",
" float: left;\n",
" margin-right: 0.25em;\n",
" color: var(--sklearn-color-icon);\n",
"}\n",
"\n",
"#sk-container-id-2 label.sk-toggleable__label-arrow:hover:before {\n",
" color: var(--sklearn-color-text);\n",
"}\n",
"\n",
"/* Toggleable content - dropdown */\n",
"\n",
"#sk-container-id-2 div.sk-toggleable__content {\n",
" max-height: 0;\n",
" max-width: 0;\n",
" overflow: hidden;\n",
" text-align: left;\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-0);\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-toggleable__content.fitted {\n",
" /* fitted */\n",
" background-color: var(--sklearn-color-fitted-level-0);\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-toggleable__content pre {\n",
" margin: 0.2em;\n",
" border-radius: 0.25em;\n",
" color: var(--sklearn-color-text);\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-0);\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-toggleable__content.fitted pre {\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-fitted-level-0);\n",
"}\n",
"\n",
"#sk-container-id-2 input.sk-toggleable__control:checked~div.sk-toggleable__content {\n",
" /* Expand drop-down */\n",
" max-height: 200px;\n",
" max-width: 100%;\n",
" overflow: auto;\n",
"}\n",
"\n",
"#sk-container-id-2 input.sk-toggleable__control:checked~label.sk-toggleable__label-arrow:before {\n",
" content: \"▾\";\n",
"}\n",
"\n",
"/* Pipeline/ColumnTransformer-specific style */\n",
"\n",
"#sk-container-id-2 div.sk-label input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
" color: var(--sklearn-color-text);\n",
" background-color: var(--sklearn-color-unfitted-level-2);\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-label.fitted input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
" background-color: var(--sklearn-color-fitted-level-2);\n",
"}\n",
"\n",
"/* Estimator-specific style */\n",
"\n",
"/* Colorize estimator box */\n",
"#sk-container-id-2 div.sk-estimator input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-2);\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-estimator.fitted input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
" /* fitted */\n",
" background-color: var(--sklearn-color-fitted-level-2);\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-label label.sk-toggleable__label,\n",
"#sk-container-id-2 div.sk-label label {\n",
" /* The background is the default theme color */\n",
" color: var(--sklearn-color-text-on-default-background);\n",
"}\n",
"\n",
"/* On hover, darken the color of the background */\n",
"#sk-container-id-2 div.sk-label:hover label.sk-toggleable__label {\n",
" color: var(--sklearn-color-text);\n",
" background-color: var(--sklearn-color-unfitted-level-2);\n",
"}\n",
"\n",
"/* Label box, darken color on hover, fitted */\n",
"#sk-container-id-2 div.sk-label.fitted:hover label.sk-toggleable__label.fitted {\n",
" color: var(--sklearn-color-text);\n",
" background-color: var(--sklearn-color-fitted-level-2);\n",
"}\n",
"\n",
"/* Estimator label */\n",
"\n",
"#sk-container-id-2 div.sk-label label {\n",
" font-family: monospace;\n",
" font-weight: bold;\n",
" display: inline-block;\n",
" line-height: 1.2em;\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-label-container {\n",
" text-align: center;\n",
"}\n",
"\n",
"/* Estimator-specific */\n",
"#sk-container-id-2 div.sk-estimator {\n",
" font-family: monospace;\n",
" border: 1px dotted var(--sklearn-color-border-box);\n",
" border-radius: 0.25em;\n",
" box-sizing: border-box;\n",
" margin-bottom: 0.5em;\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-0);\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-estimator.fitted {\n",
" /* fitted */\n",
" background-color: var(--sklearn-color-fitted-level-0);\n",
"}\n",
"\n",
"/* on hover */\n",
"#sk-container-id-2 div.sk-estimator:hover {\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-2);\n",
"}\n",
"\n",
"#sk-container-id-2 div.sk-estimator.fitted:hover {\n",
" /* fitted */\n",
" background-color: var(--sklearn-color-fitted-level-2);\n",
"}\n",
"\n",
"/* Specification for estimator info (e.g. \"i\" and \"?\") */\n",
"\n",
"/* Common style for \"i\" and \"?\" */\n",
"\n",
".sk-estimator-doc-link,\n",
"a:link.sk-estimator-doc-link,\n",
"a:visited.sk-estimator-doc-link {\n",
" float: right;\n",
" font-size: smaller;\n",
" line-height: 1em;\n",
" font-family: monospace;\n",
" background-color: var(--sklearn-color-background);\n",
" border-radius: 1em;\n",
" height: 1em;\n",
" width: 1em;\n",
" text-decoration: none !important;\n",
" margin-left: 1ex;\n",
" /* unfitted */\n",
" border: var(--sklearn-color-unfitted-level-1) 1pt solid;\n",
" color: var(--sklearn-color-unfitted-level-1);\n",
"}\n",
"\n",
".sk-estimator-doc-link.fitted,\n",
"a:link.sk-estimator-doc-link.fitted,\n",
"a:visited.sk-estimator-doc-link.fitted {\n",
" /* fitted */\n",
" border: var(--sklearn-color-fitted-level-1) 1pt solid;\n",
" color: var(--sklearn-color-fitted-level-1);\n",
"}\n",
"\n",
"/* On hover */\n",
"div.sk-estimator:hover .sk-estimator-doc-link:hover,\n",
".sk-estimator-doc-link:hover,\n",
"div.sk-label-container:hover .sk-estimator-doc-link:hover,\n",
".sk-estimator-doc-link:hover {\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-3);\n",
" color: var(--sklearn-color-background);\n",
" text-decoration: none;\n",
"}\n",
"\n",
"div.sk-estimator.fitted:hover .sk-estimator-doc-link.fitted:hover,\n",
".sk-estimator-doc-link.fitted:hover,\n",
"div.sk-label-container:hover .sk-estimator-doc-link.fitted:hover,\n",
".sk-estimator-doc-link.fitted:hover {\n",
" /* fitted */\n",
" background-color: var(--sklearn-color-fitted-level-3);\n",
" color: var(--sklearn-color-background);\n",
" text-decoration: none;\n",
"}\n",
"\n",
"/* Span, style for the box shown on hovering the info icon */\n",
".sk-estimator-doc-link span {\n",
" display: none;\n",
" z-index: 9999;\n",
" position: relative;\n",
" font-weight: normal;\n",
" right: .2ex;\n",
" padding: .5ex;\n",
" margin: .5ex;\n",
" width: min-content;\n",
" min-width: 20ex;\n",
" max-width: 50ex;\n",
" color: var(--sklearn-color-text);\n",
" box-shadow: 2pt 2pt 4pt #999;\n",
" /* unfitted */\n",
" background: var(--sklearn-color-unfitted-level-0);\n",
" border: .5pt solid var(--sklearn-color-unfitted-level-3);\n",
"}\n",
"\n",
".sk-estimator-doc-link.fitted span {\n",
" /* fitted */\n",
" background: var(--sklearn-color-fitted-level-0);\n",
" border: var(--sklearn-color-fitted-level-3);\n",
"}\n",
"\n",
".sk-estimator-doc-link:hover span {\n",
" display: block;\n",
"}\n",
"\n",
"/* \"?\"-specific style due to the `<a>` HTML tag */\n",
"\n",
"#sk-container-id-2 a.estimator_doc_link {\n",
" float: right;\n",
" font-size: 1rem;\n",
" line-height: 1em;\n",
" font-family: monospace;\n",
" background-color: var(--sklearn-color-background);\n",
" border-radius: 1rem;\n",
" height: 1rem;\n",
" width: 1rem;\n",
" text-decoration: none;\n",
" /* unfitted */\n",
" color: var(--sklearn-color-unfitted-level-1);\n",
" border: var(--sklearn-color-unfitted-level-1) 1pt solid;\n",
"}\n",
"\n",
"#sk-container-id-2 a.estimator_doc_link.fitted {\n",
" /* fitted */\n",
" border: var(--sklearn-color-fitted-level-1) 1pt solid;\n",
" color: var(--sklearn-color-fitted-level-1);\n",
"}\n",
"\n",
"/* On hover */\n",
"#sk-container-id-2 a.estimator_doc_link:hover {\n",
" /* unfitted */\n",
" background-color: var(--sklearn-color-unfitted-level-3);\n",
" color: var(--sklearn-color-background);\n",
" text-decoration: none;\n",
"}\n",
"\n",
"#sk-container-id-2 a.estimator_doc_link.fitted:hover {\n",
" /* fitted */\n",
" background-color: var(--sklearn-color-fitted-level-3);\n",
"}\n",
"</style><div id=\"sk-container-id-2\" class=\"sk-top-container\"><div class=\"sk-text-repr-fallback\"><pre>RandomSurvivalForest(min_samples_leaf=15, n_jobs=-1, random_state=20)</pre><b>In a Jupyter environment, please rerun this cell to show the HTML representation or trust the notebook. <br />On GitHub, the HTML representation is unable to render, please try loading this page with nbviewer.org.</b></div><div class=\"sk-container\" hidden><div class=\"sk-item\"><div class=\"sk-estimator fitted sk-toggleable\"><input class=\"sk-toggleable__control sk-hidden--visually\" id=\"sk-estimator-id-2\" type=\"checkbox\" checked><label for=\"sk-estimator-id-2\" class=\"sk-toggleable__label fitted sk-toggleable__label-arrow fitted\">&nbsp;RandomSurvivalForest<span class=\"sk-estimator-doc-link fitted\">i<span>Fitted</span></span></label><div class=\"sk-toggleable__content fitted\"><pre>RandomSurvivalForest(min_samples_leaf=15, n_jobs=-1, random_state=20)</pre></div> </div></div></div></div>"
]
},
"metadata": {},
"execution_count": 38
}
]
},
{
"cell_type": "code",
"source": [
"rsf.score(X_test, y_test)"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "LJ0Tp63pKvMJ",
"outputId": "64980f97-2284-4bfd-bb36-444e2aa9c971"
},
"execution_count": 39,
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
"0.6785901467505241"
]
},
"metadata": {},
"execution_count": 39
}
]
},
{
"cell_type": "code",
"source": [
"ci_cox = concordance_index_censored(y_test[\"cens\"], y_test[\"time\"], rsf.predict(X_test))\n",
"print(f'The c-index of Cox is given by {ci_cox[0]:.3f}')"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "Y1hNGO_QO2pW",
"outputId": "dea05184-dfaa-43d0-e2a9-31667eaeda33"
},
"execution_count": 40,
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"The c-index of Cox is given by 0.679\n"
]
}
]
},
{
"cell_type": "code",
"source": [
"times = np.arange(365, 1826)"
],
"metadata": {
"id": "XHsIhuW7PHik"
},
"execution_count": 41,
"outputs": []
},
{
"cell_type": "code",
"source": [
"survs = rsf.predict_survival_function(X_test)"
],
"metadata": {
"id": "iSZ0pa17PSJS"
},
"execution_count": 42,
"outputs": []
},
{
"cell_type": "code",
"source": [
"preds = np.asarray([[fn(t) for t in times] for fn in survs])"
],
"metadata": {
"id": "np-god8mPW5W"
},
"execution_count": 43,
"outputs": []
},
{
"cell_type": "code",
"source": [
"integrated_brier_score(y_trn, y_test, preds, times)"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "U1avp5nfPaOS",
"outputId": "396c114b-abfc-460e-d9b5-91ab544e31d3"
},
"execution_count": 44,
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
"0.17664251295573888"
]
},
"metadata": {},
"execution_count": 44
}
]
},
{
"cell_type": "code",
"source": [
"param_distributions = {\n",
" 'min_samples_leaf': [3, 7, 15],\n",
" 'max_depth': [3, 7, None]\n",
"}\n",
"\n",
"model_random_search = RandomizedSearchCV(\n",
" rsf, param_distributions=param_distributions, n_iter=50, n_jobs=-1, cv=3, random_state=42)\n",
"model_random_search.fit(X_trn, y_trn)"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 134
},
"id": "QjiQ8TfBPfZg",
"outputId": "b9697241-63cd-448a-f779-024bea222c72"
},
"execution_count": null,
"outputs": [
{
"output_type": "stream",
"name": "stderr",
"text": [
"The total space of parameters 9 is smaller than n_iter=50. Running 9 iterations. For exhaustive searches, use GridSearchCV.\n"
]
},
{
"output_type": "execute_result",
"data": {
"text/plain": [
"RandomizedSearchCV(cv=3,\n",
" estimator=RandomSurvivalForest(min_samples_leaf=15,\n",
" n_jobs=-1, random_state=20),\n",
" n_iter=50, n_jobs=-1,\n",
" param_distributions={'max_depth': [3, 7, None],\n",
" 'min_samples_leaf': [3, 7, 15]},\n",
" random_state=42)"
],
"text/html": [
"<style>#sk-container-id-3 {color: black;background-color: white;}#sk-container-id-3 pre{padding: 0;}#sk-container-id-3 div.sk-toggleable {background-color: white;}#sk-container-id-3 label.sk-toggleable__label {cursor: pointer;display: block;width: 100%;margin-bottom: 0;padding: 0.3em;box-sizing: border-box;text-align: center;}#sk-container-id-3 label.sk-toggleable__label-arrow:before {content: \"▸\";float: left;margin-right: 0.25em;color: #696969;}#sk-container-id-3 label.sk-toggleable__label-arrow:hover:before {color: black;}#sk-container-id-3 div.sk-estimator:hover label.sk-toggleable__label-arrow:before {color: black;}#sk-container-id-3 div.sk-toggleable__content {max-height: 0;max-width: 0;overflow: hidden;text-align: left;background-color: #f0f8ff;}#sk-container-id-3 div.sk-toggleable__content pre {margin: 0.2em;color: black;border-radius: 0.25em;background-color: #f0f8ff;}#sk-container-id-3 input.sk-toggleable__control:checked~div.sk-toggleable__content {max-height: 200px;max-width: 100%;overflow: auto;}#sk-container-id-3 input.sk-toggleable__control:checked~label.sk-toggleable__label-arrow:before {content: \"▾\";}#sk-container-id-3 div.sk-estimator input.sk-toggleable__control:checked~label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-3 div.sk-label input.sk-toggleable__control:checked~label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-3 input.sk-hidden--visually {border: 0;clip: rect(1px 1px 1px 1px);clip: rect(1px, 1px, 1px, 1px);height: 1px;margin: -1px;overflow: hidden;padding: 0;position: absolute;width: 1px;}#sk-container-id-3 div.sk-estimator {font-family: monospace;background-color: #f0f8ff;border: 1px dotted black;border-radius: 0.25em;box-sizing: border-box;margin-bottom: 0.5em;}#sk-container-id-3 div.sk-estimator:hover {background-color: #d4ebff;}#sk-container-id-3 div.sk-parallel-item::after {content: \"\";width: 100%;border-bottom: 1px solid gray;flex-grow: 1;}#sk-container-id-3 div.sk-label:hover label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-3 div.sk-serial::before {content: \"\";position: absolute;border-left: 1px solid gray;box-sizing: border-box;top: 0;bottom: 0;left: 50%;z-index: 0;}#sk-container-id-3 div.sk-serial {display: flex;flex-direction: column;align-items: center;background-color: white;padding-right: 0.2em;padding-left: 0.2em;position: relative;}#sk-container-id-3 div.sk-item {position: relative;z-index: 1;}#sk-container-id-3 div.sk-parallel {display: flex;align-items: stretch;justify-content: center;background-color: white;position: relative;}#sk-container-id-3 div.sk-item::before, #sk-container-id-3 div.sk-parallel-item::before {content: \"\";position: absolute;border-left: 1px solid gray;box-sizing: border-box;top: 0;bottom: 0;left: 50%;z-index: -1;}#sk-container-id-3 div.sk-parallel-item {display: flex;flex-direction: column;z-index: 1;position: relative;background-color: white;}#sk-container-id-3 div.sk-parallel-item:first-child::after {align-self: flex-end;width: 50%;}#sk-container-id-3 div.sk-parallel-item:last-child::after {align-self: flex-start;width: 50%;}#sk-container-id-3 div.sk-parallel-item:only-child::after {width: 0;}#sk-container-id-3 div.sk-dashed-wrapped {border: 1px dashed gray;margin: 0 0.4em 0.5em 0.4em;box-sizing: border-box;padding-bottom: 0.4em;background-color: white;}#sk-container-id-3 div.sk-label label {font-family: monospace;font-weight: bold;display: inline-block;line-height: 1.2em;}#sk-container-id-3 div.sk-label-container {text-align: center;}#sk-container-id-3 div.sk-container {/* jupyter's `normalize.less` sets `[hidden] { display: none; }` but bootstrap.min.css set `[hidden] { display: none !important; }` so we also need the `!important` here to be able to override the default hidden behavior on the sphinx rendered scikit-learn.org. See: https://github.com/scikit-learn/scikit-learn/issues/21755 */display: inline-block !important;position: relative;}#sk-container-id-3 div.sk-text-repr-fallback {display: none;}</style><div id=\"sk-container-id-3\" class=\"sk-top-container\"><div class=\"sk-text-repr-fallback\"><pre>RandomizedSearchCV(cv=3,\n",
" estimator=RandomSurvivalForest(min_samples_leaf=15,\n",
" n_jobs=-1, random_state=20),\n",
" n_iter=50, n_jobs=-1,\n",
" param_distributions={&#x27;max_depth&#x27;: [3, 7, None],\n",
" &#x27;min_samples_leaf&#x27;: [3, 7, 15]},\n",
" random_state=42)</pre><b>In a Jupyter environment, please rerun this cell to show the HTML representation or trust the notebook. <br />On GitHub, the HTML representation is unable to render, please try loading this page with nbviewer.org.</b></div><div class=\"sk-container\" hidden><div class=\"sk-item sk-dashed-wrapped\"><div class=\"sk-label-container\"><div class=\"sk-label sk-toggleable\"><input class=\"sk-toggleable__control sk-hidden--visually\" id=\"sk-estimator-id-3\" type=\"checkbox\" ><label for=\"sk-estimator-id-3\" class=\"sk-toggleable__label sk-toggleable__label-arrow\">RandomizedSearchCV</label><div class=\"sk-toggleable__content\"><pre>RandomizedSearchCV(cv=3,\n",
" estimator=RandomSurvivalForest(min_samples_leaf=15,\n",
" n_jobs=-1, random_state=20),\n",
" n_iter=50, n_jobs=-1,\n",
" param_distributions={&#x27;max_depth&#x27;: [3, 7, None],\n",
" &#x27;min_samples_leaf&#x27;: [3, 7, 15]},\n",
" random_state=42)</pre></div></div></div><div class=\"sk-parallel\"><div class=\"sk-parallel-item\"><div class=\"sk-item\"><div class=\"sk-label-container\"><div class=\"sk-label sk-toggleable\"><input class=\"sk-toggleable__control sk-hidden--visually\" id=\"sk-estimator-id-4\" type=\"checkbox\" ><label for=\"sk-estimator-id-4\" class=\"sk-toggleable__label sk-toggleable__label-arrow\">estimator: RandomSurvivalForest</label><div class=\"sk-toggleable__content\"><pre>RandomSurvivalForest(min_samples_leaf=15, n_jobs=-1, random_state=20)</pre></div></div></div><div class=\"sk-serial\"><div class=\"sk-item\"><div class=\"sk-estimator sk-toggleable\"><input class=\"sk-toggleable__control sk-hidden--visually\" id=\"sk-estimator-id-5\" type=\"checkbox\" ><label for=\"sk-estimator-id-5\" class=\"sk-toggleable__label sk-toggleable__label-arrow\">RandomSurvivalForest</label><div class=\"sk-toggleable__content\"><pre>RandomSurvivalForest(min_samples_leaf=15, n_jobs=-1, random_state=20)</pre></div></div></div></div></div></div></div></div></div></div>"
]
},
"metadata": {},
"execution_count": 38
}
]
},
{
"cell_type": "code",
"source": [
"model_random_search.score(X_test, y_test)"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "_X2klnTmQVXX",
"outputId": "48b05237-4a2f-4757-bdc2-b0c975417845"
},
"execution_count": null,
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
"0.6805555555555556"
]
},
"metadata": {},
"execution_count": 39
}
]
},
{
"cell_type": "code",
"source": [
"print(\n",
" f\"The best set of parameters is: {model_random_search.best_params_}\"\n",
")"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "6Mam6JN2Qqh3",
"outputId": "30e8221a-6cef-46cd-8b0e-ef3faf08e9c1"
},
"execution_count": null,
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"The best set of parameters is: {'min_samples_leaf': 15, 'max_depth': 3}\n"
]
}
]
},
{
"cell_type": "code",
"source": [
"rsf_best = RandomSurvivalForest(\n",
" n_estimators=100, min_samples_leaf=15, max_depth=3, n_jobs=-1, random_state=20\n",
")\n",
"rsf_best.fit(X_trn, y_trn)"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 91
},
"id": "PbSNPjgQQruO",
"outputId": "41a76e72-7928-4a0a-8186-3966912f9582"
},
"execution_count": null,
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
"RandomSurvivalForest(max_depth=3, min_samples_leaf=15, n_jobs=-1,\n",
" random_state=20)"
],
"text/html": [
"<style>#sk-container-id-4 {color: black;background-color: white;}#sk-container-id-4 pre{padding: 0;}#sk-container-id-4 div.sk-toggleable {background-color: white;}#sk-container-id-4 label.sk-toggleable__label {cursor: pointer;display: block;width: 100%;margin-bottom: 0;padding: 0.3em;box-sizing: border-box;text-align: center;}#sk-container-id-4 label.sk-toggleable__label-arrow:before {content: \"▸\";float: left;margin-right: 0.25em;color: #696969;}#sk-container-id-4 label.sk-toggleable__label-arrow:hover:before {color: black;}#sk-container-id-4 div.sk-estimator:hover label.sk-toggleable__label-arrow:before {color: black;}#sk-container-id-4 div.sk-toggleable__content {max-height: 0;max-width: 0;overflow: hidden;text-align: left;background-color: #f0f8ff;}#sk-container-id-4 div.sk-toggleable__content pre {margin: 0.2em;color: black;border-radius: 0.25em;background-color: #f0f8ff;}#sk-container-id-4 input.sk-toggleable__control:checked~div.sk-toggleable__content {max-height: 200px;max-width: 100%;overflow: auto;}#sk-container-id-4 input.sk-toggleable__control:checked~label.sk-toggleable__label-arrow:before {content: \"▾\";}#sk-container-id-4 div.sk-estimator input.sk-toggleable__control:checked~label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-4 div.sk-label input.sk-toggleable__control:checked~label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-4 input.sk-hidden--visually {border: 0;clip: rect(1px 1px 1px 1px);clip: rect(1px, 1px, 1px, 1px);height: 1px;margin: -1px;overflow: hidden;padding: 0;position: absolute;width: 1px;}#sk-container-id-4 div.sk-estimator {font-family: monospace;background-color: #f0f8ff;border: 1px dotted black;border-radius: 0.25em;box-sizing: border-box;margin-bottom: 0.5em;}#sk-container-id-4 div.sk-estimator:hover {background-color: #d4ebff;}#sk-container-id-4 div.sk-parallel-item::after {content: \"\";width: 100%;border-bottom: 1px solid gray;flex-grow: 1;}#sk-container-id-4 div.sk-label:hover label.sk-toggleable__label {background-color: #d4ebff;}#sk-container-id-4 div.sk-serial::before {content: \"\";position: absolute;border-left: 1px solid gray;box-sizing: border-box;top: 0;bottom: 0;left: 50%;z-index: 0;}#sk-container-id-4 div.sk-serial {display: flex;flex-direction: column;align-items: center;background-color: white;padding-right: 0.2em;padding-left: 0.2em;position: relative;}#sk-container-id-4 div.sk-item {position: relative;z-index: 1;}#sk-container-id-4 div.sk-parallel {display: flex;align-items: stretch;justify-content: center;background-color: white;position: relative;}#sk-container-id-4 div.sk-item::before, #sk-container-id-4 div.sk-parallel-item::before {content: \"\";position: absolute;border-left: 1px solid gray;box-sizing: border-box;top: 0;bottom: 0;left: 50%;z-index: -1;}#sk-container-id-4 div.sk-parallel-item {display: flex;flex-direction: column;z-index: 1;position: relative;background-color: white;}#sk-container-id-4 div.sk-parallel-item:first-child::after {align-self: flex-end;width: 50%;}#sk-container-id-4 div.sk-parallel-item:last-child::after {align-self: flex-start;width: 50%;}#sk-container-id-4 div.sk-parallel-item:only-child::after {width: 0;}#sk-container-id-4 div.sk-dashed-wrapped {border: 1px dashed gray;margin: 0 0.4em 0.5em 0.4em;box-sizing: border-box;padding-bottom: 0.4em;background-color: white;}#sk-container-id-4 div.sk-label label {font-family: monospace;font-weight: bold;display: inline-block;line-height: 1.2em;}#sk-container-id-4 div.sk-label-container {text-align: center;}#sk-container-id-4 div.sk-container {/* jupyter's `normalize.less` sets `[hidden] { display: none; }` but bootstrap.min.css set `[hidden] { display: none !important; }` so we also need the `!important` here to be able to override the default hidden behavior on the sphinx rendered scikit-learn.org. See: https://github.com/scikit-learn/scikit-learn/issues/21755 */display: inline-block !important;position: relative;}#sk-container-id-4 div.sk-text-repr-fallback {display: none;}</style><div id=\"sk-container-id-4\" class=\"sk-top-container\"><div class=\"sk-text-repr-fallback\"><pre>RandomSurvivalForest(max_depth=3, min_samples_leaf=15, n_jobs=-1,\n",
" random_state=20)</pre><b>In a Jupyter environment, please rerun this cell to show the HTML representation or trust the notebook. <br />On GitHub, the HTML representation is unable to render, please try loading this page with nbviewer.org.</b></div><div class=\"sk-container\" hidden><div class=\"sk-item\"><div class=\"sk-estimator sk-toggleable\"><input class=\"sk-toggleable__control sk-hidden--visually\" id=\"sk-estimator-id-6\" type=\"checkbox\" checked><label for=\"sk-estimator-id-6\" class=\"sk-toggleable__label sk-toggleable__label-arrow\">RandomSurvivalForest</label><div class=\"sk-toggleable__content\"><pre>RandomSurvivalForest(max_depth=3, min_samples_leaf=15, n_jobs=-1,\n",
" random_state=20)</pre></div></div></div></div></div>"
]
},
"metadata": {},
"execution_count": 41
}
]
},
{
"cell_type": "code",
"source": [
"times = np.arange(365, 1826)\n",
"survs = rsf_best.predict_survival_function(X_test)"
],
"metadata": {
"id": "iO5hU-exQZup"
},
"execution_count": null,
"outputs": []
},
{
"cell_type": "code",
"source": [
"preds = np.asarray([[fn(t) for t in times] for fn in survs])"
],
"metadata": {
"id": "nVQsQOocQhOI"
},
"execution_count": null,
"outputs": []
},
{
"cell_type": "code",
"source": [
"integrated_brier_score(y_trn, y_test, preds, times)"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "rYRRmruYRCgq",
"outputId": "789050d7-318f-4157-ba2c-6e911751659d"
},
"execution_count": null,
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
"0.17850725604478493"
]
},
"metadata": {},
"execution_count": 44
}
]
}
]
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment