{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# NeurIPS 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 utils import generate_data,  generate_a_hat, generate_y_hat\n",
    "from balancersV2 import BinaryBalancer\n",
    "from tqdm import tqdm\n",
    "sns.set_theme()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set the experiment\n",
    "exp = 2\n",
    "\n",
    "# Generate data\n",
    "n = 10000\n",
    "e0 = 2\n",
    "e1 = 1.5\n",
    "b = 0.1\n",
    "t = 0.35\n",
    "group = 0\n",
    "X, a, y  = generate_data(n,e0,e1,b,t)\n",
    "u = 0.023\n",
    "a_hat = generate_a_hat(X[:,2], b, u, imbalance=True)\n",
    "\n",
    "# Generate y_hat using random coefficients\n",
    "mu_c = np.array([1,1,1])\n",
    "var_c = np.array([[0.01,0,0],[0,0.01,0],[0,0,0.01]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Sample coefficients of classifier and generate y_hat\n",
    "coeffs = np.random.multivariate_normal(mu_c,var_c).T\n",
    "y_prob, y_hat = generate_y_hat(X,coeffs,exp,t)\n",
    "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": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n"
     ]
    }
   ],
   "source": [
    "# Run experiment\n",
    "iter = 100\n",
    "k = 0\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",
    "\n",
    "while k < iter:\n",
    "    # Sample coefficients of classifier and generate y_hat\n",
    "    coeffs = np.random.multivariate_normal(mu_c,var_c).T\n",
    "    y_prob, y_hat = generate_y_hat(X,coeffs,exp,t)\n",
    "    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",
    "    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",
    "    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, y_=true_balancer.y_adj, a=a, a_hat = a_hat)\n",
    "\n",
    "     # Calculate fairness and 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, y_=true_balancer.y_adj, a=a, a_hat = a_hat)\n",
    "        \n",
    "    # Calculate fairness and 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",
    "        print(k)\n",
    "    k = k+1 "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f4c80267070>"
      ]
     },
     "execution_count": 6,
     "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": [
    "# sns.kdeplot(d_tpr, shade = True, label = '\\Delta_tpr',cut = 0)\n",
    "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/imbalance_errors/B_tpr.pdf',bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f37430d4d90>"
      ]
     },
     "execution_count": 7,
     "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/imbalance_errors/B_fpr.pdf',bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Expected Loss')"
      ]
     },
     "execution_count": 8,
     "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/imbalance_errors/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
}
