{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "**Package requirement**: \n",
    "\n",
    "    - xgboost >= 1.4.0\n",
    "    - numpy, pandas, sklearn, h5py\n",
    "    - pytorch (for FMOW CLIP featurized only)\n",
    "\n",
    "**helper.py**: adjusting fine-tuning paramters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import random\n",
    "from helper import *\n",
    "import warnings\n",
    "from sklearn.model_selection import train_test_split\n",
    "import h5py\n",
    "warnings.filterwarnings('ignore')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Warfarin Example\n",
    "We consider the Warfarin data and check for our measure. We consider both the discrete case and continuous case control variables. We remark that when the control variable is discrete, our procedure is equivalent to looking at CVaR for the controlled subpopulation. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "1\n"
     ]
    }
   ],
   "source": [
    "path = '/users/ml4409/Documents/Fairness/fairrisk/fairrisk/experiments/warfarin/data/warfarin.h5'\n",
    "f = h5py.File(path, 'r')\n",
    "\n",
    "data = f['data']\n",
    "labels = [l.decode('utf-8') for l in f['labels']]\n",
    "\n",
    "var_name = ['age', 'dose', 'Black or African American', 'Asian',\n",
    "          'v_A/A', 'v_A/G', 'v_G/G', 'v_nan', 'amiodarone','enzyme',\n",
    "            'c_*1/*1', 'c_*1/*11', 'c_*1/*13', 'c_*1/*14', 'c_*1/*2',\n",
    "            'c_*1/*3', 'c_*1/*5', 'c_*1/*6', 'c_*2/*2', 'c_*2/*3', 'c_*3/*3','c_nan']\n",
    "alpha_list = [0,0.2,0.4,0.6,0.8,0.95]\n",
    "\n",
    "model_names = ['Regression','Ridge', 'XGBoost','Gradient Boosting Regressor','Random Forrest Regression']\n",
    "\n",
    "data_pd = pd.DataFrame(np.array(data[:]).T, columns=labels)\n",
    "warfarin_X = data_pd.loc[:, data_pd.columns != 'dose']\n",
    "warfarin_Y = data_pd['dose'].to_numpy() ** 0.5\n",
    "\n",
    "train_prop = 0.7\n",
    "\n",
    "cvar_list = {}\n",
    "\n",
    "num_run = 50\n",
    "for s in np.arange(50):\n",
    "    seed = int(s)\n",
    "    print(seed)\n",
    "    X_train, X_remaining, Y_train, Y_remaining = train_test_split(warfarin_X, warfarin_Y, train_size=train_prop, random_state=seed)\n",
    "    X_cvar, X_test, Y_cvar, Y_test = train_test_split(X_remaining, Y_remaining, train_size=0.9, random_state=seed+20)\n",
    "\n",
    "    train_names = X_train.columns\n",
    "    cvar_warfarin = dict.fromkeys(model_names)\n",
    "    model_warfarin = dict.fromkeys(model_names)\n",
    "    for m_name in model_names:\n",
    "        cur_model = gridsearch(X_train, Y_train, m_name, seed)\n",
    "        model_warfarin[m_name] = cur_model\n",
    "        X_remaining['loss_' + m_name] = np.asarray((cur_model.predict(X_remaining[train_names]) - Y_remaining)**2)\n",
    "        X_cvar['loss'+ m_name] = np.asarray((cur_model.predict(X_cvar[train_names]) - Y_cvar)**2)\n",
    "        X_cvar['dose'] = Y_cvar\n",
    "        cvar_warfarin[m_name]  = cvar_step(X_cvar, Y_cvar, var_name, alpha_list, 'loss'+ m_name, seed)\n",
    "    cvar_list[seed] = cvar_warfarin"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.0, 8.0)"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYEAAAEYCAYAAAC6MEqvAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO3deVhV1frA8e+rqIA4JoqiKEoOOJs3Ncu0TO2SeDNNy1TM1BwyS9NME9RuXcu82f2ZaWWUmVoOpd4cK6fCOcqJNKec0ro5I4qyfn/sw/EcZDRgA+f9PM954Oy9zt7vOgf2e/Zae68lxhiUUkp5pkJ2B6CUUso+mgSUUsqDaRJQSikPpklAKaU8mCYBpZTyYJoElFLKg9meBETkORHZLSK7RGSuiHjbHZNSSnkKW5OAiAQCQ4Gmxph6QGGgu50xKaWUJ7H9TADwAnxExAvwBU7YHI9SSnkMLzt3bow5LiKTgV+By8AqY8wq1zIi0h/oD1C8ePE7ateunfuBKqVUPrZ9+/Y/jDH+qa0TO4eNEJEywEKgG3AW+BxYYIz5JLXyTZs2Ndu2bcvFCJVSKv8Tke3GmKaprbO7OagtcMgY87sxJhFYBNxlc0xKKeUx7E4CvwLNRcRXRAS4H9hrc0xKKeUxbE0CxpjNwAJgB7DTEc9MO2NSSilPYmvHMIAxJhKItDsOpZTyRHY3BymllLKR7WcC2en8+fOcPn2axMREu0NRKlOKFClC+fLlKVmypN2hKA9VYJLA+fPnOXXqFIGBgfj4+GD1MyuVdxljuHz5MsePHwfQRKBsUWCag06fPk1gYCC+vr6aAFS+ICL4+voSGBjI6dOn7Q5HeagCkwQSExPx8fGxOwylsszHx0ebMJVtCkwSAPQMQOVL+ner7FSgkoBSSqms0SSglFIerMBcHZSW8C/CcnV/S/7x32zdXrVq1RgyZAgjRozI1u2qzBERPv/8c7p06WJ3KErlCD0TsFlERAQPPfRQmuu3bt3KoEGDcjGirImKikJEEBEKFSpEpUqV6NGjB0ePHrU7tGxx8uRJOnbsaHcYSuUYTQJ5nL+/P76+vnaHwdWrV9NcV6tWLU6ePMmxY8eYP38+O3fu5NFHH7U1puwSEBBAsWLFcnw/StlFk0AeV61aNSZPnux8LiLMnDmTrl27Urx4capXr84nn7hPv3D8+HG6d+9OmTJlKFOmDGFhYezfv9+5/sCBA3Tq1ImAgACKFy9OkyZNWLZs2U37jYqK4sknn6R06dL06NEjzRi9vLwICAigUqVK3HPPPfTr149NmzZx/vx5Z5mlS5dyxx134O3tTXBwMGPGjHE7iJ86dYrw8HB8fHyoWrUqH374IfXq1SMqKsqt7tOmTaNz584UL16cl156KVPbXrRoEQ0aNMDHx4eyZcty7733curUKQCOHj1Kp06dKFu2LL6+vtSuXZt58+a57XPBggXO5zt37qRt27bObUVERHDu3Dnn+uQzu6lTpxIYGEiZMmXo06cP8fHxab5/StlJk0A+NGHCBDp16sSPP/5It27dePLJJzly5AgA8fHxtGnTBm9vb9atW0dMTAwVK1akbdu2zgPRxYsXefDBB1m9ejU//vgjjzzyCJ07dyYuLs5tP1OmTKF27dps27aNV199NVOx/fbbbyxatIjChQtTuHBhAFauXEmPHj0YMmQIu3fvZtasWSxYsMB5EAfo3bs3R44c4ZtvvuHLL7/kk08+cdbJ1fjx4/n73//Ozp07GTx4cIbb/u233+jevTu9e/dm7969rF+/np49ezq3N2jQIOLj4/n222/ZvXs3b731FqVLl061bvHx8XTo0AE/Pz+2bNnC4sWL+f7773nyySfdym3YsIFdu3axZs0a5s+fz+LFi5k6dWqm3j+lcluB7xguiHr27MkTTzwBwMSJE5k6dSobNmygatWqzJs3D2MMH374ofP68xkzZlC+fHmWLVvGo48+SsOGDWnYsKFze2PGjGHp0qUsWLCAsWPHOpffe++9jBw5MsN49u7di5+fH0lJSVy+fBmAoUOHUrx4cQD++c9/8sILL9CnTx8AatSowaRJk3jiiSd444032LdvHytXriQmJobmzZsDEB0dTbVq1W7aV7du3Xjqqaecz3v37p3utk+cOEFiYiJdunShatWqANSrV8/5+iNHjvDII48434/g4OA06zlnzhwuXrzI7NmzKVGiBAAzZ86kTZs2/PLLL4SEhADW8A/Tp0/Hy8uLOnXq0LVrV77++mtGjx6d4XupVG7TJJAPNWjQwPm7l5cX/v7+zmEHtm/fzqFDh5wHqWTx8fEcOHAAgEuXLjF+/HiWLVvGyZMnSUxMJCEhwW27AE2bpjob3U1q1KjBV199xZUrV/jy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rVoBMHv2bIKCgpgzZw5PPfUUANeuXXMeZAEef/xx58Q05cqVA6BTp058++23GSaBVq1auc1lvHz5cpo0acL06dN5//33CQuzhup99913+eabb5g2bRqvvPKKs3xUVBTt2rUD4NKlS0yZMoVVq1Y551gIDg5my5YtTJs2jbCwMI4cOULFihVp164dRYoUISgoiKZNrRPQUqVKUbRoUXx9fQkICMjgU1OqYMgLSaClMeaEiJQHVotInDFmffJKR1KYCdZ8AnYFmZNatWrFzJkzuXz5Mu+99x4HDhxg6NChbmXeffdd3n//fY4cOcLly3vmNj4AABwsSURBVJdJTEykatWqbmVCQ0Px8rrxkVaqVInNmzcDcODAAa5evUqLFi2c6/38/Khfv77z+d69eylUqJBbmVKlSlG/fn3nJPRgNV8lJwCAChUqEBAQ4EwAyctcX5OWTz/9lHr16jmfBwYGsn//fhITE2nZsqVzeeHChWnRosVN20w+gAPs2bOHhIQEOnTo4DZHcmJiItWqVQOga9euTJ06leDgYNq3b0+HDh0IDw+nWLFiGcaqVEFke5+AMeaE4+dpYDFwp70R5T5fX19CQkKoX78+b7/9NvHx8UycONG5fv78+QwbNoyIiAhWrlxJbGwsgwYN4urVq27bSdkpKiLOfoPMTB6UXhnXg6proklel96+01O5cmVCQkKcDx8fH2ccqU12n3JZ8eLFnb8n72/p0qXExsY6H7t373b2sVSpUoWff/6ZGTNmULJkSYYPH84dd9zBpUuXMoxVqYLI1iQgIsVFpETy70A7YJedMeUFkZGRTJo0iRMnTgDWJO/NmjVjyJAhNGnShJCQEA4cOJClbYaEhFCkSBFn+zdYzSe7dt14u0NDQ0lKSiImJsa57Pz58+zcudM5CX1uCAkJoWjRom4dwdevXycmJibdOEJDQylWrBhHjhxxSywhISFuZ03e3t6EhYXx73//m61bt7J7926+++47AIoWLcr169dzrnJK5TF2NwdVABY7vt15AZ8aY1bYG5L9WrduTd26dXnllVd45513qFmzJtHR0SxfvpyQkBDmzZvHunXrKFOmTKa36efnR9++fRk1ahT+/v5UqlSJCRMmuB3wbr/9djp16sSAAQOYOXMmpUuXZsyYMZQsWZLHH388J6qaquLFizNw4EBefPFFypUrR3BwsLPP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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "mean_dict = dict.fromkeys(model_names)\n",
    "std_dict = dict.fromkeys(model_names)\n",
    "\n",
    "for m_name in model_names:\n",
    "    df = pd.DataFrame()\n",
    "    for s in np.arange(num_run):\n",
    "        seed = int(s)\n",
    "        df[seed] = cvar_list[seed][m_name]\n",
    "    mean_dict[m_name] = df.mean(axis=1)\n",
    "    std_dict[m_name] = df.std(axis=1)\n",
    "\n",
    "model_selected = ['Regression', 'Ridge', 'XGBoost','Random Forrest Regression']\n",
    "m_names = ['Linear Regression', 'Ridge Regression', 'XGBoost', 'Random Forest']\n",
    "\n",
    "width = 0.12  # the width of the bars\n",
    "\n",
    "labels = ['100%','80', '60%', '40%', '20%', '5%']\n",
    "x = np.arange(len(labels))  # the label locations\n",
    "colors=['#4daf4a', '#ff7f00', '#984ea3', '#FFD43B', '#a65628', '#f781bf', '#e41a1c', '#377eb8']\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(6,4))\n",
    "\n",
    "# plot 1\n",
    "\n",
    "    \n",
    "rect = {}\n",
    "for (i,m) in enumerate(model_selected):\n",
    "    rect[m] = ax.bar(x + (-1.1+i)*width, np.array(mean_dict[m]), width, \n",
    "                     label=m_names[i], color=colors[i], \n",
    "                     yerr = 1.96*std_dict[m]/(num_run**0.5), \n",
    "                     error_kw=dict(lw=0.5, capsize=1, capthick=-1))    \n",
    "\n",
    "# Add some text for labels, title and custom x-axis tick labels, etc.\n",
    "ax.set_ylabel(r'$\\mathsf{W}_{\\alpha}$', fontsize=15)\n",
    "ax.set_xlabel('Subpopulation size ' + r'$\\alpha$', fontsize=15)\n",
    "# ax.set_title('Warfarin, CVaR metric at varying thresholds')\n",
    "ax.set_xticks(x)\n",
    "ax.set_xticklabels(labels, fontsize=15)\n",
    "ax.legend(loc='upper left', fontsize=14)\n",
    "\n",
    "ax.set_ylim((0,8))\n",
    "plt.savefig('warfarin-cvar.png', bbox_inches=\"tight\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
