{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Point process model processing\n",
    "file_path = 'KIDPAN_DATA.DAT'\n",
    "separator = '\\t'  \n",
    "df1 = pd.read_csv(file_path, sep=separator, on_bad_lines='skip', nrows=8000)\n",
    "\n",
    "rows = list(range(8000))\n",
    "cols = [199, 176, 201, 280, 262, 270, 197, 191, 26, 295, 25, 417, 393, 392, 10, 294, 171, 301, 315, 123, 307, 308]\n",
    "\n",
    "\n",
    "selected_data1 = df1.iloc[rows, cols]\n",
    "\n",
    "column_name = 'Unnamed: 199'\n",
    "\n",
    "filtered_df4 = selected_data1.dropna(subset=[column_name])\n",
    "\n",
    "filtered_df4.columns = ['ABO_DON', 'AGE_DON', 'GENDER_DON', 'BMI_DON_CALC', 'HIST_HYPERTENS_DON', 'HIST_DIABETES_DON', 'HEP_C_ANTI_DON', 'HBV_SUR_ANTIGEN_DON', 'ABO', 'AGE', 'GENDER', 'BMI_CALC', 'CMV_STATUS', 'HIV_SEROSTATUS', 'ON_DIALYSIS', 'ABO_MAT', 'HLAMIS', 'COLD_ISCH_KI', 'DAYSWAIT_CHRON_KI', 'TX_DATE', 'GTIME_KI', 'GSTATUS_KI']\n",
    "\n",
    "filtered_df4.replace('.', pd.NA, inplace=True)\n",
    "\n",
    "filtered_df4['ABO_DON'] = filtered_df4['ABO_DON'].replace(['A1', 'A2'], 'A')\n",
    "\n",
    "filtered_df4 = filtered_df4.dropna()\n",
    "\n",
    "filtered_df4.to_csv('filtered_df4.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Index(['AGE_DON', 'GENDER_DON', 'BMI_DON_CALC', 'HIST_HYPERTENS_DON',\n",
      "       'HIST_DIABETES_DON', 'AGE', 'GENDER', 'BMI_CALC', 'CMV_STATUS',\n",
      "       'HIV_SEROSTATUS', 'ON_DIALYSIS', 'ABO_MAT', 'HLAMIS', 'COLD_ISCH_KI',\n",
      "       'DAYSWAIT_CHRON_KI', 'TX_DATE', 'GTIME_KI', 'GSTATUS_KI', 'ABO_DON_AB',\n",
      "       'ABO_DON_B', 'ABO_DON_O', 'HEP_C_ANTI_DON_ND', 'HEP_C_ANTI_DON_P',\n",
      "       'HEP_C_ANTI_DON_U', 'HBV_SUR_ANTIGEN_DON_ND', 'HBV_SUR_ANTIGEN_DON_U',\n",
      "       'ABO_AB', 'ABO_B', 'ABO_O'],\n",
      "      dtype='object')\n",
      "   AGE_DON  GENDER_DON BMI_DON_CALC  HIST_HYPERTENS_DON  HIST_DIABETES_DON  \\\n",
      "1       35         0.0   23.5134453                 0.0                0.0   \n",
      "3       17         0.0   18.1786704                 0.0                0.0   \n",
      "8       16         0.0   18.9541158                 0.0                0.0   \n",
      "14      29         0.0   23.0254711                 0.0                0.0   \n",
      "18      64         0.0   39.4444444                 0.0                0.0   \n",
      "\n",
      "    ABO_DON_B  ABO_DON_AB  HEP_C_ANTI_DON_P  HBV_SUR_ANTIGEN_DON_ND AGE  ...  \\\n",
      "1       False       False             False                   False  38  ...   \n",
      "3       False       False             False                   False  43  ...   \n",
      "8       False       False             False                   False   9  ...   \n",
      "14      False       False             False                   False  26  ...   \n",
      "18      False       False             False                   False  76  ...   \n",
      "\n",
      "    CMV_STATUS HIV_SEROSTATUS  ON_DIALYSIS  ABO_B  ABO_AB  ABO_O  ABO_MAT  \\\n",
      "1          0.0            0.0          0.0  False   False   True      1.0   \n",
      "3          0.0            0.0          0.0  False   False  False      1.0   \n",
      "8          0.0            0.0          0.0  False   False  False      1.0   \n",
      "14         0.0            0.0          0.0  False   False   True      1.0   \n",
      "18         0.0            0.0          0.0  False   False  False      1.0   \n",
      "\n",
      "    HLAMIS  COLD_ISCH_KI DAYSWAIT_CHRON_KI  \n",
      "1        4         14.00                34  \n",
      "3        3         11.00                97  \n",
      "8        6         24.00                35  \n",
      "14       4         15.00               335  \n",
      "18       1         23.00               101  \n",
      "\n",
      "[5 rows x 22 columns]\n",
      "1     1\n",
      "3     1\n",
      "8     1\n",
      "14    1\n",
      "18    1\n",
      "Name: GSTATUS_KI, dtype: object\n"
     ]
    }
   ],
   "source": [
    "# Data cleaning and preprocessing function\n",
    "def preprocess_data(data):\n",
    "    # Convert date column to datetime format\n",
    "    data['TX_DATE'] = pd.to_datetime(data['TX_DATE'])\n",
    "    \n",
    "    # Encode gender\n",
    "    data['GENDER_DON'] = data['GENDER_DON'].map({'M': 1, 'F': 0})\n",
    "    data['GENDER'] = data['GENDER'].map({'M': 1, 'F': 0})\n",
    "    \n",
    "    # Encode history of hypertension, diabetes, HIV status, etc.\n",
    "    data['HIST_HYPERTENS_DON'] = data['HIST_HYPERTENS_DON'].map({'Y': 1, 'N': 0})\n",
    "    data['HIST_DIABETES_DON'] = data['HIST_DIABETES_DON'].map({'Y': 1, 'N': 0})\n",
    "    data['CMV_STATUS'] = data['CMV_STATUS'].map({'U': 1, 'N': 0})\n",
    "    data['HIV_SEROSTATUS'] = data['HIV_SEROSTATUS'].map({'U': 1, 'N': 0})\n",
    "    data['ON_DIALYSIS'] = data['ON_DIALYSIS'].map({1.0: 1, 2.0: 0})\n",
    "    \n",
    "    # One-hot encode ABO_DON, HEP_C_ANTI_DON, HBV_SUR_ANTIGEN_DON, ABO\n",
    "    data = pd.get_dummies(data, columns=['ABO_DON', 'HEP_C_ANTI_DON', 'HBV_SUR_ANTIGEN_DON', 'ABO'], drop_first=True)\n",
    "    \n",
    "    # Fill missing values\n",
    "    data.fillna(0, inplace=True)\n",
    "    \n",
    "    # Print column names to check the result of one-hot encoding\n",
    "    print(data.columns)\n",
    "    \n",
    "    # Create covariate matrix X\n",
    "    X = data[['AGE_DON', 'GENDER_DON', 'BMI_DON_CALC', 'HIST_HYPERTENS_DON', 'HIST_DIABETES_DON', \n",
    "              'ABO_DON_B', 'ABO_DON_AB', 'HEP_C_ANTI_DON_P', 'HBV_SUR_ANTIGEN_DON_ND', \n",
    "              'AGE', 'GENDER', 'BMI_CALC', 'CMV_STATUS', 'HIV_SEROSTATUS', 'ON_DIALYSIS', \n",
    "              'ABO_B', 'ABO_AB', 'ABO_O',\n",
    "              'ABO_MAT', 'HLAMIS', 'COLD_ISCH_KI', 'DAYSWAIT_CHRON_KI']]\n",
    "    \n",
    "    # Response variable y\n",
    "    y = data['GSTATUS_KI']\n",
    "    \n",
    "    return X, y\n",
    "\n",
    "X, y = preprocess_data(filtered_df4)\n",
    "print(X.head())\n",
    "print(y.head())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [],
   "source": [
    "X = X.astype(float)\n",
    "y = y.astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9532.935902808715\n"
     ]
    }
   ],
   "source": [
    "from scipy.optimize import minimize\n",
    "\n",
    "def log_partial_likelihood(beta, X, y):\n",
    "    linear_predictor = np.dot(X, beta)\n",
    "    risk_set = np.exp(linear_predictor)\n",
    "    log_likelihood = np.sum(linear_predictor[y == 1]) - np.sum(np.log(np.cumsum(risk_set[::-1])[::-1]))\n",
    "    return -log_likelihood\n",
    "\n",
    "# Test log partial likelihood function\n",
    "beta_init = np.zeros(X.shape[1])\n",
    "print(log_partial_likelihood(beta_init, X.values, y.values))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Windows\\Temp\\ipykernel_8252\\2204930289.py:6: RuntimeWarning: divide by zero encountered in log\n",
      "  log_likelihood = np.sum(linear_predictor[y == 1]) - np.sum(np.log(np.cumsum(risk_set[::-1])[::-1]))\n",
      "d:\\python311\\Lib\\site-packages\\scipy\\optimize\\_numdiff.py:590: RuntimeWarning: invalid value encountered in subtract\n",
      "  df = fun(x) - f0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 1.56187007e-02  0.00000000e+00 -3.14820541e-01  0.00000000e+00\n",
      "  0.00000000e+00 -2.57706769e+00 -5.06031247e+01 -3.72352203e+01\n",
      " -7.48356276e-01 -3.25366125e-02  0.00000000e+00 -9.96487135e-03\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  7.03436120e+00\n",
      "  5.28649279e+01  3.35729327e+00 -9.36970172e+01 -5.51194279e-01\n",
      " -2.87130596e-03 -7.63629119e-04]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Windows\\Temp\\ipykernel_8252\\2204930289.py:6: RuntimeWarning: divide by zero encountered in log\n",
      "  log_likelihood = np.sum(linear_predictor[y == 1]) - np.sum(np.log(np.cumsum(risk_set[::-1])[::-1]))\n",
      "d:\\python311\\Lib\\site-packages\\scipy\\optimize\\_numdiff.py:590: RuntimeWarning: invalid value encountered in subtract\n",
      "  df = fun(x) - f0\n"
     ]
    }
   ],
   "source": [
    "def train_model(X, y):\n",
    "    beta_init = np.zeros(X.shape[1])\n",
    "    result = minimize(log_partial_likelihood, beta_init, args=(X.values, y.values), method='BFGS')\n",
    "    return result.x\n",
    "\n",
    "beta = train_model(X, y)\n",
    "print(beta)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model AUC: 0.4937989490929433\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from sklearn.metrics import roc_auc_score, roc_curve\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def evaluate_model(beta, X, y):\n",
    "    linear_predictor = np.dot(X, beta)\n",
    "    predictions = 1 / (1 + np.exp(-linear_predictor))\n",
    "    auc = roc_auc_score(y, predictions)\n",
    "    fpr, tpr, _ = roc_curve(y, predictions)\n",
    "    return auc, fpr, tpr\n",
    "\n",
    "auc, fpr, tpr = evaluate_model(beta, X, y)\n",
    "print(f'Model AUC: {auc}')\n",
    "\n",
    "# Plot ROC curve\n",
    "plt.figure()\n",
    "plt.plot(fpr, tpr, label=f'AUC = {auc:.2f}')\n",
    "plt.xlabel('False Positive Rate')\n",
    "plt.ylabel('True Positive Rate')\n",
    "plt.title('ROC Curve')\n",
    "plt.legend(loc='lower right')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
