{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b94de045",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-04-30T05:37:46.231668Z",
     "iopub.status.busy": "2023-04-30T05:37:46.230933Z",
     "iopub.status.idle": "2023-04-30T05:37:47.270515Z",
     "shell.execute_reply": "2023-04-30T05:37:47.269692Z"
    },
    "papermill": {
     "duration": 1.054404,
     "end_time": "2023-04-30T05:37:47.274123",
     "exception": false,
     "start_time": "2023-04-30T05:37:46.219719",
     "status": "completed"
    },
    "tags": []
   },
   "outputs": [],
   "source": [
    "from copy import deepcopy\n",
    "from functools import partial\n",
    "import os\n",
    "import pickle\n",
    "\n",
    "import folktables\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import sklearn.model_selection, sklearn.linear_model, sklearn.calibration\n",
    "from tqdm.contrib.concurrent import process_map\n",
    "\n",
    "import postprocess\n",
    "import utils\n",
    "\n",
    "split_ratio_for_test = 0.3\n",
    "split_ratio_for_postprocessing = 0.1  # among all training data\n",
    "\n",
    "# These seeds control the randomness for the post-process/test split and in\n",
    "# postprocessing.  It does not affect pre-training data nor the randomness in\n",
    "# pre-training, i.e., we assume the pre-trained predictor to be fixed.  Results\n",
    "# will be aggregated over the seeds.\n",
    "seeds = range(33, 43)\n",
    "\n",
    "# This seed controls the randomness during pre-training (fixed)\n",
    "seed_for_pretraining = 33\n",
    "\n",
    "max_workers = 48"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "94153935",
   "metadata": {
    "papermill": {
     "duration": 0.00718,
     "end_time": "2023-04-30T05:37:47.290196",
     "exception": false,
     "start_time": "2023-04-30T05:37:47.283016",
     "status": "completed"
    },
    "tags": []
   },
   "source": [
    "## Load ACS Income dataset via `folktables` package"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "651ec675",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-04-30T05:37:47.302174Z",
     "iopub.status.busy": "2023-04-30T05:37:47.301572Z",
     "iopub.status.idle": "2023-04-30T05:37:50.745900Z",
     "shell.execute_reply": "2023-04-30T05:37:50.744714Z"
    },
    "papermill": {
     "duration": 3.454187,
     "end_time": "2023-04-30T05:37:50.749676",
     "exception": false,
     "start_time": "2023-04-30T05:37:47.295489",
     "status": "completed"
    },
    "tags": []
   },
   "outputs": [],
   "source": [
    "if not os.path.exists(f\"data/acsincome/raw_dataset.pkl\"):\n",
    "  data_source = folktables.ACSDataSource(survey_year='2018',\n",
    "                                         horizon='1-Year',\n",
    "                                         survey='person')\n",
    "  raw_dataset = data_source.get_data(download=True)\n",
    "  with open(f\"data/acsincome/raw_dataset.pkl\", \"wb\") as f:\n",
    "    pickle.dump(raw_dataset, f)\n",
    "else:\n",
    "  with open(f\"data/acsincome/raw_dataset.pkl\", \"rb\") as f:\n",
    "    raw_dataset = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0ecd50a5",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-04-30T05:37:50.768233Z",
     "iopub.status.busy": "2023-04-30T05:37:50.767920Z",
     "iopub.status.idle": "2023-04-30T05:37:50.790823Z",
     "shell.execute_reply": "2023-04-30T05:37:50.789940Z"
    },
    "papermill": {
     "duration": 0.03493,
     "end_time": "2023-04-30T05:37:50.793571",
     "exception": false,
     "start_time": "2023-04-30T05:37:50.758641",
     "status": "completed"
    },
    "tags": []
   },
   "outputs": [],
   "source": [
    "ACSIncome_categories = {\n",
    "    \"COW\": {\n",
    "        1.0: (\"Employee of a private for-profit company or\"\n",
    "              \"business, or of an individual, for wages,\"\n",
    "              \"salary, or commissions\"),\n",
    "        2.0: (\"Employee of a private not-for-profit, tax-exempt,\"\n",
    "              \"or charitable organization\"),\n",
    "        3.0:\n",
    "            \"Local government employee (city, county, etc.)\",\n",
    "        4.0:\n",
    "            \"State government employee\",\n",
    "        5.0:\n",
    "            \"Federal government employee\",\n",
    "        6.0: (\"Self-employed in own not incorporated business,\"\n",
    "              \"professional practice, or farm\"),\n",
    "        7.0: (\"Self-employed in own incorporated business,\"\n",
    "              \"professional practice or farm\"),\n",
    "        8.0:\n",
    "            \"Working without pay in family business or farm\",\n",
    "        9.0:\n",
    "            \"Unemployed and last worked 5 years ago or earlier or never worked\",\n",
    "    },\n",
    "    \"SCHL\": {\n",
    "        1.0: \"No schooling completed\",\n",
    "        2.0: \"Nursery school, preschool\",\n",
    "        3.0: \"Kindergarten\",\n",
    "        4.0: \"Grade 1\",\n",
    "        5.0: \"Grade 2\",\n",
    "        6.0: \"Grade 3\",\n",
    "        7.0: \"Grade 4\",\n",
    "        8.0: \"Grade 5\",\n",
    "        9.0: \"Grade 6\",\n",
    "        10.0: \"Grade 7\",\n",
    "        11.0: \"Grade 8\",\n",
    "        12.0: \"Grade 9\",\n",
    "        13.0: \"Grade 10\",\n",
    "        14.0: \"Grade 11\",\n",
    "        15.0: \"12th grade - no diploma\",\n",
    "        16.0: \"Regular high school diploma\",\n",
    "        17.0: \"GED or alternative credential\",\n",
    "        18.0: \"Some college, but less than 1 year\",\n",
    "        19.0: \"1 or more years of college credit, no degree\",\n",
    "        20.0: \"Associate's degree\",\n",
    "        21.0: \"Bachelor's degree\",\n",
    "        22.0: \"Master's degree\",\n",
    "        23.0: \"Professional degree beyond a bachelor's degree\",\n",
    "        24.0: \"Doctorate degree\",\n",
    "    },\n",
    "    \"MAR\": {\n",
    "        1.0: \"Married\",\n",
    "        2.0: \"Widowed\",\n",
    "        3.0: \"Divorced\",\n",
    "        4.0: \"Separated\",\n",
    "        5.0: \"Never married or under 15 years old\",\n",
    "    },\n",
    "    \"SEX\": {\n",
    "        1.0: \"Male\",\n",
    "        2.0: \"Female\"\n",
    "    },\n",
    "    \"RAC1P\": {\n",
    "        1.0: \"White alone\",\n",
    "        2.0: \"Black or African American alone\",\n",
    "        3.0: \"American Indian alone\",\n",
    "        4.0: \"Alaska Native alone\",\n",
    "        5.0: (\"American Indian and Alaska Native tribes specified;\"\n",
    "              \"or American Indian or Alaska Native,\"\n",
    "              \"not specified and no other\"),\n",
    "        6.0: \"Asian alone\",\n",
    "        7.0: \"Native Hawaiian and Other Pacific Islander alone\",\n",
    "        8.0: \"Some Other Race alone\",\n",
    "        9.0: \"Two or More Races\",\n",
    "    },\n",
    "}\n",
    "\n",
    "\n",
    "def get_group_labels_and_print_statistics(sensitive_attribute='SEX',\n",
    "                                          n_classes=2):\n",
    "  target = 'PINCP'\n",
    "  features = [\n",
    "      'AGEP', 'COW', 'SCHL', 'MAR', 'OCCP', 'POBP', 'RELP', 'WKHP', 'SEX',\n",
    "      'RAC1P'\n",
    "  ]\n",
    "  df = folktables.adult_filter(raw_dataset)\n",
    "\n",
    "  if n_classes == 2:\n",
    "    label_names = [\"<=50K\", \">50K\"]\n",
    "    target_transform = lambda x: (x > 50000).astype(int)\n",
    "\n",
    "  else:\n",
    "    # Compute empirical CDF of PINCP\n",
    "    x = np.sort(df[target])\n",
    "    y = np.arange(len(x)) / float(len(x))\n",
    "\n",
    "    # Partition into bins containing roughly the same number of samples\n",
    "    partitions = np.array([\n",
    "        x[np.argmax(y >= q)] for q in np.arange(1 / n_classes, 1, 1 / n_classes)\n",
    "    ] + [np.inf])\n",
    "\n",
    "    label_names = [f'[0, {partitions[0]})'] + [\n",
    "        f'[{partitions[i]}, {partitions[i+1]})'\n",
    "        for i in range(len(partitions) - 1)\n",
    "    ]\n",
    "    target_transform = lambda x: np.argmax(\n",
    "        np.array(x)[:, None] < partitions[None, :], axis=1)\n",
    "\n",
    "  categories = deepcopy(ACSIncome_categories)\n",
    "  if sensitive_attribute == 'RAC1P':\n",
    "    # Combine RAC1P categories 3, 4, 5, and 6, 7, and 8, 9 into new categories\n",
    "    # 10, 11, and 12 respectively, due to small sample size in some groups.\n",
    "    # This is also consistent with the UCI Adult dataset.\n",
    "    categories['RAC1P'][10.0] = \"American Indian or Alaska Native alone\"\n",
    "    categories['RAC1P'][\n",
    "        11.0] = \"Asian, Native Hawaiian or Other Pacific Islander alone\"\n",
    "    categories['RAC1P'][12.0] = \"Other\"\n",
    "    df['RAC1P'] = df['RAC1P'].replace([3.0, 4.0, 5.0], 10.0)\n",
    "    df['RAC1P'] = df['RAC1P'].replace([6.0, 7.0], 11.0)\n",
    "    df['RAC1P'] = df['RAC1P'].replace([8.0, 9.0], 12.0)\n",
    "\n",
    "  data, labels, groups = folktables.BasicProblem(\n",
    "      features=features,\n",
    "      target=target,\n",
    "      target_transform=target_transform,\n",
    "      group=sensitive_attribute,\n",
    "      postprocess=lambda x: np.nan_to_num(x, -1),\n",
    "  ).df_to_pandas(df, categories=categories, dummies=True)\n",
    "\n",
    "  labels = labels.values.squeeze()\n",
    "  groups = groups.values.squeeze()\n",
    "\n",
    "  group_names, groups = np.unique(groups, return_inverse=True)\n",
    "  group_names = [categories[sensitive_attribute][n] for n in group_names]\n",
    "\n",
    "  df = pd.DataFrame(np.stack(\n",
    "      [np.array(group_names)[groups],\n",
    "       np.array(label_names)[labels]], axis=1),\n",
    "                    columns=[\"Group\", \"Target\"])\n",
    "  df_grouped = df.groupby([\"Target\", \"Group\"]).size().unstack()\n",
    "  counts = df_grouped.sum(axis=0)\n",
    "  print(\"Dataset statistics:\")\n",
    "  display(df_grouped / counts)\n",
    "  display(pd.DataFrame(counts, columns=[\"Count\"]).T)\n",
    "\n",
    "  print(\"Perfect results if dataset equals population:\")\n",
    "  display(\n",
    "      pd.DataFrame([{\n",
    "          \"alpha\":\n",
    "              np.inf,\n",
    "          \"error_rate\":\n",
    "              0.0,\n",
    "          \"delta_dp\":\n",
    "              utils.delta_dp(labels, groups),\n",
    "          \"delta_dp_rms\":\n",
    "              utils.delta_dp(\n",
    "                  labels,\n",
    "                  groups,\n",
    "                  ord=2,\n",
    "              ) / np.sqrt(n_classes)\n",
    "      }, {\n",
    "          \"alpha\":\n",
    "              0.0,\n",
    "          \"error_rate\":\n",
    "              postprocess.PostProcessorDP().fit(\n",
    "                  scores=np.concatenate(\n",
    "                      [np.eye(n_classes) for _ in range(len(group_names))],\n",
    "                      axis=0),\n",
    "                  groups=np.repeat(np.arange(len(group_names)),\n",
    "                                   len(label_names)),\n",
    "                  r=np.nan_to_num(\n",
    "                      (df_grouped.to_numpy() / counts.to_numpy())).T.flatten(),\n",
    "              ).score_,\n",
    "          \"delta_dp\":\n",
    "              0.0,\n",
    "          \"delta_dp_rms\":\n",
    "              0.0\n",
    "      }]).groupby('alpha').agg('mean').sort_index(ascending=False))\n",
    "\n",
    "  return data, labels, label_names, groups, group_names"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "61011ce5",
   "metadata": {
    "papermill": {
     "duration": 0.00679,
     "end_time": "2023-04-30T05:37:50.808521",
     "exception": false,
     "start_time": "2023-04-30T05:37:50.801731",
     "status": "completed"
    },
    "tags": []
   },
   "source": [
    "## “Sex” as sensitive attribute, and 2 categories of “Income” as target classes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1c8d451f",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-04-30T05:37:50.820636Z",
     "iopub.status.busy": "2023-04-30T05:37:50.820054Z",
     "iopub.status.idle": "2023-04-30T05:39:19.762687Z",
     "shell.execute_reply": "2023-04-30T05:39:19.761293Z"
    },
    "papermill": {
     "duration": 88.950758,
     "end_time": "2023-04-30T05:39:19.764675",
     "exception": false,
     "start_time": "2023-04-30T05:37:50.813917",
     "status": "completed"
    },
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset statistics:\n"
     ]
    },
    {
     "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>Group</th>\n",
       "      <th>Female</th>\n",
       "      <th>Male</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Target</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>&lt;=50K</th>\n",
       "      <td>0.710121</td>\n",
       "      <td>0.558329</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>&gt;50K</th>\n",
       "      <td>0.289879</td>\n",
       "      <td>0.441671</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Group     Female      Male\n",
       "Target                    \n",
       "<=50K   0.710121  0.558329\n",
       ">50K    0.289879  0.441671"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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>Group</th>\n",
       "      <th>Female</th>\n",
       "      <th>Male</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Count</th>\n",
       "      <td>797765</td>\n",
       "      <td>866735</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Group  Female    Male\n",
       "Count  797765  866735"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Perfect results if dataset equals population:\n"
     ]
    },
    {
     "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>error_rate</th>\n",
       "      <th>delta_dp</th>\n",
       "      <th>delta_dp_rms</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>alpha</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>inf</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.151793</td>\n",
       "      <td>0.151793</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0</th>\n",
       "      <td>0.075896</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       error_rate  delta_dp  delta_dp_rms\n",
       "alpha                                    \n",
       "inf      0.000000  0.151793      0.151793\n",
       "0.0      0.075896  0.000000      0.000000"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "(data, labels, label_names, groups,\n",
    " group_names) = get_group_labels_and_print_statistics(\n",
    "     sensitive_attribute='SEX', n_classes=2)\n",
    "\n",
    "data = data.values\n",
    "n_classes = len(label_names)\n",
    "n_groups = len(group_names)\n",
    "\n",
    "(data_, train_data_pre, labels_, train_labels_pre, groups_,\n",
    " train_groups_pre) = sklearn.model_selection.train_test_split(\n",
    "     data,\n",
    "     labels,\n",
    "     groups,\n",
    "     test_size=(1 - split_ratio_for_test) *\n",
    "     (1 - split_ratio_for_postprocessing),\n",
    "     random_state=seed_for_pretraining,\n",
    " )\n",
    "\n",
    "n_samples = len(data)\n",
    "n_test = int(n_samples * split_ratio_for_test)\n",
    "n_post = n_samples - len(train_data_pre) - n_test\n",
    "\n",
    "# Train logistic regression models on the pre-training data on each group\n",
    "# separately\n",
    "predictors = []\n",
    "for a in range(n_groups):\n",
    "  predictor = sklearn.linear_model.LogisticRegression(\n",
    "      random_state=seed_for_pretraining, max_iter=10000)\n",
    "  predictor.fit(train_data_pre[train_groups_pre == a],\n",
    "                train_labels_pre[train_groups_pre == a])\n",
    "  predictors.append(predictor)\n",
    "\n",
    "# Get predicted probabilities (uncalibrated)\n",
    "probas_ = np.empty((len(data_), n_classes))\n",
    "for a, predictor in enumerate(predictors):\n",
    "  probas_[groups_ == a] = predictor.predict_proba(data_[groups_ == a])\n",
    "\n",
    "# Train calibrated logistic regression models on the pre-training data on each\n",
    "# group separately\n",
    "predictors_cal = []\n",
    "for a in range(n_groups):\n",
    "  predictor_cal = sklearn.calibration.CalibratedClassifierCV(\n",
    "      sklearn.linear_model.LogisticRegression(random_state=seed_for_pretraining,\n",
    "                                              max_iter=10000),\n",
    "      cv=5,\n",
    "      method='isotonic',\n",
    "  )\n",
    "  predictor_cal.fit(train_data_pre[train_groups_pre == a],\n",
    "                    train_labels_pre[train_groups_pre == a])\n",
    "  predictors_cal.append(predictor_cal)\n",
    "\n",
    "# Get predicted probabilities (calibrated)\n",
    "probas_cal_ = np.empty((len(data_), n_classes))\n",
    "for a, predictor_cal in enumerate(predictors_cal):\n",
    "  probas_cal_[groups_ == a] = predictor_cal.predict_proba(data_[groups_ == a])"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "55d33c6b",
   "metadata": {
    "papermill": {
     "duration": 0.003772,
     "end_time": "2023-04-30T05:39:19.772823",
     "exception": false,
     "start_time": "2023-04-30T05:39:19.769051",
     "status": "completed"
    },
    "tags": []
   },
   "source": [
    "### TPR parity post-processing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "1ab923ca",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-04-30T05:39:19.782495Z",
     "iopub.status.busy": "2023-04-30T05:39:19.782076Z",
     "iopub.status.idle": "2023-04-30T05:52:08.294334Z",
     "shell.execute_reply": "2023-04-30T05:52:08.292654Z"
    },
    "papermill": {
     "duration": 768.530967,
     "end_time": "2023-04-30T05:52:08.307535",
     "exception": false,
     "start_time": "2023-04-30T05:39:19.776568",
     "status": "completed"
    },
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "91379b6739b44262bc334d2742177d0a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/130 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 350x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"2\" halign=\"left\">error_rate</th>\n",
       "      <th colspan=\"2\" halign=\"left\">delta_tpr</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>alpha</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>inf</th>\n",
       "      <td>0.221952</td>\n",
       "      <td>0.000184</td>\n",
       "      <td>0.164061</td>\n",
       "      <td>0.001178</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.1400</th>\n",
       "      <td>0.222068</td>\n",
       "      <td>0.000220</td>\n",
       "      <td>0.136160</td>\n",
       "      <td>0.004882</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.1200</th>\n",
       "      <td>0.222232</td>\n",
       "      <td>0.000230</td>\n",
       "      <td>0.115866</td>\n",
       "      <td>0.004418</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.1000</th>\n",
       "      <td>0.222546</td>\n",
       "      <td>0.000262</td>\n",
       "      <td>0.096160</td>\n",
       "      <td>0.004381</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0800</th>\n",
       "      <td>0.222988</td>\n",
       "      <td>0.000264</td>\n",
       "      <td>0.075491</td>\n",
       "      <td>0.004287</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0500</th>\n",
       "      <td>0.223788</td>\n",
       "      <td>0.000268</td>\n",
       "      <td>0.045001</td>\n",
       "      <td>0.004186</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0200</th>\n",
       "      <td>0.224985</td>\n",
       "      <td>0.000281</td>\n",
       "      <td>0.017234</td>\n",
       "      <td>0.002223</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0100</th>\n",
       "      <td>0.225652</td>\n",
       "      <td>0.000304</td>\n",
       "      <td>0.010245</td>\n",
       "      <td>0.001267</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0080</th>\n",
       "      <td>0.225753</td>\n",
       "      <td>0.000325</td>\n",
       "      <td>0.008366</td>\n",
       "      <td>0.001232</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0050</th>\n",
       "      <td>0.225913</td>\n",
       "      <td>0.000331</td>\n",
       "      <td>0.006754</td>\n",
       "      <td>0.001455</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0020</th>\n",
       "      <td>0.226666</td>\n",
       "      <td>0.000463</td>\n",
       "      <td>0.007126</td>\n",
       "      <td>0.003173</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0010</th>\n",
       "      <td>0.227139</td>\n",
       "      <td>0.000457</td>\n",
       "      <td>0.006117</td>\n",
       "      <td>0.003073</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>0.227568</td>\n",
       "      <td>0.000451</td>\n",
       "      <td>0.005232</td>\n",
       "      <td>0.003056</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       error_rate           delta_tpr          \n",
       "             mean       std      mean       std\n",
       "alpha                                          \n",
       "inf      0.221952  0.000184  0.164061  0.001178\n",
       "0.1400   0.222068  0.000220  0.136160  0.004882\n",
       "0.1200   0.222232  0.000230  0.115866  0.004418\n",
       "0.1000   0.222546  0.000262  0.096160  0.004381\n",
       "0.0800   0.222988  0.000264  0.075491  0.004287\n",
       "0.0500   0.223788  0.000268  0.045001  0.004186\n",
       "0.0200   0.224985  0.000281  0.017234  0.002223\n",
       "0.0100   0.225652  0.000304  0.010245  0.001267\n",
       "0.0080   0.225753  0.000325  0.008366  0.001232\n",
       "0.0050   0.225913  0.000331  0.006754  0.001455\n",
       "0.0020   0.226666  0.000463  0.007126  0.003173\n",
       "0.0010   0.227139  0.000457  0.006117  0.003073\n",
       "0.0001   0.227568  0.000451  0.005232  0.003056"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "alphas = [\n",
    "    np.inf, 0.14, 0.12, 0.1, 0.08, 0.05, 0.02, 0.01, 0.008, 0.005, 0.002, 0.001,\n",
    "    0.0001\n",
    "]\n",
    "\n",
    "return_vals = process_map(\n",
    "    partial(\n",
    "        utils.postprocess,\n",
    "        postprocessor_factory=postprocess.PostProcessorTPR,\n",
    "        evaluate_fn=partial(utils.evaluate,\n",
    "                            n_groups=n_groups,\n",
    "                            n_classes=n_classes,\n",
    "                            metrics=['delta_tpr']),\n",
    "        probas=probas_,\n",
    "        labels=labels_,\n",
    "        groups=groups_,\n",
    "        n_post=n_post,\n",
    "        n_test=n_test,\n",
    "    ),\n",
    "    [(alpha, seed) for alpha in alphas for seed in seeds],\n",
    "    max_workers=max_workers,\n",
    ")\n",
    "results = [{\n",
    "    'alpha': alpha,\n",
    "    **result\n",
    "} for alpha, _, result, _ in return_vals if result is not None]\n",
    "\n",
    "(fig, ax), df = utils.plot_results(results, 'delta_tpr')\n",
    "ax.set_xlabel(\"$\\\\Delta_{\\\\mathrm{TPR}}$\")\n",
    "ax.set_title(\"ACSIncome (gender, 2 classes)\")\n",
    "plt.show()\n",
    "display(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f67fb7e5",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-04-30T05:52:08.322864Z",
     "iopub.status.busy": "2023-04-30T05:52:08.322580Z",
     "iopub.status.idle": "2023-04-30T06:08:18.834711Z",
     "shell.execute_reply": "2023-04-30T06:08:18.832693Z"
    },
    "papermill": {
     "duration": 970.523463,
     "end_time": "2023-04-30T06:08:18.838522",
     "exception": false,
     "start_time": "2023-04-30T05:52:08.315059",
     "status": "completed"
    },
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "489150bf99604dbdaca7c5eb81db1bcd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/130 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "With calibration:\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 350x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"2\" halign=\"left\">error_rate</th>\n",
       "      <th colspan=\"2\" halign=\"left\">delta_tpr</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>alpha</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>inf</th>\n",
       "      <td>0.221480</td>\n",
       "      <td>0.000204</td>\n",
       "      <td>0.150372</td>\n",
       "      <td>0.001327</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.1400</th>\n",
       "      <td>0.221750</td>\n",
       "      <td>0.000193</td>\n",
       "      <td>0.134028</td>\n",
       "      <td>0.004534</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.1200</th>\n",
       "      <td>0.221979</td>\n",
       "      <td>0.000223</td>\n",
       "      <td>0.114415</td>\n",
       "      <td>0.004554</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.1000</th>\n",
       "      <td>0.222265</td>\n",
       "      <td>0.000226</td>\n",
       "      <td>0.094309</td>\n",
       "      <td>0.004382</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0800</th>\n",
       "      <td>0.222779</td>\n",
       "      <td>0.000257</td>\n",
       "      <td>0.073919</td>\n",
       "      <td>0.004031</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0500</th>\n",
       "      <td>0.223450</td>\n",
       "      <td>0.000255</td>\n",
       "      <td>0.044301</td>\n",
       "      <td>0.004129</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0200</th>\n",
       "      <td>0.224345</td>\n",
       "      <td>0.000294</td>\n",
       "      <td>0.020306</td>\n",
       "      <td>0.001858</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0100</th>\n",
       "      <td>0.225064</td>\n",
       "      <td>0.000319</td>\n",
       "      <td>0.011552</td>\n",
       "      <td>0.001471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0080</th>\n",
       "      <td>0.225232</td>\n",
       "      <td>0.000321</td>\n",
       "      <td>0.009868</td>\n",
       "      <td>0.001288</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0050</th>\n",
       "      <td>0.225531</td>\n",
       "      <td>0.000311</td>\n",
       "      <td>0.008721</td>\n",
       "      <td>0.002416</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0020</th>\n",
       "      <td>0.226457</td>\n",
       "      <td>0.000453</td>\n",
       "      <td>0.007652</td>\n",
       "      <td>0.002898</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0010</th>\n",
       "      <td>0.226938</td>\n",
       "      <td>0.000478</td>\n",
       "      <td>0.006599</td>\n",
       "      <td>0.002853</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>0.227381</td>\n",
       "      <td>0.000456</td>\n",
       "      <td>0.005617</td>\n",
       "      <td>0.002697</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       error_rate           delta_tpr          \n",
       "             mean       std      mean       std\n",
       "alpha                                          \n",
       "inf      0.221480  0.000204  0.150372  0.001327\n",
       "0.1400   0.221750  0.000193  0.134028  0.004534\n",
       "0.1200   0.221979  0.000223  0.114415  0.004554\n",
       "0.1000   0.222265  0.000226  0.094309  0.004382\n",
       "0.0800   0.222779  0.000257  0.073919  0.004031\n",
       "0.0500   0.223450  0.000255  0.044301  0.004129\n",
       "0.0200   0.224345  0.000294  0.020306  0.001858\n",
       "0.0100   0.225064  0.000319  0.011552  0.001471\n",
       "0.0080   0.225232  0.000321  0.009868  0.001288\n",
       "0.0050   0.225531  0.000311  0.008721  0.002416\n",
       "0.0020   0.226457  0.000453  0.007652  0.002898\n",
       "0.0010   0.226938  0.000478  0.006599  0.002853\n",
       "0.0001   0.227381  0.000456  0.005617  0.002697"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "alphas = [\n",
    "    np.inf, 0.14, 0.12, 0.1, 0.08, 0.05, 0.02, 0.01, 0.008, 0.005, 0.002, 0.001,\n",
    "    0.0001\n",
    "]\n",
    "\n",
    "return_vals = process_map(\n",
    "    partial(\n",
    "        utils.postprocess,\n",
    "        postprocessor_factory=postprocess.PostProcessorTPR,\n",
    "        evaluate_fn=partial(utils.evaluate,\n",
    "                            n_groups=n_groups,\n",
    "                            n_classes=n_classes,\n",
    "                            metrics=['delta_tpr']),\n",
    "        probas=probas_cal_,\n",
    "        labels=labels_,\n",
    "        groups=groups_,\n",
    "        n_post=n_post,\n",
    "        n_test=n_test,\n",
    "    ),\n",
    "    [(alpha, seed) for alpha in alphas for seed in seeds],\n",
    "    max_workers=max_workers,\n",
    ")\n",
    "results = [{\n",
    "    'alpha': alpha,\n",
    "    **result\n",
    "} for alpha, _, result, _ in return_vals if result is not None]\n",
    "\n",
    "(fig, ax), df = utils.plot_results(results, 'delta_tpr')\n",
    "ax.set_xlabel(\"$\\\\Delta_{\\\\mathrm{TPR}}$\")\n",
    "ax.set_title(\"ACSIncome (gender, 2 classes)\")\n",
    "print(\"With calibration:\")\n",
    "plt.show()\n",
    "display(df)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "055c37b1",
   "metadata": {
    "papermill": {
     "duration": 0.008904,
     "end_time": "2023-04-30T06:08:18.860598",
     "exception": false,
     "start_time": "2023-04-30T06:08:18.851694",
     "status": "completed"
    },
    "tags": []
   },
   "source": [
    "## “Race” as sensitive attribute, and 5 categories of “Income” as target classes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1dff6068",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-04-30T06:08:18.875459Z",
     "iopub.status.busy": "2023-04-30T06:08:18.874945Z",
     "iopub.status.idle": "2023-04-30T07:57:36.953832Z",
     "shell.execute_reply": "2023-04-30T07:57:36.952021Z"
    },
    "papermill": {
     "duration": 6558.088004,
     "end_time": "2023-04-30T07:57:36.955532",
     "exception": false,
     "start_time": "2023-04-30T06:08:18.867528",
     "status": "completed"
    },
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset statistics:\n"
     ]
    },
    {
     "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>Group</th>\n",
       "      <th>American Indian or Alaska Native alone</th>\n",
       "      <th>Asian, Native Hawaiian or Other Pacific Islander alone</th>\n",
       "      <th>Black or African American alone</th>\n",
       "      <th>Other</th>\n",
       "      <th>White alone</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Target</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>[0, 15000.0)</th>\n",
       "      <td>0.260657</td>\n",
       "      <td>0.188757</td>\n",
       "      <td>0.246298</td>\n",
       "      <td>0.254518</td>\n",
       "      <td>0.179713</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>[15000.0, 30000.0)</th>\n",
       "      <td>0.255286</td>\n",
       "      <td>0.164627</td>\n",
       "      <td>0.242449</td>\n",
       "      <td>0.263917</td>\n",
       "      <td>0.178926</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>[30000.0, 48600.0)</th>\n",
       "      <td>0.245150</td>\n",
       "      <td>0.173386</td>\n",
       "      <td>0.236425</td>\n",
       "      <td>0.229817</td>\n",
       "      <td>0.218850</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>[48600.0, 78030.0)</th>\n",
       "      <td>0.154125</td>\n",
       "      <td>0.178597</td>\n",
       "      <td>0.164854</td>\n",
       "      <td>0.149180</td>\n",
       "      <td>0.210315</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>[78030.0, inf)</th>\n",
       "      <td>0.084782</td>\n",
       "      <td>0.294632</td>\n",
       "      <td>0.109973</td>\n",
       "      <td>0.102568</td>\n",
       "      <td>0.212197</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Group               American Indian or Alaska Native alone  \\\n",
       "Target                                                       \n",
       "[0, 15000.0)                                      0.260657   \n",
       "[15000.0, 30000.0)                                0.255286   \n",
       "[30000.0, 48600.0)                                0.245150   \n",
       "[48600.0, 78030.0)                                0.154125   \n",
       "[78030.0, inf)                                    0.084782   \n",
       "\n",
       "Group               Asian, Native Hawaiian or Other Pacific Islander alone  \\\n",
       "Target                                                                       \n",
       "[0, 15000.0)                                                 0.188757        \n",
       "[15000.0, 30000.0)                                           0.164627        \n",
       "[30000.0, 48600.0)                                           0.173386        \n",
       "[48600.0, 78030.0)                                           0.178597        \n",
       "[78030.0, inf)                                               0.294632        \n",
       "\n",
       "Group               Black or African American alone     Other  White alone  \n",
       "Target                                                                      \n",
       "[0, 15000.0)                               0.246298  0.254518     0.179713  \n",
       "[15000.0, 30000.0)                         0.242449  0.263917     0.178926  \n",
       "[30000.0, 48600.0)                         0.236425  0.229817     0.218850  \n",
       "[48600.0, 78030.0)                         0.164854  0.149180     0.210315  \n",
       "[78030.0, inf)                             0.109973  0.102568     0.212197  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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>Group</th>\n",
       "      <th>American Indian or Alaska Native alone</th>\n",
       "      <th>Asian, Native Hawaiian or Other Pacific Islander alone</th>\n",
       "      <th>Black or African American alone</th>\n",
       "      <th>Other</th>\n",
       "      <th>White alone</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Count</th>\n",
       "      <td>14897</td>\n",
       "      <td>99212</td>\n",
       "      <td>147573</td>\n",
       "      <td>104692</td>\n",
       "      <td>1298126</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Group  American Indian or Alaska Native alone  \\\n",
       "Count                                   14897   \n",
       "\n",
       "Group  Asian, Native Hawaiian or Other Pacific Islander alone  \\\n",
       "Count                                              99212        \n",
       "\n",
       "Group  Black or African American alone   Other  White alone  \n",
       "Count                           147573  104692      1298126  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Perfect results if dataset equals population:\n"
     ]
    },
    {
     "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>error_rate</th>\n",
       "      <th>delta_dp</th>\n",
       "      <th>delta_dp_rms</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>alpha</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>inf</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.20985</td>\n",
       "      <td>0.112405</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0</th>\n",
       "      <td>0.082339</td>\n",
       "      <td>0.00000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       error_rate  delta_dp  delta_dp_rms\n",
       "alpha                                    \n",
       "inf      0.000000   0.20985      0.112405\n",
       "0.0      0.082339   0.00000      0.000000"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rxian/anaconda3/envs/fair/lib/python3.10/site-packages/sklearn/linear_model/_logistic.py:458: ConvergenceWarning: lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "  n_iter_i = _check_optimize_result(\n"
     ]
    }
   ],
   "source": [
    "(data, labels, label_names, groups,\n",
    " group_names) = get_group_labels_and_print_statistics(\n",
    "     sensitive_attribute='RAC1P', n_classes=5)\n",
    "\n",
    "data = data.values\n",
    "n_classes = len(label_names)\n",
    "n_groups = len(group_names)\n",
    "\n",
    "(data_, train_data_pre, labels_, train_labels_pre, groups_,\n",
    " train_groups_pre) = sklearn.model_selection.train_test_split(\n",
    "     data,\n",
    "     labels,\n",
    "     groups,\n",
    "     test_size=(1 - split_ratio_for_test) *\n",
    "     (1 - split_ratio_for_postprocessing),\n",
    "     random_state=seed_for_pretraining,\n",
    " )\n",
    "\n",
    "n_samples = len(data)\n",
    "n_test = int(n_samples * split_ratio_for_test)\n",
    "n_post = n_samples - len(train_data_pre) - n_test\n",
    "\n",
    "# Train logistic regression models on the pre-training data on each group\n",
    "# separately\n",
    "predictors = []\n",
    "for a in range(n_groups):\n",
    "  predictor = sklearn.linear_model.LogisticRegression(\n",
    "      random_state=seed_for_pretraining, max_iter=10000)\n",
    "  predictor.fit(train_data_pre[train_groups_pre == a],\n",
    "                train_labels_pre[train_groups_pre == a])\n",
    "  predictors.append(predictor)\n",
    "\n",
    "# Get predicted probabilities (uncalibrated)\n",
    "probas_ = np.empty((len(data_), n_classes))\n",
    "for a, predictor in enumerate(predictors):\n",
    "  probas_[groups_ == a] = predictor.predict_proba(data_[groups_ == a])\n",
    "\n",
    "# Train calibrated logistic regression models on the pre-training data on each\n",
    "# group separately\n",
    "predictors_cal = []\n",
    "for a in range(n_groups):\n",
    "  predictor_cal = sklearn.calibration.CalibratedClassifierCV(\n",
    "      sklearn.linear_model.LogisticRegression(random_state=seed_for_pretraining,\n",
    "                                              max_iter=10000),\n",
    "      cv=5,\n",
    "      method='isotonic',\n",
    "  )\n",
    "  predictor_cal.fit(train_data_pre[train_groups_pre == a],\n",
    "                    train_labels_pre[train_groups_pre == a])\n",
    "  predictors_cal.append(predictor_cal)\n",
    "\n",
    "# Get predicted probabilities (calibrated)\n",
    "probas_cal_ = np.empty((len(data_), n_classes))\n",
    "for a, predictor_cal in enumerate(predictors_cal):\n",
    "  probas_cal_[groups_ == a] = predictor_cal.predict_proba(data_[groups_ == a])"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "96b324a1",
   "metadata": {
    "papermill": {
     "duration": 0.008443,
     "end_time": "2023-04-30T07:57:36.975149",
     "exception": false,
     "start_time": "2023-04-30T07:57:36.966706",
     "status": "completed"
    },
    "tags": []
   },
   "source": [
    "### TPR parity post-processing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2d1158fd",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-04-30T07:57:36.994512Z",
     "iopub.status.busy": "2023-04-30T07:57:36.993786Z",
     "iopub.status.idle": "2023-05-01T00:20:04.344994Z",
     "shell.execute_reply": "2023-05-01T00:20:04.340431Z"
    },
    "papermill": {
     "duration": 58947.380779,
     "end_time": "2023-05-01T00:20:04.363668",
     "exception": false,
     "start_time": "2023-04-30T07:57:36.982889",
     "status": "completed"
    },
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "abe92629ec3e444fbbc2411ea458d96e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/210 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 350x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"2\" halign=\"left\">error_rate</th>\n",
       "      <th colspan=\"2\" halign=\"left\">delta_tpr</th>\n",
       "      <th colspan=\"2\" halign=\"left\">delta_tpr_rms</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>alpha</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>inf</th>\n",
       "      <td>0.547000</td>\n",
       "      <td>0.000354</td>\n",
       "      <td>0.618981</td>\n",
       "      <td>0.009449</td>\n",
       "      <td>0.291840</td>\n",
       "      <td>0.004472</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.6000</th>\n",
       "      <td>0.546998</td>\n",
       "      <td>0.000353</td>\n",
       "      <td>0.603530</td>\n",
       "      <td>0.024534</td>\n",
       "      <td>0.285083</td>\n",
       "      <td>0.010944</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.5500</th>\n",
       "      <td>0.546999</td>\n",
       "      <td>0.000355</td>\n",
       "      <td>0.564104</td>\n",
       "      <td>0.029287</td>\n",
       "      <td>0.268372</td>\n",
       "      <td>0.012565</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.5000</th>\n",
       "      <td>0.547008</td>\n",
       "      <td>0.000355</td>\n",
       "      <td>0.521702</td>\n",
       "      <td>0.024852</td>\n",
       "      <td>0.250533</td>\n",
       "      <td>0.010474</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.4500</th>\n",
       "      <td>0.547025</td>\n",
       "      <td>0.000354</td>\n",
       "      <td>0.481644</td>\n",
       "      <td>0.027194</td>\n",
       "      <td>0.233597</td>\n",
       "      <td>0.011841</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.4000</th>\n",
       "      <td>0.547097</td>\n",
       "      <td>0.000360</td>\n",
       "      <td>0.440086</td>\n",
       "      <td>0.031065</td>\n",
       "      <td>0.214709</td>\n",
       "      <td>0.014579</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.3500</th>\n",
       "      <td>0.547152</td>\n",
       "      <td>0.000357</td>\n",
       "      <td>0.384816</td>\n",
       "      <td>0.025135</td>\n",
       "      <td>0.192997</td>\n",
       "      <td>0.012579</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.3000</th>\n",
       "      <td>0.547225</td>\n",
       "      <td>0.000353</td>\n",
       "      <td>0.333242</td>\n",
       "      <td>0.023616</td>\n",
       "      <td>0.175186</td>\n",
       "      <td>0.012013</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.2500</th>\n",
       "      <td>0.547359</td>\n",
       "      <td>0.000336</td>\n",
       "      <td>0.280456</td>\n",
       "      <td>0.024356</td>\n",
       "      <td>0.167875</td>\n",
       "      <td>0.008667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.2000</th>\n",
       "      <td>0.547651</td>\n",
       "      <td>0.000345</td>\n",
       "      <td>0.236644</td>\n",
       "      <td>0.013398</td>\n",
       "      <td>0.147145</td>\n",
       "      <td>0.005800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.1500</th>\n",
       "      <td>0.547862</td>\n",
       "      <td>0.000352</td>\n",
       "      <td>0.195121</td>\n",
       "      <td>0.022682</td>\n",
       "      <td>0.119983</td>\n",
       "      <td>0.005970</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.1000</th>\n",
       "      <td>0.548375</td>\n",
       "      <td>0.000342</td>\n",
       "      <td>0.149797</td>\n",
       "      <td>0.021576</td>\n",
       "      <td>0.103443</td>\n",
       "      <td>0.007944</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0800</th>\n",
       "      <td>0.548778</td>\n",
       "      <td>0.000334</td>\n",
       "      <td>0.144516</td>\n",
       "      <td>0.017925</td>\n",
       "      <td>0.092730</td>\n",
       "      <td>0.008742</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0500</th>\n",
       "      <td>0.550031</td>\n",
       "      <td>0.000270</td>\n",
       "      <td>0.113189</td>\n",
       "      <td>0.017526</td>\n",
       "      <td>0.067318</td>\n",
       "      <td>0.006379</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0200</th>\n",
       "      <td>0.566475</td>\n",
       "      <td>0.003358</td>\n",
       "      <td>0.090068</td>\n",
       "      <td>0.022104</td>\n",
       "      <td>0.050370</td>\n",
       "      <td>0.009163</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0100</th>\n",
       "      <td>0.576500</td>\n",
       "      <td>0.003513</td>\n",
       "      <td>0.084955</td>\n",
       "      <td>0.022331</td>\n",
       "      <td>0.049965</td>\n",
       "      <td>0.009337</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0080</th>\n",
       "      <td>0.578582</td>\n",
       "      <td>0.003685</td>\n",
       "      <td>0.086211</td>\n",
       "      <td>0.023744</td>\n",
       "      <td>0.050168</td>\n",
       "      <td>0.010150</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0050</th>\n",
       "      <td>0.581698</td>\n",
       "      <td>0.003662</td>\n",
       "      <td>0.087180</td>\n",
       "      <td>0.026017</td>\n",
       "      <td>0.050012</td>\n",
       "      <td>0.011020</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0020</th>\n",
       "      <td>0.584923</td>\n",
       "      <td>0.003613</td>\n",
       "      <td>0.084751</td>\n",
       "      <td>0.026734</td>\n",
       "      <td>0.048323</td>\n",
       "      <td>0.011574</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0010</th>\n",
       "      <td>0.586062</td>\n",
       "      <td>0.003574</td>\n",
       "      <td>0.082972</td>\n",
       "      <td>0.026975</td>\n",
       "      <td>0.047409</td>\n",
       "      <td>0.011455</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>0.587090</td>\n",
       "      <td>0.003577</td>\n",
       "      <td>0.082200</td>\n",
       "      <td>0.025884</td>\n",
       "      <td>0.046747</td>\n",
       "      <td>0.010952</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       error_rate           delta_tpr           delta_tpr_rms          \n",
       "             mean       std      mean       std          mean       std\n",
       "alpha                                                                  \n",
       "inf      0.547000  0.000354  0.618981  0.009449      0.291840  0.004472\n",
       "0.6000   0.546998  0.000353  0.603530  0.024534      0.285083  0.010944\n",
       "0.5500   0.546999  0.000355  0.564104  0.029287      0.268372  0.012565\n",
       "0.5000   0.547008  0.000355  0.521702  0.024852      0.250533  0.010474\n",
       "0.4500   0.547025  0.000354  0.481644  0.027194      0.233597  0.011841\n",
       "0.4000   0.547097  0.000360  0.440086  0.031065      0.214709  0.014579\n",
       "0.3500   0.547152  0.000357  0.384816  0.025135      0.192997  0.012579\n",
       "0.3000   0.547225  0.000353  0.333242  0.023616      0.175186  0.012013\n",
       "0.2500   0.547359  0.000336  0.280456  0.024356      0.167875  0.008667\n",
       "0.2000   0.547651  0.000345  0.236644  0.013398      0.147145  0.005800\n",
       "0.1500   0.547862  0.000352  0.195121  0.022682      0.119983  0.005970\n",
       "0.1000   0.548375  0.000342  0.149797  0.021576      0.103443  0.007944\n",
       "0.0800   0.548778  0.000334  0.144516  0.017925      0.092730  0.008742\n",
       "0.0500   0.550031  0.000270  0.113189  0.017526      0.067318  0.006379\n",
       "0.0200   0.566475  0.003358  0.090068  0.022104      0.050370  0.009163\n",
       "0.0100   0.576500  0.003513  0.084955  0.022331      0.049965  0.009337\n",
       "0.0080   0.578582  0.003685  0.086211  0.023744      0.050168  0.010150\n",
       "0.0050   0.581698  0.003662  0.087180  0.026017      0.050012  0.011020\n",
       "0.0020   0.584923  0.003613  0.084751  0.026734      0.048323  0.011574\n",
       "0.0010   0.586062  0.003574  0.082972  0.026975      0.047409  0.011455\n",
       "0.0001   0.587090  0.003577  0.082200  0.025884      0.046747  0.010952"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "alphas = [\n",
    "    np.inf, 0.6, 0.55, 0.5, 0.45, 0.4, 0.35, 0.3, 0.25, 0.2, 0.15, 0.1, 0.08,\n",
    "    0.05, 0.02, 0.01, 0.008, 0.005, 0.002, 0.001, 0.0001\n",
    "]\n",
    "\n",
    "return_vals = process_map(\n",
    "    partial(\n",
    "        utils.postprocess,\n",
    "        postprocessor_factory=postprocess.PostProcessorTPR,\n",
    "        evaluate_fn=partial(utils.evaluate,\n",
    "                            n_groups=n_groups,\n",
    "                            n_classes=n_classes,\n",
    "                            metrics=['delta_tpr', 'delta_tpr_rms']),\n",
    "        probas=probas_,\n",
    "        labels=labels_,\n",
    "        groups=groups_,\n",
    "        n_post=n_post,\n",
    "        n_test=n_test,\n",
    "    ),\n",
    "    [(alpha, seed) for alpha in alphas for seed in seeds],\n",
    "    max_workers=max_workers,\n",
    ")\n",
    "results = [{\n",
    "    'alpha': alpha,\n",
    "    **result\n",
    "} for alpha, _, result, _ in return_vals if result is not None]\n",
    "\n",
    "(fig, ax), df = utils.plot_results(results, 'delta_tpr')\n",
    "ax.set_xlabel(\"$\\\\Delta_{\\\\mathrm{TPR}}$\")\n",
    "ax.set_title(\"ACSIncome (race, 5 classes)\")\n",
    "plt.show()\n",
    "display(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "526d90f3",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-05-01T00:20:04.409179Z",
     "iopub.status.busy": "2023-05-01T00:20:04.408401Z",
     "iopub.status.idle": "2023-05-01T06:42:48.531221Z",
     "shell.execute_reply": "2023-05-01T06:42:48.529094Z"
    },
    "papermill": {
     "duration": 22964.148764,
     "end_time": "2023-05-01T06:42:48.535053",
     "exception": false,
     "start_time": "2023-05-01T00:20:04.386289",
     "status": "completed"
    },
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5f8559fe54b4497aa3455bd0e183a743",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/210 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "With calibration:\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 350x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"2\" halign=\"left\">error_rate</th>\n",
       "      <th colspan=\"2\" halign=\"left\">delta_tpr</th>\n",
       "      <th colspan=\"2\" halign=\"left\">delta_tpr_rms</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>alpha</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>inf</th>\n",
       "      <td>0.555671</td>\n",
       "      <td>0.000298</td>\n",
       "      <td>0.622756</td>\n",
       "      <td>0.010371</td>\n",
       "      <td>0.288882</td>\n",
       "      <td>0.004518</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.6000</th>\n",
       "      <td>0.555666</td>\n",
       "      <td>0.000302</td>\n",
       "      <td>0.614804</td>\n",
       "      <td>0.033406</td>\n",
       "      <td>0.285335</td>\n",
       "      <td>0.015236</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.5500</th>\n",
       "      <td>0.555655</td>\n",
       "      <td>0.000306</td>\n",
       "      <td>0.560148</td>\n",
       "      <td>0.042454</td>\n",
       "      <td>0.260107</td>\n",
       "      <td>0.019171</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.5000</th>\n",
       "      <td>0.555655</td>\n",
       "      <td>0.000301</td>\n",
       "      <td>0.515183</td>\n",
       "      <td>0.032691</td>\n",
       "      <td>0.240650</td>\n",
       "      <td>0.012501</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.4500</th>\n",
       "      <td>0.555690</td>\n",
       "      <td>0.000298</td>\n",
       "      <td>0.468439</td>\n",
       "      <td>0.029505</td>\n",
       "      <td>0.223802</td>\n",
       "      <td>0.004805</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.4000</th>\n",
       "      <td>0.555672</td>\n",
       "      <td>0.000299</td>\n",
       "      <td>0.430369</td>\n",
       "      <td>0.031220</td>\n",
       "      <td>0.212570</td>\n",
       "      <td>0.002572</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.3500</th>\n",
       "      <td>0.555780</td>\n",
       "      <td>0.000309</td>\n",
       "      <td>0.375851</td>\n",
       "      <td>0.032466</td>\n",
       "      <td>0.195071</td>\n",
       "      <td>0.003246</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.3000</th>\n",
       "      <td>0.555861</td>\n",
       "      <td>0.000309</td>\n",
       "      <td>0.330807</td>\n",
       "      <td>0.025426</td>\n",
       "      <td>0.185379</td>\n",
       "      <td>0.001100</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.2500</th>\n",
       "      <td>0.556041</td>\n",
       "      <td>0.000321</td>\n",
       "      <td>0.297202</td>\n",
       "      <td>0.012875</td>\n",
       "      <td>0.184574</td>\n",
       "      <td>0.001493</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.2000</th>\n",
       "      <td>0.556022</td>\n",
       "      <td>0.000340</td>\n",
       "      <td>0.255664</td>\n",
       "      <td>0.011950</td>\n",
       "      <td>0.164796</td>\n",
       "      <td>0.002705</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.1500</th>\n",
       "      <td>0.556209</td>\n",
       "      <td>0.000338</td>\n",
       "      <td>0.207365</td>\n",
       "      <td>0.011054</td>\n",
       "      <td>0.134667</td>\n",
       "      <td>0.002849</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.1000</th>\n",
       "      <td>0.557223</td>\n",
       "      <td>0.000358</td>\n",
       "      <td>0.157796</td>\n",
       "      <td>0.016622</td>\n",
       "      <td>0.098270</td>\n",
       "      <td>0.003477</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0800</th>\n",
       "      <td>0.558899</td>\n",
       "      <td>0.000313</td>\n",
       "      <td>0.137577</td>\n",
       "      <td>0.017705</td>\n",
       "      <td>0.081416</td>\n",
       "      <td>0.003462</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0500</th>\n",
       "      <td>0.559416</td>\n",
       "      <td>0.000353</td>\n",
       "      <td>0.100132</td>\n",
       "      <td>0.017054</td>\n",
       "      <td>0.060268</td>\n",
       "      <td>0.005490</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0200</th>\n",
       "      <td>0.560493</td>\n",
       "      <td>0.001372</td>\n",
       "      <td>0.095916</td>\n",
       "      <td>0.019070</td>\n",
       "      <td>0.058341</td>\n",
       "      <td>0.006811</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0100</th>\n",
       "      <td>0.570418</td>\n",
       "      <td>0.003264</td>\n",
       "      <td>0.102407</td>\n",
       "      <td>0.013052</td>\n",
       "      <td>0.057562</td>\n",
       "      <td>0.007483</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0080</th>\n",
       "      <td>0.573169</td>\n",
       "      <td>0.003242</td>\n",
       "      <td>0.100048</td>\n",
       "      <td>0.012749</td>\n",
       "      <td>0.055779</td>\n",
       "      <td>0.006966</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0050</th>\n",
       "      <td>0.577158</td>\n",
       "      <td>0.003293</td>\n",
       "      <td>0.095579</td>\n",
       "      <td>0.012810</td>\n",
       "      <td>0.053060</td>\n",
       "      <td>0.006523</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0020</th>\n",
       "      <td>0.581139</td>\n",
       "      <td>0.003294</td>\n",
       "      <td>0.092931</td>\n",
       "      <td>0.013244</td>\n",
       "      <td>0.050815</td>\n",
       "      <td>0.006149</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0010</th>\n",
       "      <td>0.582503</td>\n",
       "      <td>0.003259</td>\n",
       "      <td>0.091326</td>\n",
       "      <td>0.013188</td>\n",
       "      <td>0.050019</td>\n",
       "      <td>0.006139</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>0.583719</td>\n",
       "      <td>0.003190</td>\n",
       "      <td>0.089848</td>\n",
       "      <td>0.013875</td>\n",
       "      <td>0.049273</td>\n",
       "      <td>0.006067</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       error_rate           delta_tpr           delta_tpr_rms          \n",
       "             mean       std      mean       std          mean       std\n",
       "alpha                                                                  \n",
       "inf      0.555671  0.000298  0.622756  0.010371      0.288882  0.004518\n",
       "0.6000   0.555666  0.000302  0.614804  0.033406      0.285335  0.015236\n",
       "0.5500   0.555655  0.000306  0.560148  0.042454      0.260107  0.019171\n",
       "0.5000   0.555655  0.000301  0.515183  0.032691      0.240650  0.012501\n",
       "0.4500   0.555690  0.000298  0.468439  0.029505      0.223802  0.004805\n",
       "0.4000   0.555672  0.000299  0.430369  0.031220      0.212570  0.002572\n",
       "0.3500   0.555780  0.000309  0.375851  0.032466      0.195071  0.003246\n",
       "0.3000   0.555861  0.000309  0.330807  0.025426      0.185379  0.001100\n",
       "0.2500   0.556041  0.000321  0.297202  0.012875      0.184574  0.001493\n",
       "0.2000   0.556022  0.000340  0.255664  0.011950      0.164796  0.002705\n",
       "0.1500   0.556209  0.000338  0.207365  0.011054      0.134667  0.002849\n",
       "0.1000   0.557223  0.000358  0.157796  0.016622      0.098270  0.003477\n",
       "0.0800   0.558899  0.000313  0.137577  0.017705      0.081416  0.003462\n",
       "0.0500   0.559416  0.000353  0.100132  0.017054      0.060268  0.005490\n",
       "0.0200   0.560493  0.001372  0.095916  0.019070      0.058341  0.006811\n",
       "0.0100   0.570418  0.003264  0.102407  0.013052      0.057562  0.007483\n",
       "0.0080   0.573169  0.003242  0.100048  0.012749      0.055779  0.006966\n",
       "0.0050   0.577158  0.003293  0.095579  0.012810      0.053060  0.006523\n",
       "0.0020   0.581139  0.003294  0.092931  0.013244      0.050815  0.006149\n",
       "0.0010   0.582503  0.003259  0.091326  0.013188      0.050019  0.006139\n",
       "0.0001   0.583719  0.003190  0.089848  0.013875      0.049273  0.006067"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "alphas = [\n",
    "    np.inf, 0.6, 0.55, 0.5, 0.45, 0.4, 0.35, 0.3, 0.25, 0.2, 0.15, 0.1, 0.08,\n",
    "    0.05, 0.02, 0.01, 0.008, 0.005, 0.002, 0.001, 0.0001\n",
    "]\n",
    "\n",
    "return_vals = process_map(\n",
    "    partial(\n",
    "        utils.postprocess,\n",
    "        postprocessor_factory=postprocess.PostProcessorTPR,\n",
    "        evaluate_fn=partial(utils.evaluate,\n",
    "                            n_groups=n_groups,\n",
    "                            n_classes=n_classes,\n",
    "                            metrics=['delta_tpr', 'delta_tpr_rms']),\n",
    "        probas=probas_cal_,\n",
    "        labels=labels_,\n",
    "        groups=groups_,\n",
    "        n_post=n_post,\n",
    "        n_test=n_test,\n",
    "    ),\n",
    "    [(alpha, seed) for alpha in alphas for seed in seeds],\n",
    "    max_workers=max_workers,\n",
    ")\n",
    "results = [{\n",
    "    'alpha': alpha,\n",
    "    **result\n",
    "} for alpha, _, result, _ in return_vals if result is not None]\n",
    "\n",
    "(fig, ax), df = utils.plot_results(results, 'delta_tpr')\n",
    "ax.set_xlabel(\"$\\\\Delta_{\\\\mathrm{TPR}}$\")\n",
    "ax.set_title(\"ACSIncome (race, 5 classes)\")\n",
    "print(\"With calibration:\")\n",
    "plt.show()\n",
    "display(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "325e57b1",
   "metadata": {
    "papermill": {
     "duration": 0.010727,
     "end_time": "2023-05-01T06:42:48.566356",
     "exception": false,
     "start_time": "2023-05-01T06:42:48.555629",
     "status": "completed"
    },
    "tags": []
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "fair",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.10"
  },
  "papermill": {
   "default_parameters": {},
   "duration": 90306.677447,
   "end_time": "2023-05-01T06:42:51.951801",
   "environment_variables": {},
   "exception": null,
   "input_path": "acsincome____.ipynb",
   "output_path": "tpr_acsincome.ipynb",
   "parameters": {},
   "start_time": "2023-04-30T05:37:45.274354",
   "version": "2.3.4"
  },
  "vscode": {
   "interpreter": {
    "hash": "aac456e002ecb64114f81d56e2b750c6ea20a76d8646af90a7cd3cc27dac8d4c"
   }
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "state": {
     "0aaf5994142a45fdab90475d620a3b57": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "0efefa05fa774a5cb08c6913f0ce29c1": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "10ca37e1ed964be19c2a6ae41920e673": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_331479cfd19644638ac7646e0414794e",
       "placeholder": "​",
       "style": "IPY_MODEL_ab705b63dbf440ca83471b39a058317a",
       "tabbable": null,
       "tooltip": null,
       "value": " 210/210 [16:21:53&lt;00:00, 86.39s/it]"
      }
     },
     "16e959d80cc44450ab3f69e6f058126f": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "2561f8f0fbf94f6a9da0093d6361f2a9": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "2685bc784b6142978d5bc5805963b875": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "2bd3cd3ac36c429ba9ce408b25fd9126": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "2e9cda61eab8486d91cc053a433e847c": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_68dda55e8ba14208a8620f97dde6092b",
       "placeholder": "​",
       "style": "IPY_MODEL_64c3465e6de84fc4ad4877c2396c9779",
       "tabbable": null,
       "tooltip": null,
       "value": "100%"
      }
     },
     "331479cfd19644638ac7646e0414794e": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "40a4faab4d75488abcb278c5904e81ff": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_a525f5ef7cdc4d4c8784726413fa4569",
       "placeholder": "​",
       "style": "IPY_MODEL_cbc52a3047674696a0aea00b502bf8b5",
       "tabbable": null,
       "tooltip": null,
       "value": " 210/210 [6:22:36&lt;00:00, 61.35s/it]"
      }
     },
     "44681099dc2e4c4e8710f25a306a582a": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "489150bf99604dbdaca7c5eb81db1bcd": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HBoxModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HBoxView",
       "box_style": "",
       "children": [
        "IPY_MODEL_5d466432d062466fa72018e85b8ae23a",
        "IPY_MODEL_92f93824ebda4279b88930eac96970c5",
        "IPY_MODEL_93a3299b08d54c0693cee9cf16ba3ad5"
       ],
       "layout": "IPY_MODEL_d98367eec958420d95e036609dbb64c0",
       "tabbable": null,
       "tooltip": null
      }
     },
     "4c55d0da22cf488ca9c9ff4defc10156": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "5d466432d062466fa72018e85b8ae23a": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_caf20ba2a1a943d890d248598b81389b",
       "placeholder": "​",
       "style": "IPY_MODEL_70bc72b4499f4f6caf68af0deb7848a5",
       "tabbable": null,
       "tooltip": null,
       "value": "100%"
      }
     },
     "5f8559fe54b4497aa3455bd0e183a743": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HBoxModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HBoxView",
       "box_style": "",
       "children": [
        "IPY_MODEL_7b2a797ff6ea437db2e950c3f15f5fd7",
        "IPY_MODEL_98b100f3724d4a0baa34dcb28ae48176",
        "IPY_MODEL_40a4faab4d75488abcb278c5904e81ff"
       ],
       "layout": "IPY_MODEL_d1b4ec40d91b495b9cb8db73d19250a0",
       "tabbable": null,
       "tooltip": null
      }
     },
     "64c3465e6de84fc4ad4877c2396c9779": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "68dda55e8ba14208a8620f97dde6092b": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "6bad04c82c3b47528c5f7ad1b05b1d34": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "70bc72b4499f4f6caf68af0deb7848a5": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "77c30abe98dc4abf8590ea2770dcd3ce": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "7b2a797ff6ea437db2e950c3f15f5fd7": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_2bd3cd3ac36c429ba9ce408b25fd9126",
       "placeholder": "​",
       "style": "IPY_MODEL_4c55d0da22cf488ca9c9ff4defc10156",
       "tabbable": null,
       "tooltip": null,
       "value": "100%"
      }
     },
     "7d64489f2e7e4dae857785c1c98aaab4": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "ProgressStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "bar_color": null,
       "description_width": ""
      }
     },
     "84214d971e21456aba04844abfcbe64e": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "862c8108dcff4c0ab69a9f32fcd49037": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "ProgressStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "bar_color": null,
       "description_width": ""
      }
     },
     "91379b6739b44262bc334d2742177d0a": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HBoxModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HBoxView",
       "box_style": "",
       "children": [
        "IPY_MODEL_2e9cda61eab8486d91cc053a433e847c",
        "IPY_MODEL_cc3434537bd6477ab1f6cc63dd456a1b",
        "IPY_MODEL_d5f34bd8856a4833a85194cf206911e1"
       ],
       "layout": "IPY_MODEL_77c30abe98dc4abf8590ea2770dcd3ce",
       "tabbable": null,
       "tooltip": null
      }
     },
     "92f93824ebda4279b88930eac96970c5": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "FloatProgressModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "ProgressView",
       "bar_style": "success",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_6bad04c82c3b47528c5f7ad1b05b1d34",
       "max": 130.0,
       "min": 0.0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_b073b364827d4d0aa8681404023f2a66",
       "tabbable": null,
       "tooltip": null,
       "value": 130.0
      }
     },
     "93a3299b08d54c0693cee9cf16ba3ad5": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_2561f8f0fbf94f6a9da0093d6361f2a9",
       "placeholder": "​",
       "style": "IPY_MODEL_44681099dc2e4c4e8710f25a306a582a",
       "tabbable": null,
       "tooltip": null,
       "value": " 130/130 [16:03&lt;00:00,  6.37s/it]"
      }
     },
     "98b100f3724d4a0baa34dcb28ae48176": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "FloatProgressModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "ProgressView",
       "bar_style": "success",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_84214d971e21456aba04844abfcbe64e",
       "max": 210.0,
       "min": 0.0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_7d64489f2e7e4dae857785c1c98aaab4",
       "tabbable": null,
       "tooltip": null,
       "value": 210.0
      }
     },
     "a525f5ef7cdc4d4c8784726413fa4569": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "ab705b63dbf440ca83471b39a058317a": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "abe92629ec3e444fbbc2411ea458d96e": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HBoxModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HBoxView",
       "box_style": "",
       "children": [
        "IPY_MODEL_bd5aed4364e64539bcf37a649059abff",
        "IPY_MODEL_f7c84a004f58407faaf5de4ef7686f12",
        "IPY_MODEL_10ca37e1ed964be19c2a6ae41920e673"
       ],
       "layout": "IPY_MODEL_16e959d80cc44450ab3f69e6f058126f",
       "tabbable": null,
       "tooltip": null
      }
     },
     "afe3673a01f140339d887e43a2e461cb": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "ProgressStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "bar_color": null,
       "description_width": ""
      }
     },
     "b073b364827d4d0aa8681404023f2a66": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "ProgressStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "bar_color": null,
       "description_width": ""
      }
     },
     "bd5aed4364e64539bcf37a649059abff": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_d28dc0f809b24266baa9e8cb07d2e63d",
       "placeholder": "​",
       "style": "IPY_MODEL_2685bc784b6142978d5bc5805963b875",
       "tabbable": null,
       "tooltip": null,
       "value": "100%"
      }
     },
     "c5d3127a23df465d926e50a0ae228f17": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "caf20ba2a1a943d890d248598b81389b": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "cbc52a3047674696a0aea00b502bf8b5": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "cc3434537bd6477ab1f6cc63dd456a1b": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "FloatProgressModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "ProgressView",
       "bar_style": "success",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_0aaf5994142a45fdab90475d620a3b57",
       "max": 130.0,
       "min": 0.0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_862c8108dcff4c0ab69a9f32fcd49037",
       "tabbable": null,
       "tooltip": null,
       "value": 130.0
      }
     },
     "d1b4ec40d91b495b9cb8db73d19250a0": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "d28dc0f809b24266baa9e8cb07d2e63d": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "d5f34bd8856a4833a85194cf206911e1": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_c5d3127a23df465d926e50a0ae228f17",
       "placeholder": "​",
       "style": "IPY_MODEL_e24b20951d4c4ab7a5c5730af428cfcd",
       "tabbable": null,
       "tooltip": null,
       "value": " 130/130 [12:42&lt;00:00,  3.22s/it]"
      }
     },
     "d98367eec958420d95e036609dbb64c0": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "e24b20951d4c4ab7a5c5730af428cfcd": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "f7c84a004f58407faaf5de4ef7686f12": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "FloatProgressModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "ProgressView",
       "bar_style": "success",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_0efefa05fa774a5cb08c6913f0ce29c1",
       "max": 210.0,
       "min": 0.0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_afe3673a01f140339d887e43a2e461cb",
       "tabbable": null,
       "tooltip": null,
       "value": 210.0
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}