{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Enforcing Fairness in Computer Vision\n",
    "\n",
    "This code demonstrates how to enforce fairness when working with deep neural networks in computer vision. \n",
    "\n",
    "We demonstrate how different notions of fairness and performance can be measured and enforced with our toolkit. \n",
    "\n",
    "We recommend you first consider the quickstart_xgboost.ipynb notebook for an introduction to the toolkit's functionality. \n",
    "\n",
    "We first show an example on [CelebA](https://mmlab.ie.cuhk.edu.hk/projects/CelebA.html). The protected groups are given by the labels for the attribute `Male` . You can specify which target attribute (e.g., Wearing_Earrings) you want to enforce fairness for. \n",
    "You can also specify which fairness and performance metrics to measure.\n",
    "\n",
    "At the end of the notebook, we look at an example using medical data from [Fitzpatrick-17k](https://arxiv.org/pdf/2104.09957).\n",
    "\n",
    "Input Requirements: \n",
    "\n",
    "1. We need the validation and test labels for the protected and target attributes.\n",
    "2. We also require the model outputs. These will typically be logits for the target attribute and probabilities for the inferred protected attribute. It is also possible to use the true group labels (non-inferred). This data used in this notebook demonstration is fetched from an anonymous repository.\n",
    "\n",
    "We use DeepFairPredictor (reccomended), which is optimized for deep learning classifiers. \n",
    "\n",
    "We also reccomend checking out this [paper](https://arxiv.org/pdf/2203.04913) for theoretically explanations into why the majority of fairness methods designed for low capacity models should not be used in settings involving high-capacity models and this [paper](https://proceedings.neurips.cc/paper_files/paper/2022/file/698c05933e5f7fde98e567a669d2c752-Paper-Conference.pdf) for more details on the two/multi headed approach for a post-processing approach to enforce fairness with validation data when working with deep learning models.  \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np \n",
    "import anonfair\n",
    "from anonfair.utils import group_metrics as gm\n",
    "from matplotlib import pyplot as plt\n",
    "import requests\n",
    "import io"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "As the files associated with pre-trained deep learning models can be quite large, we start by defining a function that can extract model outputs and labels from a URL."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define a function that takes variable names and URLs, and returns a dictionary of data\n",
    "def fetch_data_with_labels(variable_names, urls):\n",
    "    if len(variable_names) != len(urls):\n",
    "        raise ValueError(\"The number of variable names and URLs must be the same.\")\n",
    "\n",
    "    # Create a mapping between variable names and URLs\n",
    "    label_url_mapping = dict(zip(variable_names, urls))\n",
    "    fetched_data = {}\n",
    "\n",
    "    # Loop through the dictionary to fetch data\n",
    "    for label, url in label_url_mapping.items():\n",
    "        try:\n",
    "            # Fetch the data from the URL\n",
    "            response = requests.get(url)\n",
    "            response.raise_for_status()  # Check if the request was successful\n",
    "\n",
    "            # Load the data with numpy\n",
    "            data = np.load(io.BytesIO(response.content))\n",
    "\n",
    "            # Store the data in the dictionary with the given label\n",
    "            fetched_data[label] = data\n",
    "\n",
    "        except requests.exceptions.RequestException as e:\n",
    "            # Handle request errors (network issues, invalid URL, etc.)\n",
    "            print(f\"Error fetching '{label}' from '{url}': {e}\")\n",
    "\n",
    "        except Exception as e:\n",
    "            # Handle other exceptions (e.g., issues with loading data, numpy errors, etc.)\n",
    "            print(f\"Error processing '{label}' from '{url}': {e}\")\n",
    "\n",
    "    return fetched_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [],
   "source": [
    "variable_names_celeba = ['validation_labels', 'test_labels', 'validation_outputs', 'test_outputs']\n",
    "\n",
    "url_data_celeba = ['https://anonymous.4open.science/r/example_data_fairness-15BA/all_attributes_val_labels.npy',\n",
    "    'https://anonymous.4open.science/r/example_data_fairness-15BA/all_attributes_test_labels.npy',\n",
    "    'https://anonymous.4open.science/r/example_data_fairness-15BA/All_Attributes_outputs_val.npy',\n",
    "    'https://anonymous.4open.science/r/example_data_fairness-15BA/All_Attributes_outputs_test.npy']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [],
   "source": [
    "fetched_data = fetch_data_with_labels(variable_names=variable_names_celeba, urls=url_data_celeba)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [],
   "source": [
    "validation_labels = fetched_data['validation_labels'] #loading the validation labels for all attributes\n",
    "test_labels = fetched_data['test_labels'] #loading the test labels for all attributes\n",
    "validation_outputs = fetched_data['validation_outputs'] # loading the corresponding validation outputs \n",
    "test_outputs = fetched_data['test_outputs'] # loading the corresponding validation outputs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_all_celeba_attributes():\n",
    "    return ['5_o_Clock_Shadow', 'Arched_Eyebrows', 'Attractive', 'Bags_Under_Eyes', 'Bald', 'Bangs', 'Big_Lips',\n",
    "            'Big_Nose', 'Black_Hair', 'Blond_Hair', 'Blurry', 'Brown_Hair', 'Bushy_Eyebrows', 'Chubby',\n",
    "            'Double_Chin', 'Eyeglasses', 'Goatee', 'Gray_Hair', 'Heavy_Makeup', 'High_Cheekbones', 'Male',\n",
    "            'Mouth_Slightly_Open', 'Mustache', 'Narrow_Eyes', 'No_Beard', 'Oval_Face', 'Pale_Skin',\n",
    "            'Pointy_Nose', 'Receding_Hairline', 'Rosy_Cheeks', 'Sideburns', 'Smiling', 'Straight_Hair',\n",
    "            'Wavy_Hair', 'Wearing_Earrings', 'Wearing_Hat', 'Wearing_Lipstick', 'Wearing_Necklace',\n",
    "            'Wearing_Necktie', 'Young']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[-3.72390795, -0.04863382],\n",
       "       [-6.71334314,  1.003914  ],\n",
       "       [-5.54749012,  0.01078447],\n",
       "       ...,\n",
       "       [-1.99252629, -0.03643667],\n",
       "       [ 0.69160038, -0.02428942],\n",
       "       [-4.78321409,  0.98419327]])"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.column_stack((validation_outputs[:,34], validation_outputs[:,20])) #Outputs for Wearing_Earrings and Male"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([4.000e+00, 8.000e+00, 1.800e+01, 8.900e+01, 2.570e+02, 6.700e+02,\n",
       "        1.345e+03, 1.897e+03, 2.128e+03, 1.857e+03, 1.278e+03, 7.590e+02,\n",
       "        3.940e+02, 1.850e+02, 1.280e+02, 6.500e+01, 4.100e+01, 3.400e+01,\n",
       "        2.600e+01, 1.800e+01, 1.500e+01, 2.500e+01, 1.700e+01, 1.000e+01,\n",
       "        1.400e+01, 7.000e+00, 1.500e+01, 9.000e+00, 6.000e+00, 8.000e+00,\n",
       "        9.000e+00, 4.000e+00, 3.000e+00, 7.000e+00, 6.000e+00, 6.000e+00,\n",
       "        3.000e+00, 2.000e+00, 4.000e+00, 9.000e+00, 6.000e+00, 3.000e+00,\n",
       "        7.000e+00, 8.000e+00, 0.000e+00, 5.000e+00, 8.000e+00, 6.000e+00,\n",
       "        7.000e+00, 4.000e+00, 7.000e+00, 8.000e+00, 6.000e+00, 4.000e+00,\n",
       "        9.000e+00, 6.000e+00, 7.000e+00, 1.000e+00, 5.000e+00, 7.000e+00,\n",
       "        6.000e+00, 6.000e+00, 6.000e+00, 6.000e+00, 4.000e+00, 6.000e+00,\n",
       "        1.200e+01, 9.000e+00, 1.600e+01, 1.300e+01, 9.000e+00, 1.000e+01,\n",
       "        1.200e+01, 2.000e+01, 2.800e+01, 2.200e+01, 3.300e+01, 4.000e+01,\n",
       "        5.800e+01, 1.090e+02, 1.510e+02, 1.940e+02, 3.110e+02, 4.840e+02,\n",
       "        6.890e+02, 8.550e+02, 1.002e+03, 1.008e+03, 9.610e+02, 7.820e+02,\n",
       "        6.340e+02, 3.670e+02, 2.380e+02, 1.350e+02, 7.400e+01, 3.400e+01,\n",
       "        1.900e+01, 7.000e+00, 1.000e+00, 2.000e+00]),\n",
       " array([-1.13295622e-01, -1.00760359e-01, -8.82250966e-02, -7.56898338e-02,\n",
       "        -6.31545711e-02, -5.06193083e-02, -3.80840455e-02, -2.55487827e-02,\n",
       "        -1.30135199e-02, -4.78257164e-04,  1.20570056e-02,  2.45922684e-02,\n",
       "         3.71275312e-02,  4.96627939e-02,  6.21980567e-02,  7.47333195e-02,\n",
       "         8.72685823e-02,  9.98038451e-02,  1.12339108e-01,  1.24874371e-01,\n",
       "         1.37409633e-01,  1.49944896e-01,  1.62480159e-01,  1.75015422e-01,\n",
       "         1.87550685e-01,  2.00085947e-01,  2.12621210e-01,  2.25156473e-01,\n",
       "         2.37691736e-01,  2.50226998e-01,  2.62762261e-01,  2.75297524e-01,\n",
       "         2.87832787e-01,  3.00368050e-01,  3.12903312e-01,  3.25438575e-01,\n",
       "         3.37973838e-01,  3.50509101e-01,  3.63044363e-01,  3.75579626e-01,\n",
       "         3.88114889e-01,  4.00650152e-01,  4.13185415e-01,  4.25720677e-01,\n",
       "         4.38255940e-01,  4.50791203e-01,  4.63326466e-01,  4.75861728e-01,\n",
       "         4.88396991e-01,  5.00932254e-01,  5.13467517e-01,  5.26002780e-01,\n",
       "         5.38538042e-01,  5.51073305e-01,  5.63608568e-01,  5.76143831e-01,\n",
       "         5.88679093e-01,  6.01214356e-01,  6.13749619e-01,  6.26284882e-01,\n",
       "         6.38820145e-01,  6.51355407e-01,  6.63890670e-01,  6.76425933e-01,\n",
       "         6.88961196e-01,  7.01496458e-01,  7.14031721e-01,  7.26566984e-01,\n",
       "         7.39102247e-01,  7.51637510e-01,  7.64172772e-01,  7.76708035e-01,\n",
       "         7.89243298e-01,  8.01778561e-01,  8.14313823e-01,  8.26849086e-01,\n",
       "         8.39384349e-01,  8.51919612e-01,  8.64454875e-01,  8.76990137e-01,\n",
       "         8.89525400e-01,  9.02060663e-01,  9.14595926e-01,  9.27131188e-01,\n",
       "         9.39666451e-01,  9.52201714e-01,  9.64736977e-01,  9.77272240e-01,\n",
       "         9.89807502e-01,  1.00234277e+00,  1.01487803e+00,  1.02741329e+00,\n",
       "         1.03994855e+00,  1.05248382e+00,  1.06501908e+00,  1.07755434e+00,\n",
       "         1.09008960e+00,  1.10262487e+00,  1.11516013e+00,  1.12769539e+00,\n",
       "         1.14023066e+00]),\n",
       " <BarContainer object of 100 artists>)"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist((validation_outputs[:,20]), bins=100) # just looking at the outputs from the protected head. The bi-modal peak indicates good seperation between groups. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [],
   "source": [
    "protected_attribute_index = get_all_celeba_attributes().index('Male')\n",
    "target_attribute_index = get_all_celeba_attributes().index('Wearing_Earrings')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [],
   "source": [
    "val = np.column_stack((validation_outputs[:,target_attribute_index], validation_outputs[:,20]))\n",
    "val_target = validation_labels[:,target_attribute_index]\n",
    "val_groups = validation_labels[:,protected_attribute_index]\n",
    "\n",
    "test = np.column_stack((test_outputs[:,target_attribute_index], test_outputs[:,20]))\n",
    "test_target = test_labels[:,target_attribute_index]\n",
    "test_groups = test_labels[:,protected_attribute_index]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Helper functions. These are handled under-the-hood when using FairDeepPredictor.\n",
    "#We assume that classifiers return multiple scores roughly lying in [0,1].\n",
    "#To make this happen,we push logits through a sigmoid, and for square outputs we return them, and 1- them\n",
    "def sigmoid(array):\n",
    "    return np.stack ((1/(1+np.exp(array[:,0])),1/(1+np.exp(-array[:,0]))),1)\n",
    "def square_align(array):\n",
    "    return np.stack((array[:,1],1-array[:,1]),1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [],
   "source": [
    "val_dict={'data':val, 'target':val_target, 'groups':val_groups}\n",
    "test_dict={'data':test,'target':test_target,'groups':test_groups}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Enforcing Fairness with DeepFairPredictor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [],
   "source": [
    "fpred = anonfair.DeepFairPredictor(val_target,val,val_groups, use_actual_groups=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [],
   "source": [
    "fpred.fit(gm.accuracy,gm.equal_opportunity,0.01)\n",
    "# this can be changed to different definitions of fairness --- fpred.fit(gm.accuracy,gm.recall.min,0.8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>original</th>\n",
       "      <th>updated</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Accuracy</th>\n",
       "      <td>0.910380</td>\n",
       "      <td>0.901212</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Balanced Accuracy</th>\n",
       "      <td>0.853250</td>\n",
       "      <td>0.847742</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>F1 score</th>\n",
       "      <td>0.777072</td>\n",
       "      <td>0.759922</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MCC</th>\n",
       "      <td>0.721488</td>\n",
       "      <td>0.697746</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Precision</th>\n",
       "      <td>0.799487</td>\n",
       "      <td>0.763267</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Recall</th>\n",
       "      <td>0.755879</td>\n",
       "      <td>0.756606</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ROC AUC</th>\n",
       "      <td>0.956715</td>\n",
       "      <td>0.945808</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                   original   updated\n",
       "Accuracy           0.910380  0.901212\n",
       "Balanced Accuracy  0.853250  0.847742\n",
       "F1 score           0.777072  0.759922\n",
       "MCC                0.721488  0.697746\n",
       "Precision          0.799487  0.763267\n",
       "Recall             0.755879  0.756606\n",
       "ROC AUC            0.956715  0.945808"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fpred.evaluate(test_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Accuracy</th>\n",
       "      <th>Balanced Accuracy</th>\n",
       "      <th>F1 score</th>\n",
       "      <th>MCC</th>\n",
       "      <th>Precision</th>\n",
       "      <th>Recall</th>\n",
       "      <th>ROC AUC</th>\n",
       "      <th>Number of Datapoints</th>\n",
       "      <th>Positive Count</th>\n",
       "      <th>Negative Count</th>\n",
       "      <th>Positive Label Rate</th>\n",
       "      <th>Positive Prediction Rate</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>Groups</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">original</th>\n",
       "      <th>Overall</th>\n",
       "      <td>0.924800</td>\n",
       "      <td>0.861855</td>\n",
       "      <td>0.794045</td>\n",
       "      <td>0.749278</td>\n",
       "      <td>0.831169</td>\n",
       "      <td>0.760095</td>\n",
       "      <td>0.965498</td>\n",
       "      <td>19867.0</td>\n",
       "      <td>3789.0</td>\n",
       "      <td>16078.0</td>\n",
       "      <td>0.190718</td>\n",
       "      <td>0.174410</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.878429</td>\n",
       "      <td>0.852288</td>\n",
       "      <td>0.805169</td>\n",
       "      <td>0.717852</td>\n",
       "      <td>0.833624</td>\n",
       "      <td>0.778593</td>\n",
       "      <td>0.940365</td>\n",
       "      <td>11409.0</td>\n",
       "      <td>3681.0</td>\n",
       "      <td>7728.0</td>\n",
       "      <td>0.322640</td>\n",
       "      <td>0.301341</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.987349</td>\n",
       "      <td>0.564036</td>\n",
       "      <td>0.207407</td>\n",
       "      <td>0.254912</td>\n",
       "      <td>0.518519</td>\n",
       "      <td>0.129630</td>\n",
       "      <td>0.960154</td>\n",
       "      <td>8458.0</td>\n",
       "      <td>108.0</td>\n",
       "      <td>8350.0</td>\n",
       "      <td>0.012769</td>\n",
       "      <td>0.003192</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximum difference</th>\n",
       "      <td>0.108920</td>\n",
       "      <td>0.288252</td>\n",
       "      <td>0.597762</td>\n",
       "      <td>0.462940</td>\n",
       "      <td>0.315106</td>\n",
       "      <td>0.648963</td>\n",
       "      <td>0.019789</td>\n",
       "      <td>2951.0</td>\n",
       "      <td>3573.0</td>\n",
       "      <td>622.0</td>\n",
       "      <td>0.309871</td>\n",
       "      <td>0.298149</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">updated</th>\n",
       "      <th>Overall</th>\n",
       "      <td>0.914783</td>\n",
       "      <td>0.851228</td>\n",
       "      <td>0.770129</td>\n",
       "      <td>0.718332</td>\n",
       "      <td>0.793065</td>\n",
       "      <td>0.748482</td>\n",
       "      <td>0.953682</td>\n",
       "      <td>19867.0</td>\n",
       "      <td>3789.0</td>\n",
       "      <td>16078.0</td>\n",
       "      <td>0.190718</td>\n",
       "      <td>0.179997</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.875011</td>\n",
       "      <td>0.841940</td>\n",
       "      <td>0.794465</td>\n",
       "      <td>0.707874</td>\n",
       "      <td>0.846177</td>\n",
       "      <td>0.748710</td>\n",
       "      <td>0.940003</td>\n",
       "      <td>11409.0</td>\n",
       "      <td>3681.0</td>\n",
       "      <td>7728.0</td>\n",
       "      <td>0.322640</td>\n",
       "      <td>0.285476</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.968432</td>\n",
       "      <td>0.856059</td>\n",
       "      <td>0.374707</td>\n",
       "      <td>0.419688</td>\n",
       "      <td>0.250784</td>\n",
       "      <td>0.740741</td>\n",
       "      <td>0.958908</td>\n",
       "      <td>8458.0</td>\n",
       "      <td>108.0</td>\n",
       "      <td>8350.0</td>\n",
       "      <td>0.012769</td>\n",
       "      <td>0.037716</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximum difference</th>\n",
       "      <td>0.093421</td>\n",
       "      <td>0.014119</td>\n",
       "      <td>0.419758</td>\n",
       "      <td>0.288186</td>\n",
       "      <td>0.595394</td>\n",
       "      <td>0.007969</td>\n",
       "      <td>0.018905</td>\n",
       "      <td>2951.0</td>\n",
       "      <td>3573.0</td>\n",
       "      <td>622.0</td>\n",
       "      <td>0.309871</td>\n",
       "      <td>0.247761</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                             Accuracy  Balanced Accuracy  F1 score       MCC  \\\n",
       "         Groups                                                                \n",
       "original Overall             0.924800           0.861855  0.794045  0.749278   \n",
       "         0                   0.878429           0.852288  0.805169  0.717852   \n",
       "         1                   0.987349           0.564036  0.207407  0.254912   \n",
       "         Maximum difference  0.108920           0.288252  0.597762  0.462940   \n",
       "updated  Overall             0.914783           0.851228  0.770129  0.718332   \n",
       "         0                   0.875011           0.841940  0.794465  0.707874   \n",
       "         1                   0.968432           0.856059  0.374707  0.419688   \n",
       "         Maximum difference  0.093421           0.014119  0.419758  0.288186   \n",
       "\n",
       "                             Precision    Recall   ROC AUC  \\\n",
       "         Groups                                              \n",
       "original Overall              0.831169  0.760095  0.965498   \n",
       "         0                    0.833624  0.778593  0.940365   \n",
       "         1                    0.518519  0.129630  0.960154   \n",
       "         Maximum difference   0.315106  0.648963  0.019789   \n",
       "updated  Overall              0.793065  0.748482  0.953682   \n",
       "         0                    0.846177  0.748710  0.940003   \n",
       "         1                    0.250784  0.740741  0.958908   \n",
       "         Maximum difference   0.595394  0.007969  0.018905   \n",
       "\n",
       "                             Number of Datapoints  Positive Count  \\\n",
       "         Groups                                                     \n",
       "original Overall                          19867.0          3789.0   \n",
       "         0                                11409.0          3681.0   \n",
       "         1                                 8458.0           108.0   \n",
       "         Maximum difference                2951.0          3573.0   \n",
       "updated  Overall                          19867.0          3789.0   \n",
       "         0                                11409.0          3681.0   \n",
       "         1                                 8458.0           108.0   \n",
       "         Maximum difference                2951.0          3573.0   \n",
       "\n",
       "                             Negative Count  Positive Label Rate  \\\n",
       "         Groups                                                    \n",
       "original Overall                    16078.0             0.190718   \n",
       "         0                           7728.0             0.322640   \n",
       "         1                           8350.0             0.012769   \n",
       "         Maximum difference           622.0             0.309871   \n",
       "updated  Overall                    16078.0             0.190718   \n",
       "         0                           7728.0             0.322640   \n",
       "         1                           8350.0             0.012769   \n",
       "         Maximum difference           622.0             0.309871   \n",
       "\n",
       "                             Positive Prediction Rate  \n",
       "         Groups                                        \n",
       "original Overall                             0.174410  \n",
       "         0                                   0.301341  \n",
       "         1                                   0.003192  \n",
       "         Maximum difference                  0.298149  \n",
       "updated  Overall                             0.179997  \n",
       "         0                                   0.285476  \n",
       "         1                                   0.037716  \n",
       "         Maximum difference                  0.247761  "
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fpred.evaluate_groups(return_original=True) #on val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {},
   "outputs": [],
   "source": [
    "fpred.evaluate_groups(test_dict,return_original=True) #on the test set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "editable": true,
    "slideshow": {
     "slide_type": ""
    },
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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DHniR2AQERERWVK5jwDt3r0bt27dQsuWLREcHIzZs2cjJyfHlLURERERmUS5A9Dzzz+P+fPnIysrC++//z5WrFiBunXrQqPRYNu2bbh165Yp6yQiIiIyGoMfhvqgjIwMfPfdd1i8eDFu3ryJLl26YMOGDcaszyI4CZqIiKjqMenDUB/k4+ODqVOn4u+//8by5cufZFVEREREZvNER4CeVjwCREREVPWY7QgQERERUVXEAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJJTKQLQnDlz4OXlBZVKheDgYKSkpDyyf0JCAnx8fGBjYwMPDw+MHDkSBQUFevt+9tlnkMlkGDFihAkqJyIioqrI4gFo5cqViIqKQmxsLFJTU9G8eXOEhobiypUrevsvW7YM0dHRiI2NRXp6Or777jusXLkSY8aMKdX3wIED+Prrr9GsWTNT7wYRERFVIRYPQNOnT8fAgQPRv39/+Pn5Yd68ebC1tcWCBQv09v/jjz/Qpk0bvPnmm/Dy8sKLL76Ivn37ljpqlJ+fj7feegvz589HzZo1zbErREREVEVYNAAVFRXh0KFD6Ny5s7ZNLpejc+fO2Lt3r95lWrdujUOHDmkDz7lz57B582Z069ZNp9/QoUPRvXt3nXUTERERAUA1S248JycHarUaLi4uOu0uLi44efKk3mXefPNN5OTkoG3bthBC4N69exg8eLDOKbAVK1YgNTUVBw4cKFcdhYWFKCws1L7Py8urwN4QERFRVWHxU2CG2rFjB6ZMmYK5c+ciNTUVa9aswaZNmzBp0iQAwKVLlzB8+HAsXboUKpWqXOuMj4+Ho6Oj9uXh4WHKXSAiIiILkwkhhKU2XlRUBFtbW/z444/o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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "figure = fpred.plot_frontier() #looking at the frontier on the validation set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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AERERESiwwBEREREosMARERERKLDAERERESiwwBEREREosMARERERKLDAERERESiwwBEREREosMARERERKLDAERERESiwwBEREREosMARERERKLDAERERESiwwBEREREosMARERERKLDAERERESiwwBEREREosMARERERKLDAERERESiwwBEREREosMARERERKLDAERERESiwwBEREREosMARERERKLDAERERESiY/YAtGjRInh4eEChUCAwMBDJycnPbB8fHw8vLy9YWVnBzc0N48ePR2FhofpzpVKJ6OhoeHp6wsrKCk2aNMH06dMhCIKpD4WIiIiqiVrm3PnGjRsRERGBJUuWIDAwEPHx8QgJCUF6ejocHR3LtF+3bh0iIyOxYsUKdOjQARcuXEB4eDgkEgnmzp0LAPjyyy+RkJCAVatW4cUXX8Tx48cxaNAg2NnZ4eOPP67sQyQiIqIqSCKYsWskMDAQ7du3x8KFCwEAKpUKbm5uGDNmDCIjI8u0Hz16NNLS0pCUlKRe9sknn+Do0aM4ePAgAOCNN96Ak5MTli9frm7z7rvvwsrKCmvWrNGprvz8fNjZ2SEvLw+2trbPc4hERERUSfT5/jbbEFhxcTFOnDiB4ODg/xUjlSI4OBiHDx/Wuk6HDh1w4sQJ9TDZlStXsGvXLvTs2VOjTVJSEi5cuAAAOH36NA4ePIjXXnut3FqKioqQn5+v8SIiIqKay2xDYLm5uVAqlXByctJY7uTkhPPnz2tdp3///sjNzUWnTp0gCAIePXqEESNGYNKkSeo2kZGRyM/PR4sWLSCTyaBUKjFjxgy8//775dYSFxeH2NhY4xwYERERVXlmnwStj3379mHmzJlYvHgxUlJSsHnzZuzcuRPTp09Xt/n++++xdu1arFu3DikpKVi1ahVmz56NVatWlbvdiRMnIi8vT/3KyMiojMMhIiIiMzFbD1CDBg0gk8mQnZ2tsTw7OxvOzs5a14mOjsaAAQMwdOhQAEDLli1RUFCA4cOHY/LkyZBKpfj0008RGRmJvn37qtv8/fffiIuLQ1hYmNbtWlpawtLS0ohHR0RERFWZ2XqA5HI52rVrpzGhWaVSISkpCUFBQVrXefDgAaRSzZJlMhkAqC9zL6+NSqUyZvlERERUjZn1MviIiAiEhYXB398fAQEBiI+PR0FBAQYNGgQAGDhwIFxd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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fpred.plot_frontier(test_dict) # viewing performance on the test set. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>original</th>\n",
       "      <th>updated</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Class Imbalance</th>\n",
       "      <td>0.298366</td>\n",
       "      <td>0.298366</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Demographic Parity</th>\n",
       "      <td>0.303656</td>\n",
       "      <td>0.239229</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Disparate Impact</th>\n",
       "      <td>0.029013</td>\n",
       "      <td>0.195322</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximal Group Difference in Accuracy</th>\n",
       "      <td>0.113541</td>\n",
       "      <td>0.088342</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximal Group Difference in Recall</th>\n",
       "      <td>0.509111</td>\n",
       "      <td>0.030452</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximal Group Difference in Conditional Acceptance Rate</th>\n",
       "      <td>1.570496</td>\n",
       "      <td>0.676694</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximal Group Difference in Acceptance Rate</th>\n",
       "      <td>0.101305</td>\n",
       "      <td>0.498711</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximal Group Difference in Specificity</th>\n",
       "      <td>0.088855</td>\n",
       "      <td>0.039353</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximal Group Difference in Conditional Rejectance Rate</th>\n",
       "      <td>0.001225</td>\n",
       "      <td>0.071696</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximal Group Difference in Rejection Rate</th>\n",
       "      <td>0.086440</td>\n",
       "      <td>0.106764</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Treatment Equality</th>\n",
       "      <td>0.712815</td>\n",
       "      <td>7.133466</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Generalized Entropy</th>\n",
       "      <td>0.045773</td>\n",
       "      <td>0.049571</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                    original   updated\n",
       "Class Imbalance                                     0.298366  0.298366\n",
       "Demographic Parity                                  0.303656  0.239229\n",
       "Disparate Impact                                    0.029013  0.195322\n",
       "Maximal Group Difference in Accuracy                0.113541  0.088342\n",
       "Maximal Group Difference in Recall                  0.509111  0.030452\n",
       "Maximal Group Difference in Conditional Accepta...  1.570496  0.676694\n",
       "Maximal Group Difference in Acceptance Rate         0.101305  0.498711\n",
       "Maximal Group Difference in Specificity             0.088855  0.039353\n",
       "Maximal Group Difference in Conditional Rejecta...  0.001225  0.071696\n",
       "Maximal Group Difference in Rejection Rate          0.086440  0.106764\n",
       "Treatment Equality                                  0.712815  7.133466\n",
       "Generalized Entropy                                 0.045773  0.049571"
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fpred.evaluate_fairness(test_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>original</th>\n",
       "      <th>updated</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Minimal Group Minimum-Label-Accuracy</th>\n",
       "      <td>0.12963</td>\n",
       "      <td>0.801684</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Accuracy</th>\n",
       "      <td>0.92480</td>\n",
       "      <td>0.906126</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                      original   updated\n",
       "Minimal Group Minimum-Label-Accuracy   0.12963  0.801684\n",
       "Accuracy                               0.92480  0.906126"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fpred.evaluate_fairness(metrics={'min_acc':gm.min_accuracy.min,'accuracy':gm.accuracy}) #you can specify what metrics you care about"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>original</th>\n",
       "      <th>updated</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Minimal Group Minimum-Label-Accuracy</th>\n",
       "      <td>0.269231</td>\n",
       "      <td>0.801927</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Accuracy</th>\n",
       "      <td>0.910380</td>\n",
       "      <td>0.889540</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                      original   updated\n",
       "Minimal Group Minimum-Label-Accuracy  0.269231  0.801927\n",
       "Accuracy                              0.910380  0.889540"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fpred.evaluate_fairness(test_dict,metrics={'min_acc':gm.min_accuracy.min,'accuracy':gm.accuracy})"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Fitzpatrick-17k Example\n",
    "\n",
    "Next we demonstrate how our toolkit could be used with medical data. The implementation details will be similar but practitioners may want to think carefully about how they measure and enforce fairness in high stakes domains. We reccomend a harms first approach emphasising metrics such as per group recall or selection rate. \n",
    "\n",
    "Here the target label classifies if a skin condition is malignant or benign. The protected label indicates race. Data is preprocessed following the description and code of [Zong et al.](https://arxiv.org/pdf/2210.01725) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "variable_names_fitz17k = ['fitz_outputs_val', 'fitz_outputs_test', 'fitz_target_labels_val',\n",
    "                           'fitz_protected_labels_val', 'fitz_target_labels_test', 'fitz_protected_labels_test']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "url_fitz17k = ['https://anonymous.4open.science/r/example_data_fairness-15BA/60_20_20_1_balanced_outputs_val_fitz17k.npy',\n",
    "               'https://anonymous.4open.science/r/example_data_fairness-15BA/60_20_20_1_balanced_outputs_test_fitz17k.npy',\n",
    "               'https://anonymous.4open.science/r/example_data_fairness-15BA/60_20_20_1_fitz17k_target_labels_val.npy',\n",
    "               'https://anonymous.4open.science/r/example_data_fairness-15BA/60_20_20_1_fitz17k_protected_labels_val.npy',\n",
    "               'https://anonymous.4open.science/r/example_data_fairness-15BA/60_20_20_1_fitz17k_target_labels_test.npy',\n",
    "               'https://anonymous.4open.science/r/example_data_fairness-15BA/60_20_20_1_fitz17k_protected_labels_test.npy'\n",
    "               ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fitz_data = fetch_data_with_labels(variable_names_fitz17k, url_fitz17k)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ 0.79199237,  0.37575418],\n",
       "       [-2.51230526,  0.70082897],\n",
       "       [-4.45861387,  0.61371773],\n",
       "       ...,\n",
       "       [ 1.30813837,  0.23435649],\n",
       "       [-2.95502949,  0.38634309],\n",
       "       [-3.13313341,  0.14978038]])"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fitz_data['fitz_outputs_val']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fitz_outputs_val = fitz_data['fitz_outputs_val']\n",
    "fitz_outputs_test = fitz_data['fitz_outputs_test']\n",
    "fitz_target_labels_val = fitz_data['fitz_target_labels_val']\n",
    "fitz_protected_labels_val = fitz_data['fitz_protected_labels_val']\n",
    "fitz_target_labels_test = fitz_data['fitz_target_labels_test']\n",
    "fitz_protected_labels_test = fitz_data['fitz_protected_labels_test']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "val_dict_fitz={'data':fitz_outputs_val, 'target':fitz_target_labels_val, 'groups':fitz_protected_labels_val}\n",
    "test_dict_fitz={'data':fitz_outputs_test,'target':fitz_target_labels_test,'groups':fitz_protected_labels_test}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fpred_fitz = anonfair.DeepFairPredictor(fitz_target_labels_val,fitz_outputs_val,fitz_protected_labels_val)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fpred_fitz.fit(gm.accuracy,gm.recall.min,0.7)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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8gabro1sg8127drh8OHDlY4nJyejbVv1eqUzZ87g0aNHqi/hkydPomnTpvD09ISjoyMsLCzw22+/qXoL7t69iz///BO9evUCAFy4cAF37tzBv//9b9Ukk1OnTqndQzmLp7S0VHXM19cXlpaWuHLliupaFXXo0AH79+9XO3by5EmdfgYnT57E6NGj1d4re4Q0cXFxgbu7Oy5fvozXX39dazzbtm1DYWGhqvemung6duyIuLg4tTqm8qRSqdrPRXmf7777DoIgqHpv4uPjYWtrW2lIsC6YPLkhImrs9Nm93FyFh4dj9erVeOeddzBhwgRYWlrihx9+wM6dO3HgwAG1tsXFxRg/fjzmzp2LrKwsREZGYurUqRCLxWjatCnGjx+P999/H46OjnB2dsacOXPURgFatGgBqVSKzz//HJMmTcK5c+cqzbpt2bIlRCIRDh48iAEDBsDKygq2trZ47733MGPGDCgUCvTo0QN5eXmIj4+HnZ0dxowZg0mTJmH58uV4//33MWHCBCQlJWHLli06/Qy++eYbBAQEoEePHtixYwcSExOxcePGKs+JiorCO++8A7lcjv79+6OoqAinTp3C3bt3ERERgddeew1z5szBxIkTMXv2bGRlZWHZsmVVXnP27Nl45plnMHnyZEyaNAlSqRTHjh3Dv/71Lzg5OcHLywu//fYbsrKyVPVJkydPxqpVq/D2229j6tSpSE9PR2RkJCIiIirVytYJoZHJy8sTAAh5eXmmDoWIyOAePXokpKamCo8ePdL73PO3zwt+W/yqfZ2/fd4IkQtCYmKiEBISIjRv3lyQy+VCUFCQsHfvXrU2Y8aMEQYPHizMnz9fcHR0FJo2bSpMnDhRKCwsVLW5f/++MGrUKMHa2lpwcXERPv74Y6FXr17CtGnTVG2+/vprwcvLS7C0tBSCg4OF/fv3CwCE06dPq9osXLhQcHV1FUQikTBmzBhBEARBoVAIq1atEtq1aydYWFgIzZs3F0JDQ4VffvlFdd6BAweE1q1bC5aWlsLzzz8vbNq0SQAg3L17V+uzAxDWrFkjhISECJaWloKXl5ewe/du1eeZmZmV4lPasWOH4O/vL0ilUqFZs2ZCz549hT179qg+T0hIEDp16iRIpVLB399f+O6779SudezYsUrxHT9+XHjuuecES0tLwd7eXggNDVV9np6eLjz77LOClZWV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29sbiYmJuHPnDt59910sW7bMGDESERE1KP393BDi64rEzFzcvF+oWo0YQKVj7LExPL33lnJycsLRo0fRsWNHyOVyJCYmol27djh69CjeffddnD592lixGgT3liIiIlNTbrLJJEd3Rt1bqrS0FLa2tgDKEp3r16+jXbt2aNmyJdLT02sWMRERUSMRey670pAVdw03LL2ngvv5+eHMmTMAgKCgIHz88ceIj4/HwoUL0apVK4MHSEREZC6Uu4ZXnE3FbRgMS+/kZu7cuVAoFACAhQsXIjMzE88//zwOHTqEzz77zOABEhERmYPqdg0HuA2Doeg9LBUaGqr699atW+PChQvIzc1Fs2bNVDOmiIiISJ2uu4YnZuYi2Mex7gIzQ3r13JSUlKBJkyY4d+6c2nEHBwcmNkRERFXQdXsFbsNQe3olNxYWFmjRogXXsiEiItKTrtsrcBuG2tO75mbOnDn48MMPkZvL3UuJiIh0pdyaoapxDrEIuFtQVGcxmSu917np3LkzLl26hJKSErRs2RI2NjZqnycnJxs0QEPjOjdERGQqytlSVX3xigCsG9WF08IrMOo6N0OGDKlpXERERI1afz83rHmtC6buTEZVk6KiDqQixNeVC/vVkN7JTWRkpDHiICIiahSa2UirTGw4a6r29K65ISIioprjrCnj07vnRiwWVzntmzOpiIiItNN1NlTW7QIjR2K+9E5u9u7dq/a+pKQEp0+fxtatWxEVFWWwwIiIiMyRctZUTl5hlYXFK49cRDtXWxYW14Des6W0+frrr7F7927s27fPEJczGs6WIiIiU9N11pSrXIYTM/uwsBj6fX8brObm2WefRVxcnKEuR0REZLb6+7lher+2VbYpX1hM+jFIcvPo0SN89tln8PDwMMTliIiIzJ6Xk7VO7VhYrD+9a24qbpApCALu378Pa2trbN++3aDBERERmStux2A8eic3K1euVEtuxGIxmjdvjqCgIDRr1sygwREREZmr6gqLlTU3gd4OdR1ag2ewguKGggXFRERUXygLiwGoJTjKLoTp/drCy8kazrZlSU5jLizW5/tb7+Rm8+bNaNq0Kf71r3+pHf/mm2/w8OFDjBkzRv+I6xCTGyIiqk9iz2Uj6kAqsvOe1NY0s7aAAODewxLVMTe5DJGDfBvt1HCjJjdt27bF+vXr8cILL6gd/+WXX/Dmm28i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ocDy5cvx7LPPom3btrh+/brO8RCZMyY3RA2YRCJBWloaUlNTIZFITB2OSrNmzeDo6IgvvvgCly5dwtGjRxEREaHXNUQiETZv3oz09HR0794d+/fvx8WLF5GamoqYmBjcunWr2md+//33sXTpUuzevRvp6emYNWsWUlJSMG3aNABA69at4enpiQULFuDixYv44YcfsHz58krXsbCwwNtvv43ffvsNSUlJGDt2LJ599lkEBgbq9UzTp0/H+vXrce3aNbz++utwcnLC4MGD8d///heZmZk4fvw43nnnHfz9998Ayoq4ly9fjs8++wwXL15EcnKyqmi7devWKCkpweeff47Lly9j27ZtiImJ0SseInPF5IaogbOzs4OdnZ2pw1AjFouxa9cuJCUlwc/PDzNmzMAnn3yi93WeffZZJCUloV27dpgyZQp8fX3x3HPPYefOnVi5ciXCw8OrPP+dd95BREQE3n33XTzzzDOIjY3F/v37VUNeFhYW2LlzJy5cuICOHTti6dKl+Oijjypdx9raGjNnzsRrr72G7t27o2nTpti9e7fez9O/f394e3tj8eLFsLa2xq+//ooWLVpg2LBh6NChA8aPH4/CwkLV73PMmDFYtWoV1q5di6effhovvfSSaqZXp06dsGLFCixduhR+fn7YsWMHoqOj9Y6JyByJhPKDzUREpGbLli2YPn262lo4RFS/seeGiIiIzAqTGyIiIjIrHJYiIiIis8KeGyIiIjIrTG6IiIjIrDC5ISIiIrPC5IaIiIjMCpMbIiIiMitMboiIiMisMLkhIiIis8LkhoiIiMwKkxsiIiIyK/8HSiZaKJ/HW5kAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fpred_fitz.plot_frontier() #looking at the frontier on the validation set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fpred_fitz.plot_frontier(test_dict_fitz) #looking at the frontier on the validation set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Accuracy</th>\n",
       "      <th>Balanced Accuracy</th>\n",
       "      <th>F1 score</th>\n",
       "      <th>MCC</th>\n",
       "      <th>Precision</th>\n",
       "      <th>Recall</th>\n",
       "      <th>ROC AUC</th>\n",
       "      <th>Number of Datapoints</th>\n",
       "      <th>Positive Count</th>\n",
       "      <th>Negative Count</th>\n",
       "      <th>Positive Label Rate</th>\n",
       "      <th>Positive Prediction Rate</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>Groups</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">original</th>\n",
       "      <th>Overall</th>\n",
       "      <td>0.839023</td>\n",
       "      <td>0.720454</td>\n",
       "      <td>0.486000</td>\n",
       "      <td>0.396986</td>\n",
       "      <td>0.430851</td>\n",
       "      <td>0.557339</td>\n",
       "      <td>0.824450</td>\n",
       "      <td>3193.0</td>\n",
       "      <td>436.0</td>\n",
       "      <td>2757.0</td>\n",
       "      <td>0.136549</td>\n",
       "      <td>0.176636</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0</th>\n",
       "      <td>0.816804</td>\n",
       "      <td>0.708386</td>\n",
       "      <td>0.474308</td>\n",
       "      <td>0.371757</td>\n",
       "      <td>0.414747</td>\n",
       "      <td>0.553846</td>\n",
       "      <td>0.813847</td>\n",
       "      <td>2178.0</td>\n",
       "      <td>325.0</td>\n",
       "      <td>1853.0</td>\n",
       "      <td>0.149219</td>\n",
       "      <td>0.199265</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1.0</th>\n",
       "      <td>0.886700</td>\n",
       "      <td>0.746726</td>\n",
       "      <td>0.522822</td>\n",
       "      <td>0.460837</td>\n",
       "      <td>0.484615</td>\n",
       "      <td>0.567568</td>\n",
       "      <td>0.840469</td>\n",
       "      <td>1015.0</td>\n",
       "      <td>111.0</td>\n",
       "      <td>904.0</td>\n",
       "      <td>0.109360</td>\n",
       "      <td>0.128079</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximum difference</th>\n",
       "      <td>0.069895</td>\n",
       "      <td>0.038341</td>\n",
       "      <td>0.048513</td>\n",
       "      <td>0.089081</td>\n",
       "      <td>0.069869</td>\n",
       "      <td>0.013721</td>\n",
       "      <td>0.026622</td>\n",
       "      <td>1163.0</td>\n",
       "      <td>214.0</td>\n",
       "      <td>949.0</td>\n",
       "      <td>0.039860</td>\n",
       "      <td>0.071187</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">updated</th>\n",
       "      <th>Overall</th>\n",
       "      <td>0.792671</td>\n",
       "      <td>0.740920</td>\n",
       "      <td>0.468700</td>\n",
       "      <td>0.380241</td>\n",
       "      <td>0.360494</td>\n",
       "      <td>0.669725</td>\n",
       "      <td>0.819747</td>\n",
       "      <td>3193.0</td>\n",
       "      <td>436.0</td>\n",
       "      <td>2757.0</td>\n",
       "      <td>0.136549</td>\n",
       "      <td>0.253680</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0</th>\n",
       "      <td>0.776860</td>\n",
       "      <td>0.731849</td>\n",
       "      <td>0.471739</td>\n",
       "      <td>0.370780</td>\n",
       "      <td>0.364706</td>\n",
       "      <td>0.667692</td>\n",
       "      <td>0.812693</td>\n",
       "      <td>2178.0</td>\n",
       "      <td>325.0</td>\n",
       "      <td>1853.0</td>\n",
       "      <td>0.149219</td>\n",
       "      <td>0.273186</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1.0</th>\n",
       "      <td>0.826601</td>\n",
       "      <td>0.760404</td>\n",
       "      <td>0.460123</td>\n",
       "      <td>0.397795</td>\n",
       "      <td>0.348837</td>\n",
       "      <td>0.675676</td>\n",
       "      <td>0.830483</td>\n",
       "      <td>1015.0</td>\n",
       "      <td>111.0</td>\n",
       "      <td>904.0</td>\n",
       "      <td>0.109360</td>\n",
       "      <td>0.211823</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Maximum difference</th>\n",
       "      <td>0.049741</td>\n",
       "      <td>0.028555</td>\n",
       "      <td>0.011616</td>\n",
       "      <td>0.027015</td>\n",
       "      <td>0.015869</td>\n",
       "      <td>0.007983</td>\n",
       "      <td>0.017790</td>\n",
       "      <td>1163.0</td>\n",
       "      <td>214.0</td>\n",
       "      <td>949.0</td>\n",
       "      <td>0.039860</td>\n",
       "      <td>0.061364</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                             Accuracy  Balanced Accuracy  F1 score       MCC  \\\n",
       "         Groups                                                                \n",
       "original Overall             0.839023           0.720454  0.486000  0.396986   \n",
       "         0.0                 0.816804           0.708386  0.474308  0.371757   \n",
       "         1.0                 0.886700           0.746726  0.522822  0.460837   \n",
       "         Maximum difference  0.069895           0.038341  0.048513  0.089081   \n",
       "updated  Overall             0.792671           0.740920  0.468700  0.380241   \n",
       "         0.0                 0.776860           0.731849  0.471739  0.370780   \n",
       "         1.0                 0.826601           0.760404  0.460123  0.397795   \n",
       "         Maximum difference  0.049741           0.028555  0.011616  0.027015   \n",
       "\n",
       "                             Precision    Recall   ROC AUC  \\\n",
       "         Groups                                              \n",
       "original Overall              0.430851  0.557339  0.824450   \n",
       "         0.0                  0.414747  0.553846  0.813847   \n",
       "         1.0                  0.484615  0.567568  0.840469   \n",
       "         Maximum difference   0.069869  0.013721  0.026622   \n",
       "updated  Overall              0.360494  0.669725  0.819747   \n",
       "         0.0                  0.364706  0.667692  0.812693   \n",
       "         1.0                  0.348837  0.675676  0.830483   \n",
       "         Maximum difference   0.015869  0.007983  0.017790   \n",
       "\n",
       "                             Number of Datapoints  Positive Count  \\\n",
       "         Groups                                                     \n",
       "original Overall                           3193.0           436.0   \n",
       "         0.0                               2178.0           325.0   \n",
       "         1.0                               1015.0           111.0   \n",
       "         Maximum difference                1163.0           214.0   \n",
       "updated  Overall                           3193.0           436.0   \n",
       "         0.0                               2178.0           325.0   \n",
       "         1.0                               1015.0           111.0   \n",
       "         Maximum difference                1163.0           214.0   \n",
       "\n",
       "                             Negative Count  Positive Label Rate  \\\n",
       "         Groups                                                    \n",
       "original Overall                     2757.0             0.136549   \n",
       "         0.0                         1853.0             0.149219   \n",
       "         1.0                          904.0             0.109360   \n",
       "         Maximum difference           949.0             0.039860   \n",
       "updated  Overall                     2757.0             0.136549   \n",
       "         0.0                         1853.0             0.149219   \n",
       "         1.0                          904.0             0.109360   \n",
       "         Maximum difference           949.0             0.039860   \n",
       "\n",
       "                             Positive Prediction Rate  \n",
       "         Groups                                        \n",
       "original Overall                             0.176636  \n",
       "         0.0                                 0.199265  \n",
       "         1.0                                 0.128079  \n",
       "         Maximum difference                  0.071187  \n",
       "updated  Overall                             0.253680  \n",
       "         0.0                                 0.273186  \n",
       "         1.0                                 0.211823  \n",
       "         Maximum difference                  0.061364  "
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fpred_fitz.evaluate_groups(test_dict_fitz) #looking at the group breakdown on test data. "
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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": 4
}
