{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "scrolled": true
   },
   "source": [
    "# Meta-Algorithm for fair classification.\n",
    "The fairness metrics to be optimized have to specified as \"input\". Currently we can handle the following fairness metrics:\n",
    "Statistical Rate, False Positive Rate, True Positive Rate, False Negative Rate, True Negative Rate,\n",
    "Accuracy Rate, False Discovery Rate, False Omission Rate, Positive Predictive Rate, Negative Predictive Rate.\n",
    "\n",
    "-----------------------------\n",
    "\n",
    "The example below considers the cases of False Discovery Parity and Statistical Rate (disparate impact).\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [],
   "source": [
    "from IPython.display import Markdown, display\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from sklearn.preprocessing import MaxAbsScaler\n",
    "from tqdm import tqdm\n",
    "from aif360.datasets import AdultDataset, GermanDataset, CompasDataset\n",
    "from aif360.metrics import BinaryLabelDatasetMetric\n",
    "from aif360.metrics import ClassificationMetric\n",
    "from aif360.algorithms.preprocessing.optim_preproc_helpers.data_preproc_functions import load_preproc_data_adult\n",
    "from aif360.algorithms.inprocessing import MetaFairClassifier\n",
    "\n",
    "np.random.seed(12345)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Original Training dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_orig = load_preproc_data_adult()\n",
    "\n",
    "privileged_groups = [{'sex': 1}]\n",
    "unprivileged_groups = [{'sex': 0}]\n",
    "\n",
    "dataset_orig_train, dataset_orig_test = dataset_orig.split([0.7], shuffle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_orig = GermanDataset()\n",
    "privileged_groups = [{'sex': 1}]\n",
    "unprivileged_groups = [{'sex': 0}]\n",
    "dataset_orig_train, dataset_orig_test = dataset_orig.split([0.7], shuffle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [],
   "source": [
    "min_max_scaler = MaxAbsScaler()\n",
    "dataset_orig_train.features = min_max_scaler.fit_transform(dataset_orig_train.features)\n",
    "dataset_orig_test.features = min_max_scaler.transform(dataset_orig_test.features)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {
    "scrolled": true,
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/markdown": [
       "#### Training Dataset shape"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(34189, 18)\n"
     ]
    },
    {
     "data": {
      "text/markdown": [
       "#### Favorable and unfavorable labels"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1.0 0.0\n"
     ]
    },
    {
     "data": {
      "text/markdown": [
       "#### Protected attribute names"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['sex', 'race']\n"
     ]
    },
    {
     "data": {
      "text/markdown": [
       "#### Privileged and unprivileged protected attribute values"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[array([1.]), array([1.])] [array([0.]), array([0.])]\n"
     ]
    },
    {
     "data": {
      "text/markdown": [
       "#### Dataset feature names"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['race', 'sex', 'Age (decade)=10', 'Age (decade)=20', 'Age (decade)=30', 'Age (decade)=40', 'Age (decade)=50', 'Age (decade)=60', 'Age (decade)=>=70', 'Education Years=6', 'Education Years=7', 'Education Years=8', 'Education Years=9', 'Education Years=10', 'Education Years=11', 'Education Years=12', 'Education Years=<6', 'Education Years=>12']\n"
     ]
    }
   ],
   "source": [
    "display(Markdown(\"#### Training Dataset shape\"))\n",
    "print(dataset_orig_train.features.shape)\n",
    "display(Markdown(\"#### Favorable and unfavorable labels\"))\n",
    "print(dataset_orig_train.favorable_label, dataset_orig_train.unfavorable_label)\n",
    "display(Markdown(\"#### Protected attribute names\"))\n",
    "print(dataset_orig_train.protected_attribute_names)\n",
    "display(Markdown(\"#### Privileged and unprivileged protected attribute values\"))\n",
    "print(dataset_orig_train.privileged_protected_attributes, \n",
    "      dataset_orig_train.unprivileged_protected_attributes)\n",
    "display(Markdown(\"#### Dataset feature names\"))\n",
    "print(dataset_orig_train.feature_names)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train set: Difference in mean outcomes between unprivileged and privileged groups = -0.193\n",
      "Test set: Difference in mean outcomes between unprivileged and privileged groups = -0.197\n"
     ]
    }
   ],
   "source": [
    "metric_orig_train = BinaryLabelDatasetMetric(dataset_orig_train, \n",
    "                                             unprivileged_groups=unprivileged_groups,\n",
    "                                             privileged_groups=privileged_groups)\n",
    "print(\"Train set: Difference in mean outcomes between unprivileged and privileged groups = {:.3f}\".format(metric_orig_train.mean_difference()))\n",
    "metric_orig_test = BinaryLabelDatasetMetric(dataset_orig_test, \n",
    "                                            unprivileged_groups=unprivileged_groups,\n",
    "                                            privileged_groups=privileged_groups)\n",
    "print(\"Test set: Difference in mean outcomes between unprivileged and privileged groups = {:.3f}\".format(metric_orig_test.mean_difference()))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Algorithm without debiasing\n",
    "\n",
    "Get classifier without fairness constraints"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "biased_model = MetaFairClassifier(tau=0, sensitive_attr=\"sex\", type=\"fdr\").fit(dataset_orig_train)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Apply the unconstrained model to test data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "dataset_bias_test = biased_model.predict(dataset_orig_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test set: Classification accuracy = 0.789\n",
      "Test set: Balanced classification accuracy = 0.623\n",
      "Test set: Disparate impact = 0.466\n",
      "Test set: False discovery rate ratio = 0.508\n"
     ]
    }
   ],
   "source": [
    "classified_metric_bias_test = ClassificationMetric(dataset_orig_test, dataset_bias_test,\n",
    "                                                   unprivileged_groups=unprivileged_groups,\n",
    "                                                   privileged_groups=privileged_groups)\n",
    "print(\"Test set: Classification accuracy = {:.3f}\".format(classified_metric_bias_test.accuracy()))\n",
    "TPR = classified_metric_bias_test.true_positive_rate()\n",
    "TNR = classified_metric_bias_test.true_negative_rate()\n",
    "bal_acc_bias_test = 0.5*(TPR+TNR)\n",
    "print(\"Test set: Balanced classification accuracy = {:.3f}\".format(bal_acc_bias_test))\n",
    "print(\"Test set: Disparate impact = {:.3f}\".format(classified_metric_bias_test.disparate_impact()))\n",
    "fdr = classified_metric_bias_test.false_discovery_rate_ratio()\n",
    "fdr = min(fdr, 1/fdr)\n",
    "print(\"Test set: False discovery rate ratio = {:.3f}\".format(fdr))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Debiasing with FDR objective\n",
    "\n",
    "Learn a debiased classifier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "debiased_model = MetaFairClassifier(tau=0.7, sensitive_attr=\"sex\", type=\"fdr\").fit(dataset_orig_train)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Apply the debiased model to test data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_debiasing_test = debiased_model.predict(dataset_orig_test)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Model - with debiasing - dataset metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test set: Difference in mean outcomes between unprivileged and privileged groups = -0.110\n"
     ]
    }
   ],
   "source": [
    "metric_dataset_debiasing_test = BinaryLabelDatasetMetric(dataset_debiasing_test, \n",
    "                                             unprivileged_groups=unprivileged_groups,\n",
    "                                             privileged_groups=privileged_groups)\n",
    "\n",
    "print(\"Test set: Difference in mean outcomes between unprivileged and privileged groups = {:.3f}\".format(metric_dataset_debiasing_test.mean_difference()))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Model - with debiasing - classification metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test set: Classification accuracy = 0.657\n",
      "Test set: Balanced classification accuracy = 0.713\n",
      "Test set: Disparate impact = 0.794\n",
      "Test set: False discovery rate ratio = 0.660\n"
     ]
    }
   ],
   "source": [
    "classified_metric_debiasing_test = ClassificationMetric(dataset_orig_test, \n",
    "                                                 dataset_debiasing_test,\n",
    "                                                 unprivileged_groups=unprivileged_groups,\n",
    "                                                 privileged_groups=privileged_groups)\n",
    "print(\"Test set: Classification accuracy = {:.3f}\".format(classified_metric_debiasing_test.accuracy()))\n",
    "TPR = classified_metric_debiasing_test.true_positive_rate()\n",
    "TNR = classified_metric_debiasing_test.true_negative_rate()\n",
    "bal_acc_debiasing_test = 0.5*(TPR+TNR)\n",
    "print(\"Test set: Balanced classification accuracy = {:.3f}\".format(bal_acc_debiasing_test))\n",
    "print(\"Test set: Disparate impact = {:.3f}\".format(classified_metric_debiasing_test.disparate_impact()))\n",
    "fdr = classified_metric_debiasing_test.false_discovery_rate_ratio()\n",
    "fdr = min(fdr, 1/fdr)\n",
    "print(\"Test set: False discovery rate ratio = {:.3f}\".format(fdr))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "source": [
    "We see that the FDR ratio has increased meaning it is now closer to parity."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Running the algorithm for different tau values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:07<00:00,  1.35it/s]\n"
     ]
    }
   ],
   "source": [
    "accuracies, statistical_rates = [], []\n",
    "s_attr = \"sex\"\n",
    "\n",
    "all_tau = np.linspace(0, 0.9, 10)\n",
    "for tau in tqdm(all_tau):\n",
    "    debiased_model = MetaFairClassifier(tau=tau, sensitive_attr=s_attr, type='sr')\n",
    "    debiased_model.fit(dataset_orig_train)\n",
    "\n",
    "    dataset_debiasing_test = debiased_model.predict(dataset_orig_test)\n",
    "    metric = ClassificationMetric(dataset_orig_test, dataset_debiasing_test,\n",
    "                                  unprivileged_groups=[{s_attr: 0}],\n",
    "                                  privileged_groups=[{s_attr: 1}])\n",
    "\n",
    "    accuracies.append(metric.accuracy())\n",
    "    sr = metric.disparate_impact()\n",
    "    statistical_rates.append(min(sr, 1/sr))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Output fairness is represented by $\\gamma_{sr}$, which is the disparate impact ratio of different sensitive attribute values."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABJQAAAJ/CAYAAAAu+Yk+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOzdd3zM9x8H8NdlksgwEySomjFij1Kb1B6lSlW1RlE7tKWKltIapaK0aPGjatbetSpGUbONPROEUEnEyrrfH+9ekpMhudzlc+P1fDzu8f2479333kfk7vv+vt+fj0ar1WpBRERERERERESUSXaqAyAiIiIiIiIiIsvChBIREREREREREWUJE0pERERERERERJQlTCgREREREREREVGWMKFERERERERERERZwoQSERERERERERFlCRNKRERERERERESUJUwoERERERERERFRljChREREREREREREWcKEEhERERERERERZQkTSkRERERERERElCVMKBEREQGIiIiAk5MTNBqN3m3z5s2qQyMrVKJECb2fM8q+F/9Os3K7fv266vCJiIgsDhNKREREAJYtW4a4uLhU9y9evDjngyEiIiIiMnMOqgMgIiIyB0uWLEnz/k2bNuHff/9Fvnz5cjgiIsqKVq1a4d69e3r3hYSE4Ny5c0l/Ll68OGrUqJHqua6uriaPj4iIyNowoURERDbv5MmTOH36dNKfHR0dk6qVYmNjsXz5cgwaNEhVeESUCXPnzk1134QJE/DFF18k/blRo0asOiQiIjIStrwREZHNe/EEc8KECRnuf1FcXBx++eUXdOjQAcWKFUPu3Lnh6uqKEiVKoGPHjli5cmW2nrNv3z69+V569eqV6ngZzclz/fp1vX2NGjVCTEwMPvvsM5QtWxa5cuVCiRIlkh4fFBSE9957D9WqVYOPjw9cXV3h7OwMLy8vNGzYEFOnTsWjR4+y/fcxefJkvbgWLFiQ5rEKFCiQ9JgiRYogPj4+w3+P7L6PtP6+nj9/junTp8Pf3x+5c+eGh4cH3njjDRw5ciTd1z906BBatWqFvHnzwtXVFdWrV8f8+fOh1WozFX96bt68CTs7O/j6+mLhwoXpPm7z5s3QaDSoWrVqpv/OsmratGl6f1dpJXUSExPh4+OT9Ji8efPi6dOnAIBz585hwIABqFChAtzc3ODg4ID8+fOjbNmy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OloREfEGl8uWMtepA0eO2OS3w4edjkrEJyihJMlkywbffw8NG9qEzObNbemwiDd99ZX1pw0MhPfe+18/WpcLRo+2M/lz5tidRER8wS+/wFNP2ZK2jh3tbIvbbWMpv/jCGmyPGQM1aqjBtohIRhQcbJPeihWzCqV27ezMqEgmp4SSXCR3bli40CZkxsVB165W1e92Ox2ZZASnT8Ozz9r2c8/BjTeed2PFihAZads9e8LJk+ken4gIAIcOwciRUL063HwzfPCBNd0uWhRefRX+/vtc76SQEKejFRGRtFaggJ3wzJkTliyxEw06QJJMTgklSVFQEEycCH372uUBA+Dhh21JnMi1GDbMjsOuvx5efjmFO7zyih2w7dxpXbtFRNJLfLydUWnf3v5I9eoFGzZY+W779nbbP//YWZaSJZ2OVkRE0luVKvB//2fVqB9/bKX2IpmYEkpySVmywKBB8OGHtj1+PLRooQlwcvX+/dd+p8ASSzlzpnCnHDlgxIhzd9q0Kd3iE5FM6u+/reqoZElo1gymTrUzKNWqWZXSnj3neidlzep0tCIi4qSWLWH4cNuOjISvv3Y2HhEHKaEkV/T441bdmSMHfPst3HorREU5HZX4o969red2gwbQocNl7ti6tX1Yx8baCG6VE4uIt508af2PbrsNbrgBXn8ddu2ydd9PPWV9k9avt+3rrnM6WhER8SXPPAOPPWbfUTt21HhsybSUUJJUad7cmnUXLAi//25DDn791emoxJ989x1Mm2bVbiNGXKFvrctld8qeHZYutXHcIiLXyu2GNWtsIluhQjZdculS+5vTtKlVIe3efa53koiISEpcLuut17gxxMTY5Ld9+5yOShyydu1amjdvTq5cuciRIwd16tRh6tSpV72/I0eOULhwYVwuF82aNfNipN6nhJKk2k03werVUL48/PefVSotWuR0VOIPYmOtFQnAE09A1aqpeFDJkueaLEVGWjNcEZGrceAAvPuu9b6oXRs++giOHYMSJawf0o4d53onBQc7Ha2IiPiDwECYPh3KlLG+DnffbdNnJFNZunQp9erVY8WKFdx33310796dvXv30r59e4YnLo300FNPPUW0n/SZUUJJPFK8OKxcCY0awfHj1lNp3DinoxJf98EHsHEj5M0Lr73mwQMjI6FsWTvjk2IHbxGRS4iLg2++gbZtrcH2c8/B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tfOrA5e4uDgAjh8/zrFjx5KuDwoKIigo6KL7b9u2DYAyZcpcdFvBggXJmTNn0n1SY9GiRfz444+cOXOGbdu28fXXX5M3b17effddT19KulFCKZ2sWrWKkJAQp8OQDGDDBqcjEBERERERuYwcOaxnhx85efIkABUqVEh2ff/+/RkwYMBF94+OjgZsiVtKwsLCku6TGosWLUrWyLt06dJMnjyZm2++OdX7SG9KKKWTunXrUrhwYafDEBEREREREZEL/PfffwBs3Lgx2bF7StVJaWHYsGEMGzaMmJgYNm7cyGuvvUa9evUYO3YsnTp1SpcYPKWEUjoJCAggMDDQ6TBERERERERE5AIBAZYeCQ0NJSws7Ir3T6xMulQV0rFjx8idO7fHceTMmZNatWoxe/ZsatSoQbdu3bjjjjvIly+fx/tKa2rKLSIiIiIiIiLigcTeSSn1Sdq7dy8xMTEp9ldKrYCAABo3bsyJEydYt27dVe8nLSmhJCIiIiIiIiLigYYNGwLW++hCCxcuTHafq7V7924An13tpISSiIiIiIiIiIgHmjRpQqlSpZg0aRIbzpucFB0dzaBBg8iWLRsPPvhg0vV79uxh8+bNFy2Ru1T10cKFC5k1axa5cuWibt26afIarpV6KImIiIiIiIiIeCAgIIBPP/2UiIgIGjRoQIcOHQgNDWXGjBns3LmTYcOGUaJEiaT79+3blwkTJjBu3Di6dOmSdH3NmjWpVKkSVapUoUiRIpw4cYLffvuNH374gcDAQMaOHUuOHDnS/wWmghJKIiIiIiIiIiIeaty4MStWrKB///5MmTKF2NhYKleuzFtvvUX79u1TtY9BgwaxdOlSli9fzoEDB8iSJQvFihWjW7duPPPMM5QvXz6NX8XVc7ndbrfTQWRkUVFRFC1alF27dlGkSBGnwxERERERERGRC+jY3XPqoSQiIiIiIiIiIh5RQklERERERERERDyihJKIiIiIiIiIiHhECSUREREREREREfGIEkoiIiIiIiIiIuIRJZRERERERERERMQjSiiJiIiIiIiIiIhHlFASERERERERERGPKKEkIiIiIiIiIiIeUUJJREREREREREQ8ooSSiIiIiIiIiIh4RAklERERERERERHxiBJKIiIiIiIiIiLikQCnA8joEhISANizZ4/DkYiIiIiIiIhIShKP2ROP4eXKlFBK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4M6ZM6e7Zs2a7pEjR7rj4uLS4VWIZA4ut9vtTtM1dSIiIiIiIiIikqGoKbeIiIiIiIiIiHhECSUREREREREREfGIEkoiIiIiIiIiIuIRJZRERERERERERMQjSiiJiIiIiIiIiIhHlFASERERERERERGPKKEkIiIiIiIiIiIeUUJJREREREREREQ8ooSSiIiIiIiIiIh4RAklERER8TqXy5XsZ8eOHU6H5FMaNWp00X+j1P4sW7bM6fBFRERElFASERER8dT5CZ4SJUo4HY6IiIhIugtwOgARERGRzKZhw4bkzZs32XU7d+5k3bp1SZfz5s1Lw4YNL3psvnz50jw+ERERkStRQklEREQknQ0cOPCi68aPH0/Xrl2TLlesWJHp06enZ1giIiIiqaYlbyIiIpLuLlwylpCQwKeffkqdOnXImTMnOXPm5NZbb2X+/PkXPXbHjh3JHt+oUSNOnz7NoEGDqFixItmzZydPnjy0bduWX3/99aLHjx8/PtnjBwwYcMX4Lrz+fDt37ky3JXC//fYbffr0ISIigjJlypAnTx4CAwMJDQ2lXLlyPPTQQ/zwww8pPvbCvk0X9rVKzX8XERERkUSqUBIRERFHnT59mjvvvJNFixYlu37FihW0aNGCGTNm0KZNm0s+Pjo6mltvvTXZcrHTp08zc+ZMvvnmG2bPnk2zZs3SLP70tGjRIoYOHXrR9TExMWzZsoUtW7bw+eefM2DAAPr37+9AhCIiIpJZKKEkIiIijtq3bx+LFi2iUKFCVKpUifXr13Pw4EEA3G43ffr0uWxCacOGDQDceOONFC9enJ9//pnDhw8DcObMGTp16sTmzZvJnz//Ncfatm1bAGbMmJF0XUhICHfeeWfSZW88z5WULl2aAgUKkDt3bhISEti9eze//fYbCQkJAAwYMIC77rqL6tWrp3ksIiIikjkpoSQiIiKOa9asGTNnziR79uzs27ePKlWqsH//fgC2bdvGv//+S7FixS75+Oeffz6pcufgwYM0btyYP/74A4AjR47w4Ycf8uqrr15znIk9jc5f9pYvX75063XUvn17HnrooRQbc3/zzTe0bNky6fKUKVOUUBIREZE0ox5KIiIi4rh3332X7NmzA1CgQAFq166d7Pb//vvvko8NDQ1N1u8nb968vPjii8nus3jxYu8F66CiRYvy888/c//991OuXDlCQ0PJmjUrLpcrWTIJYPPmzQ5FKSIiIpmBKpRERETEUTlz5qRcuXLJrgsPD092+cyZM5d8fOnSpQkJCUl2XaVKlZJd3rlz5zVG6RuefvppRowYkar7RkdHp3E0IiIikpkpoSQiIiKOypMnz0XXZc2aNd2ePy4uLtnlffv2pdtze2LdunUXJZPKlClD2bJlCQoK4uTJk8mm4rnd7svuz19et4iIiPgmJZRERETEr23fvp1Tp04lLZkD+PPPP5Pdp3jx4knb2bJlS3bboUOHkl3+4Ycf0iDKa3dhXD169GD06NFJl1etWpUsoXShlF536dKlL7l/ERERkctRDyURERHxa8eOHeO1115Lunzo0CGGDBmS7D6333570vb111+f7Lavv/6aqKgowBqAX9h/KSXnJ68OHTp02SV53hIbG5vs8vnL/KKjo+nXr99lH3/h6/7oo4+SqpjGjh3LN99846VIRUREJDNQhZKIiIj4vSFDhjBr1iyKFy/Ozz//nKzqKFeuXHTv3j3pcq1atQgLC+PYsWMAREVFUapUKQoVKsSuXbuuuFQMoFy5cqxfvx6AmJgYqlSpQoUKFciaNSt33XUXDz74oJdfIdSpUyfZ5eHDh/P999+TJ08e1qxZw5EjRy77+DvuuIMJEyYkXR43bhxz5swB4PDhw16PV0RERDI2VSiJiIiIX6tZsyaNGjViy5YtLFq0KFkyKVu2bHzxxRcUKFAg6bqQkBAGDhyYbB+xsbH8+++/uN1uevXqdcXnfPTRR5Nd3rp1K7Nnz2bGjBn89ttv1/iKUtagQQPuueeeZNetXbuWBQsWEB0dfVFV1oXuu+8+atasmey6w4cPc/jwYUJDQ+nSpYu3QxYREZEMTAklERER8WshISEsWrSIt956i4oVKxIcHEzu3Lm5++67Wb16NS1atLjoMc888wwTJ07k5ptvJjg4mNDQUBo2bMisWbN4//33r/icTzzxBKNHj6Z69eoXTZhLS1OmTGHw4MGULVuWwMBArrvuOu68806WL1/Offfdd9nHBgYGsnjxYnr27EnRokUJDAykUKFCdOnShd9//52GDRum06sQERGRjMDlTk1dt4iIiIiP2LFjByVLlky63LBhQ5YtW+ZcQCIiIiKZkCqURERERERERETEI0oo8dbffwAAAIpJREFUiYiIiIiIiIiIR5RQEhERERERERERj6iHkoiIiIiIiIiIeEQVSiIiIiIiIiIi4hEllERERERERERExCNKKImIiIiIiIiIiEeUUBIREREREREREY8ooSQiIiIiIiIiIh5RQklERERERERERDyihJKIiIiIiIiIiHhECSUREREREREREfHI/wNIczA88nbzNAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1300x700 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax1 = plt.subplots(figsize=(13,7))\n",
    "ax1.plot(all_tau, accuracies, color='r')\n",
    "ax1.set_title('Accuracy and $\\gamma_{sr}$ vs Tau', fontsize=16, fontweight='bold')\n",
    "ax1.set_xlabel('Input Tau', fontsize=16, fontweight='bold')\n",
    "ax1.set_ylabel('Accuracy', color='r', fontsize=16, fontweight='bold')\n",
    "ax1.xaxis.set_tick_params(labelsize=14)\n",
    "ax1.yaxis.set_tick_params(labelsize=14)\n",
    "\n",
    "ax2 = ax1.twinx()\n",
    "ax2.plot(all_tau, statistical_rates, color='b')\n",
    "ax2.set_ylabel('$\\gamma_{sr}$', color='b', fontsize=16, fontweight='bold')\n",
    "ax2.yaxis.set_tick_params(labelsize=14)\n",
    "ax2.grid(True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [04:16<00:00,  2.56s/it]\n"
     ]
    }
   ],
   "source": [
    "DEOO_fin = []\n",
    "DPE_fin = []\n",
    "mis_fin = []\n",
    "sigma = 1\n",
    "for step in tqdm(range(100)):\n",
    "    mu_00 = 3 * np.random.rand(1)\n",
    "    mu_01 = np.random.rand(1)\n",
    "    mu_10 = np.random.rand(1)\n",
    "    mu_11 = np.random.rand(1)\n",
    "    for i in range(1000):\n",
    "        if(dataset_orig.labels[i] == 2 and dataset_orig.features[:,7][i] == 0):\n",
    "            #z = np.random.normal(mu_00, sigma, 57)\n",
    "            #z = np.random.chisquare(2,57)\n",
    "            z = np.random.standard_t(4, 57)\n",
    "            for j in range(7):\n",
    "                dataset_orig.features[i][j] = z[j]\n",
    "            for j in range(8, 58):\n",
    "                dataset_orig.features[i][j] = z[j - 1]\n",
    "        elif(dataset_orig.labels[i] == 2 and dataset_orig.features[:,7][i] == 1):\n",
    "            #z = np.random.normal(mu_01, sigma, 57)\n",
    "            #z = np.random.standard_t(4, 57)\n",
    "            z = np.random.chisquare(2,57)\n",
    "            for j in range(7):\n",
    "                dataset_orig.features[i][j] = z[j]\n",
    "            for j in range(8, 58):\n",
    "                dataset_orig.features[i][j] = z[j - 1]\n",
    "        elif(dataset_orig.labels[i] == 1 and dataset_orig.features[:,7][i] == 0):\n",
    "            #z = np.random.normal(mu_10, sigma, 57)\\\n",
    "            z = np.random.chisquare(4,57)\n",
    "            for j in range(7):\n",
    "                dataset_orig.features[i][j] = z[j]\n",
    "            for j in range(8, 58):\n",
    "                dataset_orig.features[i][j] = z[j - 1]\n",
    "        else:\n",
    "            #z = np.random.normal(mu_11, sigma, 57)\n",
    "            #z = np.random.chisquare(1,57)\n",
    "            z = np.random.laplace(mu_11, sigma, 57)\n",
    "            for j in range(7):\n",
    "                dataset_orig.features[i][j] = z[j]\n",
    "            for j in range(8, 58):\n",
    "                dataset_orig.features[i][j] = z[j - 1]\n",
    "    randseed = np.random.randint(10000)\n",
    "    dataset_orig_train, dataset_orig_vt = dataset_orig.split([0.6], shuffle=True, seed = np.random.randint(0, 10000))\n",
    "    dataset_orig_valid, dataset_orig_test = dataset_orig_vt.split([0.5], shuffle=True, seed = np.random.randint(0, 10000))\n",
    "    # Placeholder for predicted and transformed datasets\n",
    "    dataset_orig_train_pred = dataset_orig_train.copy(deepcopy=True)\n",
    "    dataset_orig_valid_pred = dataset_orig_valid.copy(deepcopy=True)\n",
    "    dataset_orig_test_pred = dataset_orig_test.copy(deepcopy=True)\n",
    "\n",
    "    dataset_new_valid_pred = dataset_orig_valid.copy(deepcopy=True)\n",
    "    dataset_new_test_pred = dataset_orig_test.copy(deepcopy=True)\n",
    "\n",
    "    y_test = dataset_orig_test.labels.ravel()\n",
    "\n",
    "    debiased_model = MetaFairClassifier(tau=0.7, sensitive_attr=\"sex\", type=\"fdr\").fit(dataset_orig_train)\n",
    "    dataset_debiasing_test = debiased_model.predict(dataset_orig_test)\n",
    "\n",
    "    eq = 0\n",
    "    for i in range(len(y_test)):\n",
    "        if(dataset_debiasing_test.labels.ravel()[i] == y_test[i]):\n",
    "            eq += 1\n",
    "    mis_fin.append(eq / len(y_test))\n",
    "    n_10 = 0\n",
    "    n_11 = 0\n",
    "    c_10 = 0\n",
    "    c_11 = 0\n",
    "    for i in range(len(y_test)):\n",
    "        if(y_test[i] == 1 and dataset_debiasing_test.protected_attributes[:,1][i] == 0):\n",
    "            n_10 += 1\n",
    "            if(dataset_debiasing_test.labels.ravel()[i] == 1):\n",
    "                c_10 += 1\n",
    "        elif(y_test[i] == 1 and dataset_debiasing_test.protected_attributes[:,1][i] == 1):\n",
    "            n_11 += 1\n",
    "            if(dataset_debiasing_test.labels.ravel()[i] == 1):\n",
    "                c_11 += 1\n",
    "    DEOO_fin.append(c_10 / n_10 - c_11 / n_11)\n",
    "    n_00 = 0\n",
    "    n_01 = 0\n",
    "    c_00 = 0\n",
    "    c_01 = 0\n",
    "    for i in range(len(y_test)):\n",
    "        if(y_test[i] == 2 and dataset_debiasing_test.protected_attributes[:,1][i] == 0):\n",
    "            n_00 += 1\n",
    "            if(dataset_debiasing_test.labels.ravel()[i] == 1):\n",
    "                c_00 += 1\n",
    "        elif(y_test[i] == 2 and dataset_debiasing_test.protected_attributes[:,1][i] == 1):\n",
    "            n_01 += 1\n",
    "            if(dataset_debiasing_test.labels.ravel()[i] == 1):\n",
    "                c_01 += 1\n",
    "    DPE_fin.append(c_00 / n_00 - c_01 / n_01)\n",
    "DEOO_fin = np.array(DEOO_fin)\n",
    "DPE_fin = np.array(DPE_fin)\n",
    "mis_fin = np.array(mis_fin)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [02:07<00:00,  1.27s/it]\n"
     ]
    }
   ],
   "source": [
    "DEOO_fin = []\n",
    "DPE_fin = []\n",
    "mis_fin = []\n",
    "sigma = 1\n",
    "for step in tqdm(range(100)):\n",
    "    randseed = np.random.randint(10000)\n",
    "    dataset_orig_train, dataset_orig_vt = dataset_orig.split([0.6], shuffle=True, seed = np.random.randint(0, 10000))\n",
    "    dataset_orig_valid, dataset_orig_test = dataset_orig_vt.split([0.5], shuffle=True, seed = np.random.randint(0, 10000))\n",
    "    # Placeholder for predicted and transformed datasets\n",
    "    dataset_orig_train_pred = dataset_orig_train.copy(deepcopy=True)\n",
    "    dataset_orig_valid_pred = dataset_orig_valid.copy(deepcopy=True)\n",
    "    dataset_orig_test_pred = dataset_orig_test.copy(deepcopy=True)\n",
    "\n",
    "    dataset_new_valid_pred = dataset_orig_valid.copy(deepcopy=True)\n",
    "    dataset_new_test_pred = dataset_orig_test.copy(deepcopy=True)\n",
    "\n",
    "    y_test = dataset_orig_test.labels.ravel()\n",
    "\n",
    "    debiased_model = MetaFairClassifier(tau=0.7, sensitive_attr=\"sex\", type=\"fdr\").fit(dataset_orig_train)\n",
    "    dataset_debiasing_test = debiased_model.predict(dataset_orig_test)\n",
    "\n",
    "    eq = 0\n",
    "    for i in range(len(y_test)):\n",
    "        if(dataset_debiasing_test.labels.ravel()[i] == y_test[i]):\n",
    "            eq += 1\n",
    "    mis_fin.append(eq / len(y_test))\n",
    "    n_10 = 0\n",
    "    n_11 = 0\n",
    "    c_10 = 0\n",
    "    c_11 = 0\n",
    "    for i in range(len(y_test)):\n",
    "        if(y_test[i] == 1 and dataset_debiasing_test.protected_attributes[:,1][i] == 0):\n",
    "            n_10 += 1\n",
    "            if(dataset_debiasing_test.labels.ravel()[i] == 1):\n",
    "                c_10 += 1\n",
    "        elif(y_test[i] == 1 and dataset_debiasing_test.protected_attributes[:,1][i] == 1):\n",
    "            n_11 += 1\n",
    "            if(dataset_debiasing_test.labels.ravel()[i] == 1):\n",
    "                c_11 += 1\n",
    "    DEOO_fin.append(c_10 / n_10 - c_11 / n_11)\n",
    "    n_00 = 0\n",
    "    n_01 = 0\n",
    "    c_00 = 0\n",
    "    c_01 = 0\n",
    "    for i in range(len(y_test)):\n",
    "        if(y_test[i] == 0 and dataset_debiasing_test.protected_attributes[:,1][i] == 0):\n",
    "            n_00 += 1\n",
    "            if(dataset_debiasing_test.labels.ravel()[i] == 1):\n",
    "                c_00 += 1\n",
    "        elif(y_test[i] == 0 and dataset_debiasing_test.protected_attributes[:,1][i] == 1):\n",
    "            n_01 += 1\n",
    "            if(dataset_debiasing_test.labels.ravel()[i] == 1):\n",
    "                c_01 += 1\n",
    "    DPE_fin.append(c_00 / n_00 - c_01 / n_01)\n",
    "DEOO_fin = np.array(DEOO_fin)\n",
    "DPE_fin = np.array(DPE_fin)\n",
    "mis_fin = np.array(mis_fin)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.17228323181597385\n",
      "0.19381204311392067\n",
      "0.6879598730678679\n",
      "0.7466424403726072\n",
      "0.2529187688423358\n",
      "0.27060087655248294\n"
     ]
    }
   ],
   "source": [
    "print(np.mean(abs(DEOO_fin)))\n",
    "print(np.mean(abs(DPE_fin)))\n",
    "print(np.mean(mis_fin))\n",
    "print(np.percentile(mis_fin, 95))\n",
    "print(np.percentile(abs(DEOO_fin), 95))\n",
    "print(np.percentile(abs(DPE_fin), 95))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "References:\n",
    "\n",
    "     Celis, L. E., Huang, L., Keswani, V., & Vishnoi, N. K. (2018). \n",
    "     \"Classification with Fairness Constraints: A Meta-Algorithm with Provable Guarantees.\"\"\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.7.13 ('aif360')",
   "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.7.13"
  },
  "vscode": {
   "interpreter": {
    "hash": "d27cd899c2aad711dbfe864d87d8e4a3aa2aa47421b84ce5060d18007824eabc"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
