{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# NeurIPS Real Data Experiment\n",
    "\n",
    "# Load all necessary packages\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from balancersV2 import BinaryBalancer\n",
    "from tqdm import tqdm\n",
    "from sklearn.metrics import confusion_matrix\n",
    "sns.set_theme()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Necessary function\n",
    "def check_conditions(U0, U1, alphas, est_r):\n",
    "    alpha_h_11, alpha_h_01, alpha_h_10, alpha_h_00 = alphas[0], alphas[1], alphas[2], alphas[3]\n",
    "    rh_11, rh_01, rh_10, rh_00 = est_r[0], est_r[1], est_r[2], est_r[3]\n",
    "    if U1/rh_11 <= alpha_h_11 <= 1-(U1/rh_11) and U0/rh_01 <= alpha_h_01 <= 1-(U0/rh_01) and U1/rh_10 <= alpha_h_10 <= 1-(U1/rh_11) and U0/rh_00 <= alpha_h_00 <= 1-(U0/rh_00):\n",
    "        return 1\n",
    "    else:\n",
    "        return 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def ROC(y,y_prob):\n",
    "    tprs = []\n",
    "    fprs = []\n",
    "    thresholds = np.linspace(0,1,100)\n",
    "    for t in thresholds:\n",
    "        y_hat = (y_prob >= t).astype('float')\n",
    "        tn, fp, fn, tp = confusion_matrix(y, y_hat).ravel()\n",
    "        tprs.append(tp/(tp+fn))\n",
    "        fprs.append(fp/(tn+fp))\n",
    "    return (thresholds, fprs, tprs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load data \n",
    "data = pd.read_csv('results_grouped_condition.csv', index_col=[0])\n",
    "a_total = np.array(data['Sex'])\n",
    "y_total = np.array(data['grouped_condition'])\n",
    "a_hat_total = np.array(data['a_hat'])\n",
    "y_prob_total = np.array(data['y_prob'])\n",
    "val_num = len(a_total) - 100000\n",
    "val_indices = np.random.choice(val_num, size=val_num, replace=False)\n",
    "y_val = y_total[val_indices]\n",
    "y_prob_val = y_prob_total[val_indices]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.797979797979798\n"
     ]
    }
   ],
   "source": [
    "# Determine optimal threshold to get y_hat\n",
    "thresholds, fprs, tprs = ROC(y_val,y_prob_val)\n",
    "opt_t = thresholds[np.argmax(np.array(tprs) - np.array(fprs))]\n",
    "print(opt_t)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Test set\n",
    "a = np.delete(a_total,val_indices)\n",
    "y = np.delete(y_total,val_indices)\n",
    "a_hat = np.delete(a_hat_total,val_indices)\n",
    "y_prob = np.delete(y_prob_total,val_indices)\n",
    "y_hat = y_prob >= opt_t"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "true_balancer = BinaryBalancer(y=y, y_=y_hat, a=a, a_hat = a_hat)\n",
    "\n",
    "# See if conditions are met\n",
    "alpha_list = [true_balancer.a_gr_list[1].tpr,\n",
    "                true_balancer.a_gr_list[0].tpr,\n",
    "                true_balancer.a_gr_list[1].fpr,\n",
    "                true_balancer.a_gr_list[0].fpr]\n",
    "\n",
    "est_r = [true_balancer.est_base_rates['rh_11'], \n",
    "            true_balancer.est_base_rates['rh_01'], \n",
    "            true_balancer.est_base_rates['rh_10'],\n",
    "            true_balancer.est_base_rates['rh_00']]\n",
    "check_conditions(true_balancer.U0, true_balancer.U1, alpha_list, est_r)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "iter = 100\n",
    "num_rows = len(a)\n",
    "d_tpr = []\n",
    "d_fpr = []\n",
    "d_tpr_fair = []\n",
    "d_fpr_fair = []\n",
    "d_tpr_opt = []\n",
    "d_fpr_opt = []\n",
    "b_tpr = []\n",
    "b_fpr = []\n",
    "b_tpr_fair = []\n",
    "b_fpr_fair = []\n",
    "b_tpr_opt = []\n",
    "b_fpr_opt = []\n",
    "o_loss = []\n",
    "fair_loss = []\n",
    "opt_loss = []\n",
    "k = 0 \n",
    "\n",
    "while k < iter:\n",
    "    random_indices = np.random.choice(num_rows, size=num_rows, replace=True)\n",
    "    a_s = a[random_indices]\n",
    "    y_s = y[random_indices]\n",
    "    a_hat_s = a_hat[random_indices]\n",
    "    y_hat_s = y_hat[random_indices]\n",
    "    true_balancer = BinaryBalancer(y=y_s, y_=y_hat_s, a=a_s, a_hat = a_hat_s)\n",
    "\n",
    "    # See if conditions are met\n",
    "    alpha_list = [true_balancer.a_gr_list[1].tpr,\n",
    "                  true_balancer.a_gr_list[0].tpr,\n",
    "                  true_balancer.a_gr_list[1].fpr,\n",
    "                  true_balancer.a_gr_list[0].fpr]\n",
    "    est_r = [true_balancer.est_base_rates['rh_11'], \n",
    "             true_balancer.est_base_rates['rh_01'], \n",
    "             true_balancer.est_base_rates['rh_10'],\n",
    "             true_balancer.est_base_rates['rh_00']]\n",
    "\n",
    "    if check_conditions(true_balancer.U0, true_balancer.U1, alpha_list, est_r) == 0:\n",
    "        continue\n",
    "\n",
    "    # Measure true bias\n",
    "    d_tpr.append(np.abs(true_balancer.a_gr_list[1].tpr - true_balancer.a_gr_list[0].tpr))\n",
    "    d_fpr.append(np.abs(true_balancer.a_gr_list[1].fpr - true_balancer.a_gr_list[0].fpr))\n",
    "\n",
    "    # Calculate worst case fairness violations\n",
    "    b_tpr.append(np.max([np.abs(true_balancer.tpr_ub), np.abs(true_balancer.tpr_lb)]))\n",
    "    b_fpr.append(np.max([np.abs(true_balancer.fpr_ub), np.abs(true_balancer.fpr_lb)]))\n",
    "    o_loss.append(0.5*(1 - true_balancer.overall_rates.tpr  + true_balancer.overall_rates.fpr))\n",
    "\n",
    "    # Adjust fairness with respect to A_hat\n",
    "    true_balancer.adjust(task = 'fair')\n",
    "    fair_balancer = BinaryBalancer(y=y_s, y_=true_balancer.y_adj, a=a_s, a_hat = a_hat_s)\n",
    "\n",
    "     # Calculate new worst case fairness violations\n",
    "    d_tpr_fair.append(np.abs(fair_balancer.a_gr_list[1].tpr - fair_balancer.a_gr_list[0].tpr))\n",
    "    d_fpr_fair.append(np.abs(fair_balancer.a_gr_list[1].fpr - fair_balancer.a_gr_list[0].fpr))\n",
    "    b_tpr_fair.append(np.max([np.abs(fair_balancer.tpr_ub), np.abs(fair_balancer.tpr_lb)]))\n",
    "    b_fpr_fair.append(np.max([np.abs(fair_balancer.fpr_ub), np.abs(fair_balancer.fpr_lb)]))\n",
    "    fair_loss.append(0.5*(1 - fair_balancer.overall_rates.tpr + fair_balancer.overall_rates.fpr))\n",
    "\n",
    "    # Adjust optimally\n",
    "    true_balancer.adjust()\n",
    "    opt_balancer = BinaryBalancer(y=y_s, y_=true_balancer.y_adj, a=a_s, a_hat = a_hat_s)\n",
    "        \n",
    "    # Calculate new worst case fairness violations\n",
    "    d_tpr_opt.append(np.abs(opt_balancer.a_gr_list[1].tpr - opt_balancer.a_gr_list[0].tpr))\n",
    "    d_fpr_opt.append(np.abs(opt_balancer.a_gr_list[1].fpr - opt_balancer.a_gr_list[0].fpr))\n",
    "    b_tpr_opt.append(np.max([np.abs(opt_balancer.tpr_ub), np.abs(opt_balancer.tpr_lb)]))\n",
    "    b_fpr_opt.append(np.max([np.abs(opt_balancer.fpr_ub), np.abs(opt_balancer.fpr_lb)]))\n",
    "    opt_loss.append(0.5*(1 - opt_balancer.overall_rates.tpr  + opt_balancer.overall_rates.fpr))\n",
    "\n",
    "    if k%100 == 0:\n",
    "        k\n",
    "    k = k+1 "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f041ecf5bd0>"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "method = [r'$f$']*iter + [r'$f_{\\widehat{fair}}$']*iter + [r'$f_{opt}$']*iter + [r'$f$']*iter + [r'$f_{\\widehat{fair}}$']*iter + [r'$f_{opt}$']*iter\n",
    "metrics = d_tpr + d_tpr_fair + d_tpr_opt + b_tpr + b_tpr_fair + b_tpr_opt\n",
    "metric_label = [r'$\\Delta_{TPR}$']*3*iter + [r'$B_{TPR}$']*3*iter\n",
    "b_tpr_df = pd.DataFrame(list(zip(metrics, method, metric_label)), columns =['Metric', 'Classifier', 'Metric Label'])\n",
    "sns.violinplot(data=b_tpr_df, x = 'Classifier', y = 'Metric', cut = 0, hue = 'Metric Label', hue_order= [r'$B_{TPR}$', r'$\\Delta_{TPR}$'])\n",
    "plt.xticks(fontsize=16)\n",
    "plt.yticks(fontsize=16)\n",
    "plt.xlabel('')\n",
    "plt.ylabel('Fairness Violation', fontsize=16)\n",
    "plt.legend(fontsize=14, borderpad=0.25)\n",
    "# plt.savefig('Figures/ICML_experiments/real_data/B_tpr.pdf',bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f041e12dff0>"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "method = [r'$f$']*iter + [r'$f_{\\widehat{fair}}$']*iter + [r'$f_{opt}$']*iter + [r'$f$']*iter + [r'$f_{\\widehat{fair}}$']*iter + [r'$f_{opt}$']*iter\n",
    "metrics = d_fpr + d_fpr_fair + d_fpr_opt + b_fpr + b_fpr_fair + b_fpr_opt\n",
    "metric_label = [r'$\\Delta_{FPR}$']*3*iter + [r'$B_{FPR}$']*3*iter\n",
    "b_tpr_df = pd.DataFrame(list(zip(metrics, method, metric_label)), columns =['Metric', 'Classifier', 'Metric Label'])\n",
    "sns.violinplot(data=b_tpr_df, x = 'Classifier', y = 'Metric', cut = 0, hue = 'Metric Label', hue_order= [r'$B_{FPR}$', r'$\\Delta_{FPR}$'])\n",
    "plt.xticks(fontsize=16)\n",
    "plt.yticks(fontsize=16)\n",
    "plt.xlabel('')\n",
    "plt.ylabel('Fairness Violation', fontsize=16)\n",
    "plt.legend(fontsize=14, borderpad=0.25)\n",
    "# plt.savefig('Figures/ICML_experiments/real_data/B_fpr.pdf',bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Expected Loss')"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "method =  [r'$f$']*iter + [r'$f_{\\widehat{fair}}$']*iter + [r'$f_{opt}$']*iter\n",
    "losses = o_loss + fair_loss + opt_loss\n",
    "loss_df = pd.DataFrame(list(zip(losses, method)), columns =['Expected Loss', 'Classifier'])\n",
    "sns.violinplot(data=loss_df, x = 'Classifier', y = 'Expected Loss', cut = 0)\n",
    "plt.xticks(fontsize=16)\n",
    "plt.yticks(fontsize=16)\n",
    "plt.xlabel('')\n",
    "plt.ylabel('Expected Loss', fontsize=16)\n",
    "# plt.savefig('Figures/ICML_experiments/real_data/loss.pdf',bbox_inches=\"tight\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.10.5 ('cuda102')",
   "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.10.5"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "3480f17d4fb79fd692b6ed7a9ca0948306936357486d7718056d429d227b38c3"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
