{
 "cells": [
  {
   "cell_type": "markdown",
   "source": [
    "# Use SurvivalEVAL for PySurvival and auton-survival models\n",
    "\n",
    "In this notebook we introduce the use of `SurvivalEvaluator` in the package to evaluate the performance for a `PySurvival` and [`auton-survival`](https://autonlab.org/auton-survival/) model."
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "**Note that the `PySurvival` package is no longer maintained and only support until Python 3.7**. Therefore, this evaluation package has deprecated the support for `PySurvival` models. \n",
    "\n",
    "If you are interested in some survival models implemented in the `PySurvival` package, you can find all those models in other packages:\n",
    "- `Cox Proportional Hazard` model: you can use the `lifelines` package or `scikit-survival` package.\n",
    "- Linear and Neural `Multi-task Logistic Regression` models: you can use the [`torchmtlr`](https://github.com/mkazmier/torchmtlr) package. \n",
    "    - Also, the MTLR model in `PySurvival` has problem of convergence (due to the incorrect implementation of the loss function) and the `torchmtlr` package has fixed this problem.\n",
    "- Parametric models (exponential, Weibull, etc): you can use the `lifeline` package.\n",
    "- Survival trees and forests: you can use the `scikit-survival` package.\n",
    "\n",
    "However, if you still prefer to use the `PySurvival` package, this tutorial will guide you through the evaluation process, with the assumption that you have already familiar with the training step for the `PySurvival` package."
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "In the following, we will:\n",
    "1. Load the GBSG dataset;\n",
    "2. Train the `DeepSurvivalMachines` model;\n",
    "3. Perform evaluation on the 30% testing set.\n",
    "\n",
    "As the `PySurvival` and `auton-survival` models have the similar data structure for the predicted survival curves. If you are using the `PySurvival` package, you can skip the first two steps and directly go to the [third step](#3-perform-evaluation-on-the-testing-set)."
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "## 1. Load the dataset"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2024-03-06T06:04:58.444647Z",
     "start_time": "2024-03-06T06:04:58.051279Z"
    }
   },
   "outputs": [],
   "source": [
    "from lifelines.datasets import load_gbsg2\n",
    "# Load the data and split train/test set\n",
    "gbsg2 = load_gbsg2()\n",
    "gbsg2 = gbsg2.replace({\"horTh\": {\"no\": 0, \"yes\": 1}, \"menostat\": {\"Pre\": 0, \"Post\": 1}, \"tgrade\": {\"I\": 1, \"II\": 2, \"III\": 3}})\n",
    "train, test = gbsg2.iloc[:400, :], gbsg2.iloc[400:, :]\n",
    "\n",
    "x_train, x_test = train.drop([\"time\", \"cens\"], axis=1).astype(float), test.drop([\"time\", \"cens\"], axis=1).astype(float)\n",
    "t_train, t_test = train[\"time\"], test[\"time\"]\n",
    "e_train, e_test = train[\"cens\"], test[\"cens\"]"
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "## 2. Train the model"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 21%|██▏       | 2143/10000 [00:01<00:04, 1754.42it/s]\n",
      "100%|██████████| 1/1 [00:00<00:00, 90.47it/s]\n"
     ]
    },
    {
     "data": {
      "text/plain": "<auton_survival.models.dsm.DeepSurvivalMachines at 0x7fa06c410e80>"
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from auton_survival import models\n",
    "\n",
    "# Train a Deep Survival Machine (DSM) model\n",
    "model = models.dsm.DeepSurvivalMachines(k=3, layers=[32, 32])\n",
    "model.fit(x_train, t_train, e_train)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-03-06T06:05:01.859231Z",
     "start_time": "2024-03-06T06:04:59.714258Z"
    }
   },
   "execution_count": 2
  },
  {
   "cell_type": "markdown",
   "source": [
    "## 3. Perform evaluation on the testing set\n",
    "Let first make the predictions on the testing set. "
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "t_max = t_train.max()\n",
    "\n",
    "# make a list of 100 uniform time points from 0 to t_max\n",
    "# Any monotonic increasing time points can be used here\n",
    "time_coordinates = np.linspace(0, t_max, 100).tolist()\n",
    "\n",
    "# make predictions\n",
    "predictions = model.predict_survival(x_test, t=time_coordinates)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-03-06T06:05:03.625921Z",
     "start_time": "2024-03-06T06:05:03.606276Z"
    }
   },
   "execution_count": 3
  },
  {
   "cell_type": "markdown",
   "source": [
    "This is for `PySurvival` users, you should build your model and start from here by ignoring the above cells and uncommenting the following lines."
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "outputs": [],
   "source": [
    "# survival_curves = model.predict_survival(X, None)\n",
    "# time_coordinates = model.times"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-03-06T06:05:06.085673Z",
     "start_time": "2024-03-06T06:05:06.083436Z"
    }
   },
   "execution_count": 4
  },
  {
   "cell_type": "code",
   "outputs": [],
   "source": [
    "from Evaluator import SurvivalEvaluator\n",
    "\n",
    "evaler = SurvivalEvaluator(predictions, time_coordinates, t_test, e_test, t_train, e_train)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-03-06T06:05:07.351194Z",
     "start_time": "2024-03-06T06:05:07.100045Z"
    }
   },
   "execution_count": 5
  },
  {
   "cell_type": "markdown",
   "source": [
    "The rest of the evaluation process is the same as the other tutorials. \n",
    "\n",
    "For the sake of completeness, we will repeat a brief example of the evaluation process. You can find more details ones in the [PyCox example](https://github.com/shi-ang/SurvivalEVAL/blob/main/Examples/Pycox_Example.ipynb) and [scikit-survival example](https://github.com/shi-ang/SurvivalEVAL/blob/main/Examples/Scikit-survival_Example.ipynb)."
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Calculate the concordance index."
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Concordance index is 0.6124070232252189, meaning that the model can correctly order 12103.0 pairs among 19763.0 comparable pairs in the testing set.\n"
     ]
    }
   ],
   "source": [
    "cindex, concordant_pairs, total_pairs = evaler.concordance(ties=\"None\")\n",
    "print(\"Concordance index is {}, meaning that the model can correctly order {} pairs among {} comparable pairs \"\n",
    "      \"in the testing set.\".format(cindex, concordant_pairs, total_pairs))"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-03-06T06:05:09.280222Z",
     "start_time": "2024-03-06T06:05:09.270309Z"
    }
   },
   "execution_count": 6
  },
  {
   "cell_type": "markdown",
   "source": [
    "Calculate the integrated Brier score (IBS)"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Integrated Brier score is 0.144790156076693.\n"
     ]
    }
   ],
   "source": [
    "ibs = evaler.integrated_brier_score(num_points=None, IPCW_weighted=True, draw_figure=True)\n",
    "print(\"Integrated Brier score is {}.\".format(ibs))"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-03-06T06:05:11.166007Z",
     "start_time": "2024-03-06T06:05:10.986834Z"
    }
   },
   "execution_count": 7
  },
  {
   "cell_type": "markdown",
   "source": [
    "Calculate the MAE-PO (Pseudo observation) score"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MAE-PO loss is 1273.1081672393984.\n"
     ]
    }
   ],
   "source": [
    "mae_score = evaler.mae(method='Pseudo_obs')\n",
    "print(\"MAE-PO loss is {}.\".format(mae_score))"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-03-06T06:05:12.946584Z",
     "start_time": "2024-03-06T06:05:12.934167Z"
    }
   },
   "execution_count": 8
  },
  {
   "cell_type": "markdown",
   "source": [
    "Calculate the distribution calibration (D-Calibration)"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The model is not d-calibrated!\n"
     ]
    }
   ],
   "source": [
    "p_value, bin_statistics = evaler.d_calibration()\n",
    "if p_value >= 0.05:\n",
    "    print(\"The model is d-calibrated!\")\n",
    "else:\n",
    "    print(\"The model is not d-calibrated!\")"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-03-06T06:05:14.300946Z",
     "start_time": "2024-03-06T06:05:14.259027Z"
    }
   },
   "execution_count": 9
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 0
}
