{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "A comparision with FairLearn reductions on multi-group adult"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.7094544169999999\n"
     ]
    }
   ],
   "source": [
    "import dataset_loader\n",
    "from anonfair import FairPredictor\n",
    "from anonfair import group_metrics as gm\n",
    "from anonfair.utils.performance import evaluate_fairness\n",
    "import fairlearn.reductions\n",
    "\n",
    "import xgboost\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import fairlearn\n",
    "import time\n",
    "import pandas as pd\n",
    "train_data, val_data, test_data = dataset_loader.adult('race',train_proportion=0.7,test_proportion=0.3)\n",
    "\n",
    "start=time.perf_counter()\n",
    "predictor = xgboost.XGBClassifier().fit(X=train_data['data'], y=train_data['target'])\n",
    "stop=time.perf_counter()\n",
    "print(stop-start)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([' Amer-Indian-Eskimo', ' Asian-Pac-Islander', ' Black', ' Other',\n",
       "       ' White'], dtype=object)"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjoAAAGdCAYAAAAbudkLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA3TElEQVR4nO3dfVyV9f3H8feJOwHhKCDgWXjTIhWxMi1Fc+pPRUskW8sbjPI3U8uSmLrU32qzfgtTS9t0NU2NZjprU5uVMVyay7wNx5aKN5V5MyEs6SDGgOD7+6MH188DimiHkKvX8/E4jwfXdX2u6/p+r+s6nDffc86FwxhjBAAAYENXNXYDAAAAGgpBBwAA2BZBBwAA2BZBBwAA2BZBBwAA2BZBBwAA2BZBBwAA2BZBBwAA2JZvYzegMVVVVenkyZMKCQmRw+Fo7OYAAIB6MMbozJkzcrlcuuqqusdsvtdB5+TJk4qJiWnsZgAAgMtw/PhxXX311XXWfK+DTkhIiKRvDlRoaGgjtwYAANRHcXGxYmJirNfxunyvg07121WhoaEEHQAAmpj6fOyEDyMDAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADb8m3sBthZuxlvNXYTLtmnTw9t7CYAAOA1jOgAAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADbIugAAADbuuSg8/e//13Dhg2Ty+WSw+HQ66+/bi2rqKjQ9OnT1aVLFwUHB8vlcunee+/VyZMnPbZRVlamyZMnKyIiQsHBwUpOTtaJEyc8aoqKipSamiqn0ymn06nU1FR9+eWXHjXHjh3TsGHDFBwcrIiICKWlpam8vPxSuwQAAGzqkoPO2bNndcMNN2jRokW1ln311Vfas2ePHn/8ce3Zs0dr167VoUOHlJyc7FGXnp6udevWafXq1dq6datKSkqUlJSkyspKqyYlJUW5ubnKyspSVlaWcnNzlZqaai2vrKzU0KFDdfbsWW3dulWrV6/WmjVrNHXq1EvtEgAAsCmHMcZc9soOh9atW6fhw4dfsGb37t265ZZbdPToUbVp00Zut1utWrXSihUrNHLkSEnSyZMnFRMTow0bNmjw4MHKy8tTXFycduzYoR49ekiSduzYoYSEBB04cEAdOnTQ22+/raSkJB0/flwul0uStHr1ao0dO1aFhYUKDQ29aPuLi4vldDrldrvrVX+p+KeeAAB436W8fjf4Z3TcbrccDodatGghScrJyVFFRYUSExOtGpfLpfj4eG3btk2StH37djmdTivkSFLPnj3ldDo9auLj462QI0mDBw9WWVmZcnJyztuWsrIyFRcXezwAAIB9NWjQ+c9//qMZM2YoJSXFSlwFBQXy9/dXy5YtPWqjoqJUUFBg1URGRtbaXmRkpEdNVFSUx/KWLVvK39/fqqlp9uzZ1md+nE6nYmJivnUfAQDAlavBgk5FRYVGjRqlqqoqPf/88xetN8bI4XBY0+f+/G1qzjVz5ky53W7rcfz48fp0BQAANFENEnQqKio0YsQIHTlyRBs3bvR4/yw6Olrl5eUqKiryWKewsNAaoYmOjtZnn31Wa7unTp3yqKk5clNUVKSKiopaIz3VAgICFBoa6vEAAAD25fWgUx1yDh8+rL/97W8KDw/3WN6tWzf5+flp48aN1rz8/Hzt3btXvXr1kiQlJCTI7XZr165dVs3OnTvldrs9avbu3av8/HyrJjs7WwEBAerWrZu3uwUAAJog30tdoaSkRB999JE1feTIEeXm5iosLEwul0s/+clPtGfPHr355puqrKy0Rl3CwsLk7+8vp9OpcePGaerUqQoPD1dYWJimTZumLl26aODAgZKkTp06aciQIRo/frwWL14sSZowYYKSkpLUoUMHSVJiYqLi4uKUmpqqefPm6fTp05o2bZrGjx/PSA0AAJB0GUHngw8+UP/+/a3pKVOmSJLuu+8+zZo1S+vXr5ck3XjjjR7rbd68Wf369ZMkLViwQL6+vhoxYoRKS0s1YMAAZWZmysfHx6pfuXKl0tLSrG9nJScne9y7x8fHR2+99ZYmTZqk3r17KzAwUCkpKXrmmWcutUsAAMCmvtV9dJo67qNTG/fRAQBc6a6o++gAAAA0FoIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwLYIOAACwrUsOOn//+981bNgwuVwuORwOvf766x7LjTGaNWuWXC6XAgMD1a9fP+3bt8+jpqysTJMnT1ZERISCg4OVnJysEydOeNQUFRUpNTVVTqdTTqdTqamp+vLLLz1qjh07pmHDhik4OFgRERFKS0tTeXn5pXYJAADY1CUHnbNnz+qGG27QokWLzrt87ty5mj9/vhYtWqTdu3crOjpagwYN0pkzZ6ya9PR0rVu3TqtXr9bWrVtVUlKipKQkVVZWWjUpKSnKzc1VVlaWsrKylJubq9TUVGt5ZWWlhg4dqrNnz2rr1q1avXq11qxZo6lTp15qlwAAgE05jDHmsld2OLRu3ToNHz5c0jejOS6XS+np6Zo+fbqkb0ZvoqKiNGfOHE2cOFFut1utWrXSihUrNHLkSEnSyZMnFRMTow0bNmjw4MHKy8tTXFycduzYoR49ekiSduzYoYSEBB04cEAdOnTQ22+/raSkJB0/flwul0uStHr1ao0dO1aFhYUKDQ29aPuLi4vldDrldrvrVX+p2s14y+vbbGifPj20sZsAAECdLuX126uf0Tly5IgKCgqUmJhozQsICFDfvn21bds2SVJOTo4qKio8alwul+Lj462a7du3y+l0WiFHknr27Cmn0+lREx8fb4UcSRo8eLDKysqUk5Nz3vaVlZWpuLjY4wEAAOzLq0GnoKBAkhQVFeUxPyoqylpWUFAgf39/tWzZss6ayMjIWtuPjIz0qKm5n5YtW8rf39+qqWn27NnWZ36cTqdiYmIuo5cAAKCpaJBvXTkcDo9pY0yteTXVrDlf/eXUnGvmzJlyu93W4/jx43W2CQAANG1eDTrR0dGSVGtEpbCw0Bp9iY6OVnl5uYqKiuqs+eyzz2pt/9SpUx41NfdTVFSkioqKWiM91QICAhQaGurxAAAA9uXVoNO+fXtFR0dr48aN1rzy8nJt2bJFvXr1kiR169ZNfn5+HjX5+fnau3evVZOQkCC3261du3ZZNTt37pTb7fao2bt3r/Lz862a7OxsBQQEqFu3bt7sFgAAaKJ8L3WFkpISffTRR9b0kSNHlJubq7CwMLVp00bp6enKyMhQbGysYmNjlZGRoaCgIKWkpEiSnE6nxo0bp6lTpyo8PFxhYWGaNm2aunTpooEDB0qSOnXqpCFDhmj8+PFavHixJGnChAlKSkpShw4dJEmJiYmKi4tTamqq5s2bp9OnT2vatGkaP348IzUAAEDSZQSdDz74QP3797emp0yZIkm67777lJmZqUcffVSlpaWaNGmSioqK1KNHD2VnZyskJMRaZ8GCBfL19dWIESNUWlqqAQMGKDMzUz4+PlbNypUrlZaWZn07Kzk52ePePT4+Pnrrrbc0adIk9e7dW4GBgUpJSdEzzzxz6UcBAADY0re6j05Tx310auM+OgCAK12j3UcHAADgSkLQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtkXQAQAAtuX1oPP111/rscceU/v27RUYGKhrrrlGTz75pKqqqqwaY4xmzZoll8ulwMBA9evXT/v27fPYTllZmSZPnqyIiAgFBwcrOTlZJ06c8KgpKipSamqqnE6nnE6nUlNT9eWXX3q7SwAAoInyetCZM2eOfv/732vRokXKy8vT3LlzNW/ePC1cuNCqmTt3rubPn69FixZp9+7dio6O1qBBg3TmzBmrJj09XevWrdPq1au1detWlZSUKCkpSZWVlVZNSkqKcnNzlZWVpaysLOXm5io1NdXbXQIAAE2UwxhjvLnBpKQkRUVFadmyZda8u+66S0FBQVqxYoWMMXK5XEpPT9f06dMlfTN6ExUVpTlz5mjixIlyu91q1aqVVqxYoZEjR0qSTp48qZiYGG3YsEGDBw9WXl6e4uLitGPHDvXo0UOStGPHDiUkJOjAgQPq0KHDRdtaXFwsp9Mpt9ut0NBQbx4GSVK7GW95fZsN7dOnhzZ2EwAAqNOlvH57fUTn1ltv1TvvvKNDhw5Jkv75z39q69atuv322yVJR44cUUFBgRITE611AgIC1LdvX23btk2SlJOTo4qKCo8al8ul+Ph4q2b79u1yOp1WyJGknj17yul0WjUAAOD7zdfbG5w+fbrcbrc6duwoHx8fVVZW6qmnntLo0aMlSQUFBZKkqKgoj/WioqJ09OhRq8bf318tW7asVVO9fkFBgSIjI2vtPzIy0qqpqaysTGVlZdZ0cXHxZfYSAAA0BV4f0Xn11Vf1yiuvaNWqVdqzZ49efvllPfPMM3r55Zc96hwOh8e0MabWvJpq1pyvvq7tzJ492/rgstPpVExMTH27BQAAmiCvB52f//znmjFjhkaNGqUuXbooNTVVP/vZzzR79mxJUnR0tCTVGnUpLCy0Rnmio6NVXl6uoqKiOms+++yzWvs/depUrdGiajNnzpTb7bYex48f/3adBQAAVzSvB52vvvpKV13luVkfHx/r6+Xt27dXdHS0Nm7caC0vLy/Xli1b1KtXL0lSt27d5Ofn51GTn5+vvXv3WjUJCQlyu93atWuXVbNz50653W6rpqaAgACFhoZ6PAAAgH15/TM6w4YN01NPPaU2bdqoc+fO+sc//qH58+frpz/9qaRv3m5KT09XRkaGYmNjFRsbq4yMDAUFBSklJUWS5HQ6NW7cOE2dOlXh4eEKCwvTtGnT1KVLFw0cOFCS1KlTJw0ZMkTjx4/X4sWLJUkTJkxQUlJSvb5xBQAA7M/rQWfhwoV6/PHHNWnSJBUWFsrlcmnixIn65S9/adU8+uijKi0t1aRJk1RUVKQePXooOztbISEhVs2CBQvk6+urESNGqLS0VAMGDFBmZqZ8fHysmpUrVyotLc36dlZycrIWLVrk7S4BAIAmyuv30WlKuI9ObdxHBwBwpWvU++gAAABcKQg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAtgg6AADAthok6Pz73//WPffco/DwcAUFBenGG29UTk6OtdwYo1mzZsnlcikwMFD9+vXTvn37PLZRVlamyZMnKyIiQsHBwUpOTtaJEyc8aoqKipSamiqn0ymn06nU1FR9+eWXDdElAADQBHk96BQVFal3797y8/PT22+/rf379+vZZ59VixYtrJq5c+dq/vz5WrRokXbv3q3o6GgNGjRIZ86csWrS09O1bt06rV69Wlu3blVJSYmSkpJUWVlp1aSkpCg3N1dZWVnKyspSbm6uUlNTvd0lAADQRDmMMcabG5wxY4bef/99vffee+ddboyRy+VSenq6pk+fLumb0ZuoqCjNmTNHEydOlNvtVqtWrbRixQqNHDlSknTy5EnFxMRow4YNGjx4sPLy8hQXF6cdO3aoR48ekqQdO3YoISFBBw4cUIcOHS7a1uLiYjmdTrndboWGhnrpCPy/djPe8vo2G9qnTw9t7CYAAFCnS3n99vqIzvr169W9e3fdfffdioyMVNeuXfXiiy9ay48cOaKCggIlJiZa8wICAtS3b19t27ZNkpSTk6OKigqPGpfLpfj4eKtm+/btcjqdVsiRpJ49e8rpdFo1NZWVlam4uNjjAQAA7MvrQeeTTz7RCy+8oNjYWP31r3/VAw88oLS0NP3hD3+QJBUUFEiSoqKiPNaLioqylhUUFMjf318tW7assyYyMrLW/iMjI62ammbPnm19nsfpdComJubbdRYAAFzRvB50qqqqdNNNNykjI0Ndu3bVxIkTNX78eL3wwgsedQ6Hw2PaGFNrXk01a85XX9d2Zs6cKbfbbT2OHz9e324BAIAmyOtBp3Xr1oqLi/OY16lTJx07dkySFB0dLUm1Rl0KCwutUZ7o6GiVl5erqKiozprPPvus1v5PnTpVa7SoWkBAgEJDQz0eAADAvrwedHr37q2DBw96zDt06JDatm0rSWrfvr2io6O1ceNGa3l5ebm2bNmiXr16SZK6desmPz8/j5r8/Hzt3bvXqklISJDb7dauXbusmp07d8rtdls1AADg+83X2xv82c9+pl69eikjI0Mj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BB0AAGBbBB0AAGBbBB0AAGBbBB0AAGBbBB0AAGBbXv9fV8B3jX+1AQC4EEZ0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbRF0AACAbfk2dgMAAE1buxlvNXYTLtmnTw9t7CbgO8KIDgAAsC2CDgAAsC2CDgAAsC2CDgAAsC2CDgAAsC2CDgAAsC2CDgAAsC2CDgAAsK0mf8PA559/XvPmzVN+fr46d+6s5557Tn369GnsZgG4AnAjOwBNOui8+uqrSk9P1/PPP6/evXtr8eLFuu2227R//361adOmsZsHAIDXNMXgLjV+eG/Sb13Nnz9f48aN0/33369OnTrpueeeU0xMjF544YXGbhoAALgCNNkRnfLycuXk5GjGjBke8xMTE7Vt27bzrlNWVqaysjJr2u12S5KKi4sbpI1VZV81yHYbUkMdi4bEccaFcG18NzjO342meJylhjnW1ds0xly0tskGnc8//1yVlZWKiorymB8VFaWCgoLzrjN79mw98cQTtebHxMQ0SBubIudzjd2C7weOMy6Ea+O7wXH+7jTksT5z5oycTmedNU026FRzOBwe08aYWvOqzZw5U1OmTLGmq6qqdPr0aYWHh19wnctVXFysmJgYHT9+XKGhoV7dNhoe56/p4xw2fZzDpq+hzqExRmfOnJHL5bpobZMNOhEREfLx8ak1elNYWFhrlKdaQECAAgICPOa1aNGioZooSQoNDeUJ2oRx/po+zmHTxzls+hriHF5sJKdak/0wsr+/v7p166aNGzd6zN+4caN69erVSK0CAABXkiY7oiNJU6ZMUWpqqrp3766EhAQtWbJEx44d0wMPPNDYTQMAAFeAJh10Ro4cqS+++EJPPvmk8vPzFR8frw0bNqht27aN3TQFBAToV7/6Va23ytA0cP6aPs5h08c5bPquhHPoMPX5bhYAAEAT1GQ/owMAAHAxBB0AAGBbBB0AAGBbBB0vGjt2rIYPH15nTbt27fTcc899J+1B/fTr10/p6ele2159rgN4R2Zmpse9sGbNmqUbb7yx0dpTXxdrZ81+eZO3r/em6ru6Vt599105HA59+eWXDb6vK5XD4dDrr7/eaPsn6NRQUlIiPz8/vfrqqx7zR44cKYfDoY8//thj/g9/+EP9z//8T723v3v3bk2YMMGabuwLwM6qf8FUPwIDA9W5c2ctWbKksZv2nenQoYP8/f3173//u7GbUktDXPvTpk3TO++849Vtnk/Na+vcx4X+Bc2lGDlypA4dOlRnzeWe27Vr1+p///d/v03z6mXWrFnWMfHx8VFMTIzuv/9+nTp1qkH32RSCblNTWVmpBQsW6Prrr1ezZs3UokUL3XbbbXr//fc96q7U40/QqaF58+bq3r27Nm/e7DF/y5YtiomJ8Zh/4sQJffLJJ+rfv3+9t9+qVSsFBQV5rb24uIMHDyo/P1/79+/XxIkT9eCDD34nL4aNbevWrfrPf/6ju+++W5mZmY3WjvLy8u9sX82bN1d4ePh3tr/qa+vcR2Rk5LfebmBgYJ3b+TbnNiwsTCEhId+yhfXTuXNn5efn69ixY3rhhRf0xhtv6N577/1O9m0n3+VzqCZjjEaNGqUnn3xSaWlpysvLs14P+/Xr12h/qF/KMSHonEf//v317rvvWtN5eXkqLS3VpEmTPOZv3rxZfn5+6t27t8f6zzzzjFq3bq3w8HA99NBDqqiosJad+9ZVu3btJEl33nmnHA6HNS1Jb7zxhrp166ZmzZrpmmuu0RNPPKGvv/7a2139XoiMjFR0dLTat2+vtLQ0tWvXTnv27Llg/SuvvKLu3bsrJCRE0dHRSklJUWFhoUfNvn37NHToUIWGhiokJER9+vSpNdpXLScnR5GRkXrqqae82q+LWbZsmVJSUpSamqrly5fX+i+/7dq1069//Wvde++9at68udq2bau//OUvOnXqlO644w41b95cXbp00QcffOCx3rZt2/SjH/1IgYGBiomJUVpams6ePVtru2PHjpXT6dT48eMv2tZPP/1UDodDa9euVf/+/RUUFKQbbrhB27dv96jLzMxUmzZtFBQUpDvvvFNffPGFx/Kaf1Hu3r1bgwYNUkREhJxOp/r27Vvr3DscDi1dulR33nmngoKCFBsbq/Xr11+0zdL/X1vnPq666ptfq++++65uueUWBQcHq0WLFurdu7eOHj163u0cOXJE1157rR588EFVVVVd8C255cuXq02bNurfv7/Cw8OVkpKi+fPnKyoqyuMae/755xUbG6tmzZopICBAvr6+Cg0N1YgRI9SrVy+Pt64udr1Xj16988476t69u4KCgtSrVy8dPHjwosfH19dX0dHR+sEPfqCkpCSlpaUpOztbpaWlysrK0q233qoWLVooPDxcSUlJtZ5DJ06c0KhRoxQWFqbg4GB1795dO3furNe5udRz4K1rZcOGDbruuusUGBio/v3769NPP621r4Z4DjWU1157TX/+85/1hz/8Qffff7/at2+vG264QUuWLFFycrLuv/9+nT17VpmZmXriiSf0z3/+0xrJOzeEf/7553Uet/379+v2229X8+bNFRUVpdTUVH3++efW8n79+unhhx/WlClTFBERoUGDBtW/Ewa1ZGdnG0nm5MmTxhhjfve735mhQ4eanTt3mh/84AdW3X//93+bW2+91Zq+7777TGhoqHnggQdMXl6eeeONN0xQUJBZsmSJVdO2bVuzYMECY4wxhYWFRpJ56aWXTH5+viksLDTGGJOVlWVCQ0NNZmam+fjjj012drZp166dmTVr1nfQe/vYvHmzkWSKioqMMcZUVVWZt99+2/j5+ZktW7ZYdX379jWPPPKINb1s2TKzYcMG8/HHH5vt27ebnj17mttuu81afuLECRMWFmZ+/OMfm927d5uDBw+a5cuXmwMHDhhjvrkO7rjjDqsNTqfTPP/88w3e33MVFxeb4OBgs3fvXvP111+bqKgos2nTJo+atm3bmrCwMPP73//eHDp0yDz44IMmJCTEDBkyxLz22mvm4MGDZvjw4aZTp06mqqrKGGPMv/71L9O8eXOzYMECc+jQIfP++++brl27mrFjx3psNzQ01MybN88cPnzYHD58+LxtlGTWrVtnjDHmyJEjRpLp2LGjefPNN83BgwfNT37yE9O2bVtTUVFhjDFmx44dxuFwmNmzZ5uDBw+a3/zmN6ZFixbG6XRa2/zVr35lbrjhBmv6nXfeMStWrDD79+83+/fvN+PGjTNRUVGmuLjYox1XX321WbVqlTl8+LBJS0szzZs3N1988cUFj2/Na6umiooK43Q6zbRp08xHH31k9u/fbzIzM83Ro0drtfPDDz80rVu3NjNmzLDWf+mll2r1q3nz5uYnP/mJ2bVrl2nWrJnx9fU1iYmJJigoyGRmZprly5cbSWb58uXGx8fHrFy50nTu3NnceOONZtq0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U6ZM8agZPXq0oqOjNXz4cL3//vv65JNPtGbNmlrfxLuQ+p6Dat64Vh544AF9/PHHmjJlig4ePKhVq1bV+vp/Yz6HLseoUaN055136r777tOyZcv06aef6l//+pcmTpyo9evXa+nSpdZIS7t27XTkyBHl5ubq888/V1lZWb328dBDD+n06dMaPXq0du3apU8++UTZ2dn66U9/elnBqSaCzgVUvy115swZ6z1r6ZsRmISEBJ05c8YrQefZZ5/Vxo0bFRMTo65du0qSBg8erDfffFMbN27UzTffrJ49e2r+/Pnf6i/L77MOHTqodevWuvbaazV9+nRNnDhRCxcuPG9tq1atlJmZqT/96U+Ki4vT008/rWeeecajJjw8XJs2bVJJSYn69u2rbt266cUXXzzviE10dLQ2bdqkDz/8UGPGjPHKk7Yu69ev1xdffKE777yz1rLY2Fh16dJFy5Ytu+ztX3/99dqyZYsOHz6sPn36qGvXrnr88cc9hpcbSs+ePbV06VItXLhQN954o7Kzsy8a/pcvX66ioiJ17dpVqampSktL88roUrXqa+vcR05OjoKCgnTgwAHddddduu666zRhwgQ9/PDDmjhxYq1tNG/eXG+//baMMbr99ts9vmZ8LrfbfdFzW1BQoICAAK1du1YDBgzQxx9/rFOnTsnPz08TJkzQNddco7i4OGu9+lzvDeGqq67S6tWrlZOTo/j4eP3sZz/TvHnzPGr8/f2VnZ2tyMhI3X777erSpYuefvppj89A1uVSzoHknWulTZs2WrNmjd544w3dcMMN+v3vf1/r80ON+Ry6HA6HQ6+99pp+8YtfaMGCBerYsaP69Omjo0ePavPmzR53gb/rrrs0ZMgQ9e/fX61atdIf//jHeu3D5XLp/fffV2VlpQYPHqz4+Hg98sgjcjqd1u0avlUfzOW88Q0AANAEMKIDAABsi6ADAABsi6ADAABsi6ADAABsi6ADAABsi6ADAABsi6ADAABsi6ADAABsi6ADAABsi6ADAABsi6ADAABsi6ADAABs6/8AdYaDwvlpj34AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "plt.hist(test_data['groups'])\n",
    "np.unique(test_data['groups'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "anon=pd.DataFrame(np.zeros((3,3)),columns=['Accuracy','Demographic Parity','Time'])\n",
    "anon=np.zeros((3,4))\n",
    "fairl=pd.DataFrame(np.zeros((3,3)),columns=['Accuracy','Demographic Parity','Time'])\n",
    "fairl=np.zeros((3,4))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i,name in enumerate ((' Amer-Indian-Eskimo', ' Asian-Pac-Islander', ' Black', \"Other\")):\n",
    "    start=time.perf_counter()\n",
    "    fpred = FairPredictor(predictor,train_data)\n",
    "    fpred.fit(gm.accuracy,gm.demographic_parity,0.01)\n",
    "    stop=time.perf_counter()\n",
    "    score=fpred.evaluate_fairness(test_data,metrics={'a':gm.accuracy,'b':gm.demographic_parity},verbose=False)\n",
    "    anon[0,i]=score['updated']['a']#['updated']\n",
    "    anon[1,i]=score['updated']['b']#['updated']\n",
    "    anon[2,i]=stop-start\n",
    "    start=time.perf_counter()\n",
    "    fair = fairlearn.reductions.ExponentiatedGradient(xgboost.XGBClassifier(),fairlearn.reductions.DemographicParity())\n",
    "    fair.fit(X=train_data['data'],\n",
    "         y=train_data['target'],\n",
    "         sensitive_features=train_data['groups'])\n",
    "    stop=time.perf_counter()\n",
    "    score=evaluate_fairness(test_data['target'], fair.predict(test_data['data']), test_data['groups'], metrics={'a':gm.accuracy,'b':gm.demographic_parity},verbose=False)\n",
    "    fairl[0,i]=score[0]['a']#['updated']\n",
    "    fairl[1,i]=score[0]['b']#['updated']\n",
    "    fairl[2,i]=stop-start\n",
    "    train_data['groups'][train_data['groups']==name]=' Other'\n",
    "    test_data['groups'][test_data['groups']==name]=' Other'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "anon_df=pd.DataFrame(anon.T,columns=['Accuracy','Demographic Parity','Time'])\n",
    "fairl_df=pd.DataFrame(fairl.T,columns=['Accuracy','Demographic Parity','Time'])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lrrrrrr}\n",
      "\\toprule\n",
      " & Accuracy & Demographic Parity & Time & Accuracy & Demographic Parity & Time \\\\\n",
      "\\midrule\n",
      "0 & 0.868414 & 0.020884 & 50.576869 & 0.867527 & 0.032869 & 42.506781 \\\\\n",
      "1 & 0.867663 & 0.028689 & 0.802240 & 0.868141 & 0.041368 & 27.054427 \\\\\n",
      "2 & 0.868073 & 0.008791 & 0.081120 & 0.867049 & 0.015203 & 23.689572 \\\\\n",
      "3 & 0.868073 & 0.003674 & 0.055124 & 0.869574 & 0.006705 & 27.069056 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(pd.concat((anon_df,fairl_df),axis=1).to_latex())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "py3.8",
   "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
