{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "de5da1d9-1f1a-49c2-80ca-363b0c1e22b3",
   "metadata": {},
   "source": [
    "# Reproducing Figures and Tables"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "mental-format",
   "metadata": {},
   "outputs": [],
   "source": [
    "from __future__ import print_function, absolute_import, division\n",
    "import sys, os, json, requests, time, datetime, logging, pickle\n",
    "from pathlib import Path\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import sklearn\n",
    "import sklearn.linear_model\n",
    "import tqdm\n",
    "import wandb\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "\n",
    "import seaborn as sns\n",
    "import matplotlib\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "\n",
    "sns.set()\n",
    "sns.set(font_scale=2.5,)\n",
    "sns.set_style(\"white\")\n",
    "# sns.set_style({'font.family': 'Times New Roman'})\n",
    "sns.set_palette(\"colorblind\")\n",
    "\n",
    "\n",
    "plt.rcParams.update({'font.size': 20, 'lines.linewidth':4, 'lines.markersize':12, \n",
    "                         'xtick.labelsize':15, 'ytick.labelsize':15, 'axes.labelsize':20,\n",
    "                         'axes.titlesize': 20, 'legend.fontsize':20,\n",
    "                         'pdf.fonttype': 42, 'ps.fonttype':42,\n",
    "                        'image.interpolation':'nearest', 'figure.figsize': (10,8),\n",
    "                     'text.usetex': False\n",
    "                     \n",
    "                    })\n",
    "tqdm.tqdm.pandas()\n",
    "# logging.getLogger().setLevel(logging.CRITICAL)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "81015aff-46e0-4014-8d03-178bd25f2e2c",
   "metadata": {},
   "source": [
    "Table utility functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "cleared-scanner",
   "metadata": {},
   "outputs": [],
   "source": [
    "def show_table(df, gg_method = 'min'):\n",
    "    df = df.reset_index(drop=True)\n",
    "    return pd.concat([\n",
    "    (df\n",
    "      .query(\"constraint=='eo'\")\n",
    "     .assign(run_count=lambda x:x['exp_name'], grid_count=lambda x:x['grid'])\n",
    "     .groupby([\"constraint\", \"violation_eps\", \"loss_type\", ])\n",
    "     .agg({\n",
    "         'test_balloss_cls_eo': agg_method,\n",
    "              'run_count': 'nunique',\n",
    "         'grid_count': 'nunique',\n",
    "     })\n",
    "    ),\n",
    "    (df\n",
    "      .query(\"constraint=='dp'\")\n",
    "     .assign(run_count=lambda x:x['exp_name'], grid_count=lambda x:x['grid'])\n",
    "     .groupby([\"constraint\", \"violation_eps\", \"loss_type\", ])\n",
    "     .agg({\n",
    "         'test_balloss_cls_dp': agg_method,\n",
    "         'run_count': 'nunique',\n",
    "         'grid_count': 'nunique',\n",
    "     })\n",
    "    )\n",
    "        ], axis=1)\n",
    "\n",
    "def show_agg_df(df, gg_method = 'min',\n",
    "                added_cols=[\"train_acc\", \"test_acc\"],\n",
    "                group_cols=[\"constraint\",\"violation_eps\", \"loss_type\", \"use_drw\"]):\n",
    "    df = df.reset_index(drop=True)\n",
    "    eo_df = (df.query(\"constraint=='eo'\")\n",
    "     .assign(run_count=lambda x:x['exp_name'], grid_count=lambda x:x['grid'])\n",
    "     .reset_index(drop=True)\n",
    "     .rename({'test_balloss_cls_eo': 'test_balanced_loss',\n",
    "              'train_balloss_cls_eo': 'train_balanced_loss',\n",
    "              'test_eo': 'test_violation',\n",
    "              'train_eo': 'train_violation'\n",
    "             },axis=1)\n",
    "    )\n",
    "    dp_df = (df.query(\"constraint=='dp'\")\n",
    "     .assign(run_count=lambda x:x['exp_name'], grid_count=lambda x:x['grid'])\n",
    "     .reset_index(drop=True)\n",
    "     .rename({'test_balloss_cls_dp': 'test_balanced_loss',\n",
    "              'train_balloss_cls_dp': 'train_balanced_loss',\n",
    "              'test_dp': 'test_violation',\n",
    "              'train_dp': 'train_violation'\n",
    "             },axis=1)\n",
    "    )\n",
    "    df = pd.concat([eo_df, dp_df]).reset_index(drop=True)\n",
    "\n",
    "    return (df\n",
    "     .iloc[df.groupby(group_cols)['test_balanced_loss'].idxmin()]\n",
    "     [group_cols+added_cols+[\n",
    "       \"test_balanced_loss\",\"train_balanced_loss\",\n",
    "       \"test_violation\", \"train_violation\", \n",
    "       \"test_cls_avg_acc\", \"train_cls_avg_acc\", \n",
    "        \n",
    "      ]]\n",
    "    .reset_index(drop=True)\n",
    "    .assign(bal_acc_gap=lambda x :  x['train_cls_avg_acc'] - x['test_cls_avg_acc'] )\n",
    "    .assign(bal_loss_gap=lambda x :  x['test_balanced_loss'] - x['train_balanced_loss'] )\n",
    "    .assign(violation_gap=lambda x :  x['test_violation'] - x['train_violation'] )\n",
    "    ).groupby(group_cols).first()\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "aboriginal-vocabulary",
   "metadata": {},
   "source": [
    "# Load Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1112,
   "id": "sharp-decrease",
   "metadata": {},
   "outputs": [],
   "source": [
    "def process_table(table, method_suffix='-GS', tuple_header=None, use_drw=None, show_gap=False, constraint='eo'):\n",
    "    if use_drw is not None:\n",
    "        table = table.query(f'use_drw=={use_drw}')\n",
    "    table = (show_agg_df(table, group_cols=[\"constraint\",\"violation_eps\", \"loss_type\"],                        \n",
    "                        )\n",
    "    .query(f'constraint==\"{constraint}\"')\n",
    "    .reset_index()\n",
    "    .drop(['constraint'],axis=1)\n",
    "    .rename({'violation_eps':r\"$\\epsilon$\", 'loss_type': 'Method'},axis=1)\n",
    "    .replace({'Method':{'fdam':f'FIFA{method_suffix}',\n",
    "                             'ldam': f'LDAM{method_suffix}',\n",
    "                             'standard': f'Vanilla{method_suffix}',\n",
    "                            }})\n",
    "            )\n",
    "    n_methods = table.Method.nunique()\n",
    "    table[r\"$\\epsilon$\"] = table[r\"$\\epsilon$\"].apply(lambda e:r\"\\multirow{\"+ f\"{n_methods}\"+r\"}{*}{\"+f\"{e:.2f}\"+\"}\")\n",
    "    table=table.assign(   \n",
    "        bal_loss_gap_abs=lambda x:np.abs(x['bal_loss_gap']),\n",
    "        violation_gap_abs=lambda x:np.abs(x['violation_gap']),\n",
    "        bal_acc_gap_abs=lambda x:np.abs(x['bal_acc_gap']),\n",
    "        train_bal_err=lambda x:1.-x['train_cls_avg_acc'],\n",
    "        test_bal_err=lambda x:1.-x['test_cls_avg_acc'],\n",
    "    ).set_index([r\"$\\epsilon$\", 'Method'])\n",
    "    \n",
    "\n",
    "    table_cols = ['train_balanced_loss','test_balanced_loss','bal_loss_gap_abs',\n",
    "               'train_violation','test_violation','violation_gap_abs',\n",
    "#                 'train_bal_err','test_bal_err','bal_acc_gap_abs'\n",
    "                 ]\n",
    "    tuple_list = [\n",
    "        ('Combined Loss', 'Train'),     ('Combined Loss', 'Test'),     ('Combined Loss', 'Gap'),\n",
    "        ('Fairness Violation', 'Train'),     ('Fairness Violation', 'Test'),     ('Fairness Violation', 'Gap'),\n",
    "#         ('Balanced Error', 'Train'),     ('Balanced Error', 'Test'),     ('Balanced Error', 'Gap'),\n",
    "    ]\n",
    "    if not show_gap:\n",
    "        tuple_list = [t for t in tuple_list if t[1] !='Gap']\n",
    "        table_cols = [c for c in table_cols if 'gap' not in c] \n",
    "    if tuple_header is not None:\n",
    "        tuple_list = [(tuple_header,)+t for t in tuple_list]\n",
    "    table=table[table_cols]\n",
    "    table.columns = pd.MultiIndex.from_tuples(tuple_list)\n",
    "    return table"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "empty-forty",
   "metadata": {},
   "source": [
    "## Data Summary"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 737,
   "id": "nutritional-algeria",
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.options.display.float_format = '{:.2}'.format"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 849,
   "id": "proper-communist",
   "metadata": {},
   "outputs": [],
   "source": [
    "import src.example_datasets as egdata \n",
    "import src.datasets\n",
    "adult_income_data = egdata.load_adult_income_dataset(Path(\"/shared/zjiayao/data/adult_income\"))\n",
    "adult_size_map_handle = src.datasets.construct_data_size_map(\n",
    "       y_train=adult_income_data[1], \n",
    "       A_train=adult_income_data[2],\n",
    "       y_test=adult_income_data[4],\n",
    "       A_test=adult_income_data[5],\n",
    "    attr_name='sex',\n",
    "   )\n",
    "\n",
    "\n",
    "\n",
    "dutch_data = egdata.load_dutch_data( Path(\"/shared/zjiayao/data/dutch_consensus/dutch.csv\"), seed=1)\n",
    "dutch_data[0] = pd.concat([dutch_data[0],\n",
    "                                dutch_data[2]=='Female'],\n",
    "                               axis=1).astype(float)\n",
    "dutch_data[3] = pd.concat([dutch_data[3],\n",
    "                                dutch_data[5]=='Female'],\n",
    "                               axis=1).astype(float)\n",
    "dutch_size_map_handle = src.datasets.construct_data_size_map(\n",
    "           y_train=dutch_data[1], \n",
    "           A_train=dutch_data[2],\n",
    "           y_test=dutch_data[4],\n",
    "           A_test=dutch_data[5],\n",
    "        attr_name='gender',\n",
    "       )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1102,
   "id": "offensive-military",
   "metadata": {},
   "outputs": [],
   "source": [
    "adult_sizes = (pd.concat([adult_size_map_handle('train').rename({'n':'Train'},axis=1),\n",
    "            adult_size_map_handle('test').rename({'n':'Test'},axis=1)], axis=1)\n",
    " .reset_index()\n",
    " .rename({'label': 'Label', 'sex': 'Gender'},axis=1)\n",
    " .sort_values([ 'Label','Gender'])\n",
    ")\n",
    "adult_sizes['Data'] = 'AdultIncome'\n",
    "\n",
    "dutch_sizes = (pd.concat([dutch_size_map_handle('train').rename({'n':'Train'},axis=1),\n",
    "            dutch_size_map_handle('test').rename({'n':'Test'},axis=1)], axis=1)\n",
    " .reset_index()\n",
    " .rename({'label': 'Label', 'gender': 'Gender'},axis=1)\n",
    " .sort_values([ 'Label','Gender'])\n",
    ")\n",
    "dutch_sizes['Data'] = 'DutchConsensus'\n",
    "celeba_sizes = (pd.concat([src.datasets.get_celeba_size_map('train').rename({'n':'Train'},axis=1),\n",
    "                          src.datasets.get_celeba_size_map('test').rename({'n':'Test'},axis=1)],\n",
    "                         axis=1)\n",
    "    .reset_index()\n",
    "    .replace({\"gender\": {'male':'Male', 'female':'Female'}})\n",
    "    .rename({'blond': 'Label', 'gender': 'Gender'},axis=1)\n",
    " .sort_values([ 'Label','Gender'])\n",
    ")\n",
    "celeba_sizes['Data'] = 'CelebA'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1104,
   "id": "outer-minutes",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_sizes = (  pd.concat([celeba_sizes, adult_sizes,dutch_sizes])\n",
    " .sort_values(['Data', 'Label','Gender'])\n",
    " .set_index(['Data', 'Label','Gender'])\n",
    ").reset_index()\n",
    "data_sizes=data_sizes.replace({\n",
    "        'Gender':{\n",
    "            'Male': r'$\\texttt{Male}$',\n",
    "            'Female': r'$\\texttt{Female}$',\n",
    "        }\n",
    "    })\n",
    "\n",
    "data_sizes['label'] = data_sizes['Label'].apply(lambda l : r'\\texttt{+}' if l==1 else r'\\texttt{-}')\n",
    "data_sizes['Subgroup'] = data_sizes.apply(lambda s:\n",
    "                                         f\"({s['Gender']}, {s['label']})\",axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1105,
   "id": "special-muscle",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_sizes['Traing Sample Proportions']=data_sizes['Train'] / data_sizes.groupby('Data')['Train'].transform('sum')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2e992592-52ff-49f8-b2c2-2e6391670c79",
   "metadata": {},
   "source": [
    "#### Figure 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 941,
   "id": "received-executive",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rcParams.update({'hatch.color': 'k'})\n",
    "sns.set_palette(\"colorblind\")\n",
    "\n",
    "ax=plt.gca()\n",
    "bar=sns.barplot(\n",
    "    x='Data',\n",
    "    y='Traing Sample Proportions', hue='Subgroup',# kind='bar',\n",
    "    data=data_sizes,\n",
    "#     pd.melt(data_sizes.reset_index(), id_vars=['Data', 'Label','Gender'], value_vars=['Train','Test'],\n",
    "#         var_name='Split', value_name='Sample Size'), \n",
    "    alpha=0.6,\n",
    "ax=ax\n",
    ")\n",
    "hatches = ['-', '\\\\', '-', '\\\\',\n",
    "           '-', '\\\\', '-', '\\\\',\n",
    "           '-', '\\\\', '-', '\\\\',\n",
    "          ]\n",
    "patch_idx = np.argsort([b.xy[0] for b in bar.patches])\n",
    "for i in patch_idx: \n",
    "    # Set a different hatch for each bar\n",
    "    thisbar = bar.patches[i]\n",
    "    thisbar.set_hatch('----' if i % 2 == 0 else '////', )\n",
    "    thisbar.set_edgecolor([0.5,0.5,0.5])\n",
    "\n",
    "\n",
    "ax.set_xlabel(r\"Dataset\")\n",
    "ax.set_ylabel(r\"Relative Frequency\")\n",
    "ax.set_ylim([0, 0.5])\n",
    "sns.move_legend(ax,loc=2,ncol=2,fontsize=12,title_fontsize=18,title=r'$\\textbf{Subgroup}$', fancybox=False)\n",
    "plt.tight_layout()\n",
    "plt.savefig('./figs/teaser_hist'+'.png', bbox_inches='tight')\n",
    "plt.savefig('./figs/teaser_hist'+'.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e2768381-19fc-45ff-a3db-d672d6e97c54",
   "metadata": {},
   "source": [
    "#### Table 3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1107,
   "id": "affected-violin",
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.options.display.float_format = '{:.2}'.format\n",
    "data_sizes = (  pd.concat([celeba_sizes, adult_sizes,dutch_sizes])\n",
    " .sort_values(['Data', 'Label','Gender'])\n",
    " .set_index(['Data', 'Label','Gender'])\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1110,
   "id": "naughty-faith",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th>Data</th>\n",
       "      <th colspan=\"4\" halign=\"left\">AdultIncome</th>\n",
       "      <th colspan=\"4\" halign=\"left\">CelebA</th>\n",
       "      <th colspan=\"4\" halign=\"left\">DutchConsensus</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Label</th>\n",
       "      <th colspan=\"2\" halign=\"left\">0.0</th>\n",
       "      <th colspan=\"2\" halign=\"left\">1.0</th>\n",
       "      <th colspan=\"2\" halign=\"left\">0.0</th>\n",
       "      <th colspan=\"2\" halign=\"left\">1.0</th>\n",
       "      <th colspan=\"2\" halign=\"left\">0.0</th>\n",
       "      <th colspan=\"2\" halign=\"left\">1.0</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Gender</th>\n",
       "      <th>Female</th>\n",
       "      <th>Male</th>\n",
       "      <th>Female</th>\n",
       "      <th>Male</th>\n",
       "      <th>Female</th>\n",
       "      <th>Male</th>\n",
       "      <th>Female</th>\n",
       "      <th>Male</th>\n",
       "      <th>Female</th>\n",
       "      <th>Male</th>\n",
       "      <th>Female</th>\n",
       "      <th>Male</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Train</th>\n",
       "      <td>9592</td>\n",
       "      <td>15128</td>\n",
       "      <td>1179</td>\n",
       "      <td>6662</td>\n",
       "      <td>71629</td>\n",
       "      <td>66874</td>\n",
       "      <td>22880</td>\n",
       "      <td>1387</td>\n",
       "      <td>69117</td>\n",
       "      <td>59608</td>\n",
       "      <td>7991</td>\n",
       "      <td>15064</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Test</th>\n",
       "      <td>4831</td>\n",
       "      <td>7604</td>\n",
       "      <td>590</td>\n",
       "      <td>3256</td>\n",
       "      <td>9767</td>\n",
       "      <td>7535</td>\n",
       "      <td>2480</td>\n",
       "      <td>180</td>\n",
       "      <td>17231</td>\n",
       "      <td>15006</td>\n",
       "      <td>1912</td>\n",
       "      <td>3796</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Data   AdultIncome                     CelebA                      \\\n",
       "Label          0.0           1.0          0.0           1.0         \n",
       "Gender      Female   Male Female  Male Female   Male Female  Male   \n",
       "Train         9592  15128   1179  6662  71629  66874  22880  1387   \n",
       "Test          4831   7604    590  3256   9767   7535   2480   180   \n",
       "\n",
       "Data   DutchConsensus                       \n",
       "Label             0.0           1.0         \n",
       "Gender         Female   Male Female   Male  \n",
       "Train           69117  59608   7991  15064  \n",
       "Test            17231  15006   1912   3796  "
      ]
     },
     "execution_count": 1110,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data_sizes.T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1111,
   "id": "charming-midwest",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lrrrrrrrrrrrr}\n",
      "\\toprule\n",
      "Data & \\multicolumn{4}{c}{AdultIncome} & \\multicolumn{4}{c}{CelebA} & \\multicolumn{4}{c}{DutchConsensus} \\\\\n",
      "Label & \\multicolumn{2}{c}{0.0} & \\multicolumn{2}{c}{1.0} & \\multicolumn{2}{c}{0.0} & \\multicolumn{2}{c}{1.0} & \\multicolumn{2}{c}{0.0} & \\multicolumn{2}{c}{1.0} \\\\\n",
      "Gender &      Female &   Male & Female &  Male & Female &   Male & Female &  Male &         Female &   Male & Female &   Male \\\\\n",
      "\\midrule\n",
      "Train &        9592 &  15128 &   1179 &  6662 &  71629 &  66874 &  22880 &  1387 &          69117 &  59608 &   7991 &  15064 \\\\\n",
      "Test  &        4831 &   7604 &    590 &  3256 &   9767 &   7535 &   2480 &   180 &          17231 &  15006 &   1912 &   3796 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(data_sizes.T\n",
    " .to_latex(multicolumn_format='c',escape=False)\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "adolescent-mobility",
   "metadata": {},
   "source": [
    "## Adult Income"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1171,
   "id": "artificial-final",
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.options.display.float_format = '{:.5%}'.format"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c0815a25-5450-4c9b-a908-37549694564c",
   "metadata": {},
   "source": [
    "#### Table 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1169,
   "id": "floppy-youth",
   "metadata": {},
   "outputs": [],
   "source": [
    "income_gs_eo_df = process_table(income_gs_sweeps_df, method_suffix='', \n",
    "                             show_gap=False,\n",
    "                             tuple_header='EO',\n",
    "                             constraint='eo'\n",
    "                            )\n",
    "income_gs_dp_df = process_table(income_gs_sweeps_df, method_suffix='', \n",
    "                             show_gap=False,\n",
    "                             tuple_header='DP',\n",
    "                             constraint='dp'\n",
    "                            )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1172,
   "id": "olive-croatia",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead 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></th>\n",
       "      <th colspan=\"4\" halign=\"left\">EO</th>\n",
       "      <th colspan=\"4\" halign=\"left\">DP</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th colspan=\"2\" halign=\"left\">Combined Loss</th>\n",
       "      <th colspan=\"2\" halign=\"left\">Fairness Violation</th>\n",
       "      <th colspan=\"2\" halign=\"left\">Combined Loss</th>\n",
       "      <th colspan=\"2\" halign=\"left\">Fairness Violation</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Train</th>\n",
       "      <th>Test</th>\n",
       "      <th>Train</th>\n",
       "      <th>Test</th>\n",
       "      <th>Train</th>\n",
       "      <th>Test</th>\n",
       "      <th>Train</th>\n",
       "      <th>Test</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>$\\epsilon$</th>\n",
       "      <th>Method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">\\multirow{2}{*}{0.01}</th>\n",
       "      <th>FIFA</th>\n",
       "      <td>14.77618%</td>\n",
       "      <td>14.93573%</td>\n",
       "      <td>8.53851%</td>\n",
       "      <td>8.50086%</td>\n",
       "      <td>13.75700%</td>\n",
       "      <td>14.05881%</td>\n",
       "      <td>0.08609%</td>\n",
       "      <td>0.00999%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Vanilla</th>\n",
       "      <td>16.68724%</td>\n",
       "      <td>17.28659%</td>\n",
       "      <td>10.39000%</td>\n",
       "      <td>10.92794%</td>\n",
       "      <td>14.83347%</td>\n",
       "      <td>15.09909%</td>\n",
       "      <td>3.32436%</td>\n",
       "      <td>3.65903%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">\\multirow{2}{*}{0.05}</th>\n",
       "      <th>FIFA</th>\n",
       "      <td>14.79263%</td>\n",
       "      <td>14.91599%</td>\n",
       "      <td>8.57436%</td>\n",
       "      <td>8.50841%</td>\n",
       "      <td>13.74952%</td>\n",
       "      <td>14.03440%</td>\n",
       "      <td>0.11811%</td>\n",
       "      <td>0.01008%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Vanilla</th>\n",
       "      <td>16.68724%</td>\n",
       "      <td>17.28659%</td>\n",
       "      <td>10.39000%</td>\n",
       "      <td>10.92794%</td>\n",
       "      <td>14.83475%</td>\n",
       "      <td>15.09909%</td>\n",
       "      <td>3.32895%</td>\n",
       "      <td>3.65903%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">\\multirow{2}{*}{0.10}</th>\n",
       "      <th>FIFA</th>\n",
       "      <td>14.70959%</td>\n",
       "      <td>14.88935%</td>\n",
       "      <td>8.17597%</td>\n",
       "      <td>8.16283%</td>\n",
       "      <td>13.72278%</td>\n",
       "      <td>14.03193%</td>\n",
       "      <td>0.11331%</td>\n",
       "      <td>0.01011%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Vanilla</th>\n",
       "      <td>16.68724%</td>\n",
       "      <td>17.28659%</td>\n",
       "      <td>10.39000%</td>\n",
       "      <td>10.92794%</td>\n",
       "      <td>14.82782%</td>\n",
       "      <td>15.09909%</td>\n",
       "      <td>3.31507%</td>\n",
       "      <td>3.65903%</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                         EO                               \\\n",
       "                              Combined Loss           Fairness Violation   \n",
       "                                      Train      Test              Train   \n",
       "$\\epsilon$            Method                                               \n",
       "\\multirow{2}{*}{0.01} FIFA        14.77618% 14.93573%           8.53851%   \n",
       "                      Vanilla     16.68724% 17.28659%          10.39000%   \n",
       "\\multirow{2}{*}{0.05} FIFA        14.79263% 14.91599%           8.57436%   \n",
       "                      Vanilla     16.68724% 17.28659%          10.39000%   \n",
       "\\multirow{2}{*}{0.10} FIFA        14.70959% 14.88935%           8.17597%   \n",
       "                      Vanilla     16.68724% 17.28659%          10.39000%   \n",
       "\n",
       "                                                   DP            \\\n",
       "                                        Combined Loss             \n",
       "                                   Test         Train      Test   \n",
       "$\\epsilon$            Method                                      \n",
       "\\multirow{2}{*}{0.01} FIFA     8.50086%     13.75700% 14.05881%   \n",
       "                      Vanilla 10.92794%     14.83347% 15.09909%   \n",
       "\\multirow{2}{*}{0.05} FIFA     8.50841%     13.74952% 14.03440%   \n",
       "                      Vanilla 10.92794%     14.83475% 15.09909%   \n",
       "\\multirow{2}{*}{0.10} FIFA     8.16283%     13.72278% 14.03193%   \n",
       "                      Vanilla 10.92794%     14.82782% 15.09909%   \n",
       "\n",
       "                                                           \n",
       "                              Fairness Violation           \n",
       "                                           Train     Test  \n",
       "$\\epsilon$            Method                               \n",
       "\\multirow{2}{*}{0.01} FIFA              0.08609% 0.00999%  \n",
       "                      Vanilla           3.32436% 3.65903%  \n",
       "\\multirow{2}{*}{0.05} FIFA              0.11811% 0.01008%  \n",
       "                      Vanilla           3.32895% 3.65903%  \n",
       "\\multirow{2}{*}{0.10} FIFA              0.11331% 0.01011%  \n",
       "                      Vanilla           3.31507% 3.65903%  "
      ]
     },
     "execution_count": 1172,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.concat([income_gs_eo_df,income_gs_dp_df],axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1173,
   "id": "distinct-advocacy",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{llrrrrrrrr}\n",
      "\\toprule\n",
      "                      &         & \\multicolumn{4}{c}{EO} & \\multicolumn{4}{c}{DP} \\\\\n",
      "                      &         & \\multicolumn{2}{c}{Combined Loss} & \\multicolumn{2}{c}{Fairness Violation} & \\multicolumn{2}{c}{Combined Loss} & \\multicolumn{2}{c}{Fairness Violation} \\\\\n",
      "                      &         &         Train &      Test &              Train &      Test &         Train &      Test &              Train &     Test \\\\\n",
      "$\\epsilon$ & Method &               &           &                    &           &               &           &                    &          \\\\\n",
      "\\midrule\n",
      "\\multirow{2}{*}{0.01} & FIFA &     14.77618% & 14.93573% &           8.53851% &  8.50086% &     13.75700% & 14.05881% &           0.08609% & 0.00999% \\\\\n",
      "                      & Vanilla &     16.68724% & 17.28659% &          10.39000% & 10.92794% &     14.83347% & 15.09909% &           3.32436% & 3.65903% \\\\\n",
      "\\multirow{2}{*}{0.05} & FIFA &     14.79263% & 14.91599% &           8.57436% &  8.50841% &     13.74952% & 14.03440% &           0.11811% & 0.01008% \\\\\n",
      "                      & Vanilla &     16.68724% & 17.28659% &          10.39000% & 10.92794% &     14.83475% & 15.09909% &           3.32895% & 3.65903% \\\\\n",
      "\\multirow{2}{*}{0.10} & FIFA &     14.70959% & 14.88935% &           8.17597% &  8.16283% &     13.72278% & 14.03193% &           0.11331% & 0.01011% \\\\\n",
      "                      & Vanilla &     16.68724% & 17.28659% &          10.39000% & 10.92794% &     14.82782% & 15.09909% &           3.31507% & 3.65903% \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(\n",
    "    pd.concat([income_gs_eo_df,income_gs_dp_df],axis=1).to_latex( multicolumn_format='c',escape=False)\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0545d664-3c0f-481d-af3e-b9176fb662e3",
   "metadata": {},
   "source": [
    "#### Table 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 773,
   "id": "prostate-causing",
   "metadata": {},
   "outputs": [],
   "source": [
    "income_gs_sweeps_df = pd.read_csv(\"./csv_data/income_grid_search.csv\",)\n",
    "income_eg_sweeps_df = pd.read_csv(\"./csv_data/income_expgrad.csv\",)\n",
    "\n",
    "income_gs_sweeps_df['loss_type'] = income_gs_sweeps_df['loss_type'].apply(lambda s : 'standard' if s == 'standard' else 'fdam')\n",
    "income_eg_sweeps_df['loss_type'] = income_eg_sweeps_df['loss_type'].apply(lambda s : 'standard' if s == 'standard' else 'fdam')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 774,
   "id": "spatial-bishop",
   "metadata": {},
   "outputs": [],
   "source": [
    "dutch_eg_sweeps_df = pd.read_csv(\"./csv_data/dutch_expgrad.csv\", )\n",
    "dutch_eg_sweeps_df['loss_type'] = dutch_eg_sweeps_df['loss_type'].apply(lambda s : 'standard' if s == 'standard' else 'fdam')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 775,
   "id": "czech-declaration",
   "metadata": {},
   "outputs": [],
   "source": [
    "income_eg_df = process_table(income_eg_sweeps_df, method_suffix='', \n",
    "                             show_gap=False,\n",
    "                             tuple_header='AdultIncome'\n",
    "                            )\n",
    "ducth_eg_df = process_table(dutch_eg_sweeps_df, method_suffix='', \n",
    "                             show_gap=False,\n",
    "                             tuple_header='DutchConsensus'\n",
    "                            )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 776,
   "id": "processed-facing",
   "metadata": {},
   "outputs": [],
   "source": [
    "expg_df = pd.concat([income_eg_df,ducth_eg_df],axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 790,
   "id": "imperial-advice",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead 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></th>\n",
       "      <th colspan=\"4\" halign=\"left\">AdultIncome</th>\n",
       "      <th colspan=\"4\" halign=\"left\">DutchConsensus</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th colspan=\"2\" halign=\"left\">Combined Loss</th>\n",
       "      <th colspan=\"2\" halign=\"left\">Fairness Violation</th>\n",
       "      <th colspan=\"2\" halign=\"left\">Combined Loss</th>\n",
       "      <th colspan=\"2\" halign=\"left\">Fairness Violation</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Train</th>\n",
       "      <th>Test</th>\n",
       "      <th>Train</th>\n",
       "      <th>Test</th>\n",
       "      <th>Train</th>\n",
       "      <th>Test</th>\n",
       "      <th>Train</th>\n",
       "      <th>Test</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>$\\epsilon$</th>\n",
       "      <th>Method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">\\multirow{2}{*}{0.01}</th>\n",
       "      <th>FIFA</th>\n",
       "      <td>15.72170%</td>\n",
       "      <td>13.48116%</td>\n",
       "      <td>7.88627%</td>\n",
       "      <td>2.77756%</td>\n",
       "      <td>12.80131%</td>\n",
       "      <td>13.16857%</td>\n",
       "      <td>3.72201%</td>\n",
       "      <td>4.35324%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Vanilla</th>\n",
       "      <td>13.95614%</td>\n",
       "      <td>14.30009%</td>\n",
       "      <td>6.78607%</td>\n",
       "      <td>6.74747%</td>\n",
       "      <td>12.84442%</td>\n",
       "      <td>13.22665%</td>\n",
       "      <td>3.79351%</td>\n",
       "      <td>4.43227%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">\\multirow{2}{*}{0.05}</th>\n",
       "      <th>FIFA</th>\n",
       "      <td>13.56342%</td>\n",
       "      <td>13.54908%</td>\n",
       "      <td>5.70877%</td>\n",
       "      <td>4.93145%</td>\n",
       "      <td>12.88197%</td>\n",
       "      <td>13.22278%</td>\n",
       "      <td>3.85249%</td>\n",
       "      <td>4.43227%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Vanilla</th>\n",
       "      <td>14.46966%</td>\n",
       "      <td>14.86473%</td>\n",
       "      <td>7.59619%</td>\n",
       "      <td>7.85747%</td>\n",
       "      <td>12.88178%</td>\n",
       "      <td>13.22355%</td>\n",
       "      <td>3.85249%</td>\n",
       "      <td>4.43227%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">\\multirow{2}{*}{0.10}</th>\n",
       "      <th>FIFA</th>\n",
       "      <td>13.58569%</td>\n",
       "      <td>13.90430%</td>\n",
       "      <td>6.12168%</td>\n",
       "      <td>5.96891%</td>\n",
       "      <td>12.87168%</td>\n",
       "      <td>13.17477%</td>\n",
       "      <td>3.83258%</td>\n",
       "      <td>4.35324%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Vanilla</th>\n",
       "      <td>15.53416%</td>\n",
       "      <td>15.93873%</td>\n",
       "      <td>9.75137%</td>\n",
       "      <td>10.07504%</td>\n",
       "      <td>12.87569%</td>\n",
       "      <td>13.20988%</td>\n",
       "      <td>3.83921%</td>\n",
       "      <td>4.40593%</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                AdultIncome                               \\\n",
       "                              Combined Loss           Fairness Violation   \n",
       "                                      Train      Test              Train   \n",
       "$\\epsilon$            Method                                               \n",
       "\\multirow{2}{*}{0.01} FIFA        15.72170% 13.48116%           7.88627%   \n",
       "                      Vanilla     13.95614% 14.30009%           6.78607%   \n",
       "\\multirow{2}{*}{0.05} FIFA        13.56342% 13.54908%           5.70877%   \n",
       "                      Vanilla     14.46966% 14.86473%           7.59619%   \n",
       "\\multirow{2}{*}{0.10} FIFA        13.58569% 13.90430%           6.12168%   \n",
       "                      Vanilla     15.53416% 15.93873%           9.75137%   \n",
       "\n",
       "                                        DutchConsensus            \\\n",
       "                                         Combined Loss             \n",
       "                                   Test          Train      Test   \n",
       "$\\epsilon$            Method                                       \n",
       "\\multirow{2}{*}{0.01} FIFA     2.77756%      12.80131% 13.16857%   \n",
       "                      Vanilla  6.74747%      12.84442% 13.22665%   \n",
       "\\multirow{2}{*}{0.05} FIFA     4.93145%      12.88197% 13.22278%   \n",
       "                      Vanilla  7.85747%      12.88178% 13.22355%   \n",
       "\\multirow{2}{*}{0.10} FIFA     5.96891%      12.87168% 13.17477%   \n",
       "                      Vanilla 10.07504%      12.87569% 13.20988%   \n",
       "\n",
       "                                                           \n",
       "                              Fairness Violation           \n",
       "                                           Train     Test  \n",
       "$\\epsilon$            Method                               \n",
       "\\multirow{2}{*}{0.01} FIFA              3.72201% 4.35324%  \n",
       "                      Vanilla           3.79351% 4.43227%  \n",
       "\\multirow{2}{*}{0.05} FIFA              3.85249% 4.43227%  \n",
       "                      Vanilla           3.85249% 4.43227%  \n",
       "\\multirow{2}{*}{0.10} FIFA              3.83258% 4.35324%  \n",
       "                      Vanilla           3.83921% 4.40593%  "
      ]
     },
     "execution_count": 790,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "expg_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 780,
   "id": "private-cookie",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{llrrrrrrrr}\n",
      "\\toprule\n",
      "                      &         & \\multicolumn{4}{c}{AdultIncome} & \\multicolumn{4}{c}{DutchConsensus} \\\\\n",
      "                      &         & \\multicolumn{2}{c}{Combined Loss} & \\multicolumn{2}{c}{Fairness Violation} & \\multicolumn{2}{c}{Combined Loss} & \\multicolumn{2}{c}{Fairness Violation} \\\\\n",
      "                      &         &         Train &     Test &              Train &     Test &          Train &     Test &              Train &    Test \\\\\n",
      "$\\epsilon$ & Method &               &          &                    &          &                &          &                    &         \\\\\n",
      "\\midrule\n",
      "\\multirow{2}{*}{0.01} & FIFA &      15.7217% & 13.4812% &            7.8863% &  2.7776% &       12.8013% & 13.1686% &            3.7220% & 4.3532% \\\\\n",
      "                      & Vanilla &      13.9561% & 14.3001% &            6.7861% &  6.7475% &       12.8444% & 13.2267% &            3.7935% & 4.4323% \\\\\n",
      "\\multirow{2}{*}{0.05} & FIFA &      13.5634% & 13.5491% &            5.7088% &  4.9315% &       12.8820% & 13.2228% &            3.8525% & 4.4323% \\\\\n",
      "                      & Vanilla &      14.4697% & 14.8647% &            7.5962% &  7.8575% &       12.8818% & 13.2236% &            3.8525% & 4.4323% \\\\\n",
      "\\multirow{2}{*}{0.10} & FIFA &      13.5857% & 13.9043% &            6.1217% &  5.9689% &       12.8717% & 13.1748% &            3.8326% & 4.3532% \\\\\n",
      "                      & Vanilla &      15.5342% & 15.9387% &            9.7514% & 10.0750% &       12.8757% & 13.2099% &            3.8392% & 4.4059% \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(\n",
    "    expg_df.to_latex( multicolumn_format='c', escape=False)\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "together-latino",
   "metadata": {},
   "source": [
    "## CelebaA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1117,
   "id": "european-puppy",
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.options.display.float_format = '{:.2%}'.format"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1113,
   "id": "actual-newspaper",
   "metadata": {},
   "outputs": [],
   "source": [
    "bld_sweeps_df=pd.read_csv(\"./csv_data/blond_grid_search.csv\")\n",
    "bld_rep_sweeps_df = pd.read_csv(\"./csv_data/blond_grid_search_best_repeated.csv\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "19872f78-468e-4db4-8226-fcefd4fea6b5",
   "metadata": {},
   "source": [
    "#### Table 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1121,
   "id": "convenient-arkansas",
   "metadata": {},
   "outputs": [],
   "source": [
    "bld_eo_df = process_table(pd.concat([bld_sweeps_df,bld_rep_sweeps_df]), method_suffix='-GS', use_drw=0, \n",
    "                             show_gap=True,\n",
    "                             tuple_header=None,\n",
    "                          constraint='eo'\n",
    "                            )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 711,
   "id": "convenient-provider",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{llrrrrrrrrr}\n",
      "\\toprule\n",
      "               & \\$\\textbackslash epsilon\\$ & \\multicolumn{3}{c}{\\textbackslash multirow\\{3\\}\\{*\\}\\{0.01\\}} & \\multicolumn{3}{c}{\\textbackslash multirow\\{3\\}\\{*\\}\\{0.05\\}} & \\multicolumn{3}{c}{\\textbackslash multirow\\{3\\}\\{*\\}\\{0.10\\}} \\\\\n",
      "               & Method &               FIFA-GS & LDAM-GS & Vanilla-GS &               FIFA-GS & LDAM-GS & Vanilla-GS &               FIFA-GS & LDAM-GS & Vanilla-GS \\\\\n",
      "\\midrule\n",
      "Combined Loss & Train &                 7.37\\% &   5.22\\% &      7.14\\% &                 5.46\\% &   5.47\\% &      8.84\\% &                 5.92\\% &   8.48\\% &      8.90\\% \\\\\n",
      "               & Test &                 6.71\\% &   7.29\\% &     14.01\\% &                 6.34\\% &   7.38\\% &     13.05\\% &                 6.54\\% &   7.34\\% &     16.71\\% \\\\\n",
      "               & Gap &                 0.66\\% &   2.07\\% &      6.87\\% &                 0.88\\% &   1.91\\% &      4.21\\% &                 0.62\\% &   1.14\\% &      7.82\\% \\\\\n",
      "Fairness Violation & Train &                 5.31\\% &   2.32\\% &      6.69\\% &                 2.63\\% &   2.57\\% &      9.45\\% &                 3.11\\% &   6.93\\% &     11.37\\% \\\\\n",
      "               & Test &                 2.75\\% &   5.39\\% &     20.29\\% &                 3.29\\% &   5.57\\% &     17.92\\% &                 2.65\\% &   2.96\\% &     26.15\\% \\\\\n",
      "               & Gap &                 2.57\\% &   3.07\\% &     13.59\\% &                 0.66\\% &   3.00\\% &      8.47\\% &                 0.46\\% &   3.97\\% &     14.78\\% \\\\\n",
      "Balanced Error & Train &                 9.43\\% &   8.12\\% &      7.59\\% &                 8.29\\% &   8.36\\% &      8.22\\% &                 8.72\\% &  10.04\\% &      6.42\\% \\\\\n",
      "               & Test &                10.67\\% &   9.20\\% &      7.74\\% &                 9.39\\% &   9.19\\% &      8.17\\% &                10.43\\% &  11.72\\% &      7.27\\% \\\\\n",
      "               & Gap &                 1.25\\% &   1.07\\% &      0.15\\% &                 1.10\\% &   0.83\\% &      0.05\\% &                 1.70\\% &   1.68\\% &      0.85\\% \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(\n",
    "    bld_eo_df.T.to_latex( multicolumn_format='c')\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ced29e03-50eb-431c-a440-015a1c4b0ff4",
   "metadata": {},
   "source": [
    "#### Table 4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1151,
   "id": "southeast-syracuse",
   "metadata": {},
   "outputs": [],
   "source": [
    "bld_all_sweeps = pd.concat([bld_sweeps_df,bld_rep_sweeps_df])\n",
    "# grouping all experiments correspond to FIFA\n",
    "bld_all_sweeps['loss_type'] = bld_all_sweeps['loss_type'].apply(lambda s : 'standard' if s == 'standard' else 'fdam')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1162,
   "id": "continuing-improvement",
   "metadata": {},
   "outputs": [],
   "source": [
    "bld_eo_df = process_table(bld_all_sweeps, method_suffix='', use_drw=0, \n",
    "                          constraint='eo',\n",
    "                             show_gap=False,\n",
    "                             tuple_header='EO',\n",
    "                            )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1163,
   "id": "wicked-expense",
   "metadata": {},
   "outputs": [],
   "source": [
    "bld_dp_df = process_table(bld_all_sweeps, method_suffix='', use_drw=0, \n",
    "                             show_gap=False,\n",
    "                             tuple_header='DP',\n",
    "                          constraint='dp',\n",
    "\n",
    "                            )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1164,
   "id": "herbal-charlotte",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead 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></th>\n",
       "      <th colspan=\"4\" halign=\"left\">EO</th>\n",
       "      <th colspan=\"4\" halign=\"left\">DP</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th colspan=\"2\" halign=\"left\">Combined Loss</th>\n",
       "      <th colspan=\"2\" halign=\"left\">Fairness Violation</th>\n",
       "      <th colspan=\"2\" halign=\"left\">Combined Loss</th>\n",
       "      <th colspan=\"2\" halign=\"left\">Fairness Violation</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Train</th>\n",
       "      <th>Test</th>\n",
       "      <th>Train</th>\n",
       "      <th>Test</th>\n",
       "      <th>Train</th>\n",
       "      <th>Test</th>\n",
       "      <th>Train</th>\n",
       "      <th>Test</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>$\\epsilon$</th>\n",
       "      <th>Method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">\\multirow{2}{*}{0.01}</th>\n",
       "      <th>FIFA</th>\n",
       "      <td>7.37%</td>\n",
       "      <td>6.71%</td>\n",
       "      <td>5.31%</td>\n",
       "      <td>2.75%</td>\n",
       "      <td>8.65%</td>\n",
       "      <td>7.21%</td>\n",
       "      <td>4.84%</td>\n",
       "      <td>1.45%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Vanilla</th>\n",
       "      <td>7.14%</td>\n",
       "      <td>14.01%</td>\n",
       "      <td>6.69%</td>\n",
       "      <td>20.29%</td>\n",
       "      <td>10.74%</td>\n",
       "      <td>10.43%</td>\n",
       "      <td>4.72%</td>\n",
       "      <td>1.35%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">\\multirow{2}{*}{0.05}</th>\n",
       "      <th>FIFA</th>\n",
       "      <td>5.46%</td>\n",
       "      <td>6.34%</td>\n",
       "      <td>2.63%</td>\n",
       "      <td>3.29%</td>\n",
       "      <td>10.02%</td>\n",
       "      <td>9.40%</td>\n",
       "      <td>4.73%</td>\n",
       "      <td>1.07%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Vanilla</th>\n",
       "      <td>8.84%</td>\n",
       "      <td>13.05%</td>\n",
       "      <td>9.45%</td>\n",
       "      <td>17.92%</td>\n",
       "      <td>12.14%</td>\n",
       "      <td>11.60%</td>\n",
       "      <td>8.34%</td>\n",
       "      <td>5.17%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">\\multirow{2}{*}{0.10}</th>\n",
       "      <th>FIFA</th>\n",
       "      <td>5.92%</td>\n",
       "      <td>6.54%</td>\n",
       "      <td>3.11%</td>\n",
       "      <td>2.65%</td>\n",
       "      <td>9.04%</td>\n",
       "      <td>8.32%</td>\n",
       "      <td>2.98%</td>\n",
       "      <td>0.04%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Vanilla</th>\n",
       "      <td>8.90%</td>\n",
       "      <td>16.71%</td>\n",
       "      <td>11.37%</td>\n",
       "      <td>26.15%</td>\n",
       "      <td>12.13%</td>\n",
       "      <td>11.66%</td>\n",
       "      <td>9.77%</td>\n",
       "      <td>6.83%</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                         EO                                   \\\n",
       "                              Combined Loss        Fairness Violation          \n",
       "                                      Train   Test              Train   Test   \n",
       "$\\epsilon$            Method                                                   \n",
       "\\multirow{2}{*}{0.01} FIFA            7.37%  6.71%              5.31%  2.75%   \n",
       "                      Vanilla         7.14% 14.01%              6.69% 20.29%   \n",
       "\\multirow{2}{*}{0.05} FIFA            5.46%  6.34%              2.63%  3.29%   \n",
       "                      Vanilla         8.84% 13.05%              9.45% 17.92%   \n",
       "\\multirow{2}{*}{0.10} FIFA            5.92%  6.54%              3.11%  2.65%   \n",
       "                      Vanilla         8.90% 16.71%             11.37% 26.15%   \n",
       "\n",
       "                                         DP                                  \n",
       "                              Combined Loss        Fairness Violation        \n",
       "                                      Train   Test              Train  Test  \n",
       "$\\epsilon$            Method                                                 \n",
       "\\multirow{2}{*}{0.01} FIFA            8.65%  7.21%              4.84% 1.45%  \n",
       "                      Vanilla        10.74% 10.43%              4.72% 1.35%  \n",
       "\\multirow{2}{*}{0.05} FIFA           10.02%  9.40%              4.73% 1.07%  \n",
       "                      Vanilla        12.14% 11.60%              8.34% 5.17%  \n",
       "\\multirow{2}{*}{0.10} FIFA            9.04%  8.32%              2.98% 0.04%  \n",
       "                      Vanilla        12.13% 11.66%              9.77% 6.83%  "
      ]
     },
     "execution_count": 1164,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.concat([bld_eo_df,bld_dp_df],axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1165,
   "id": "flexible-compilation",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{llrrrrrrrr}\n",
      "\\toprule\n",
      "                      &         & \\multicolumn{4}{c}{EO} & \\multicolumn{4}{c}{DP} \\\\\n",
      "                      &         & \\multicolumn{2}{c}{Combined Loss} & \\multicolumn{2}{c}{Fairness Violation} & \\multicolumn{2}{c}{Combined Loss} & \\multicolumn{2}{c}{Fairness Violation} \\\\\n",
      "                      &         &         Train &   Test &              Train &   Test &         Train &   Test &              Train &  Test \\\\\n",
      "$\\epsilon$ & Method &               &        &                    &        &               &        &                    &       \\\\\n",
      "\\midrule\n",
      "\\multirow{2}{*}{0.01} & FIFA &         7.37% &  6.71% &              5.31% &  2.75% &         8.65% &  7.21% &              4.84% & 1.45% \\\\\n",
      "                      & Vanilla &         7.14% & 14.01% &              6.69% & 20.29% &        10.74% & 10.43% &              4.72% & 1.35% \\\\\n",
      "\\multirow{2}{*}{0.05} & FIFA &         5.46% &  6.34% &              2.63% &  3.29% &        10.02% &  9.40% &              4.73% & 1.07% \\\\\n",
      "                      & Vanilla &         8.84% & 13.05% &              9.45% & 17.92% &        12.14% & 11.60% &              8.34% & 5.17% \\\\\n",
      "\\multirow{2}{*}{0.10} & FIFA &         5.92% &  6.54% &              3.11% &  2.65% &         9.04% &  8.32% &              2.98% & 0.04% \\\\\n",
      "                      & Vanilla &         8.90% & 16.71% &             11.37% & 26.15% &        12.13% & 11.66% &              9.77% & 6.83% \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(\n",
    "    pd.concat([bld_eo_df,bld_dp_df],axis=1).to_latex( multicolumn_format='c',escape=False)\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "lyric-malawi",
   "metadata": {},
   "source": [
    "## Plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 290,
   "id": "familiar-allen",
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "\n",
    "sns.set()\n",
    "sns.set(font_scale=1.5,)\n",
    "sns.set_style(\"white\")\n",
    "sns.set_style({'font.family': 'Times New Roman'})\n",
    "sns.set_palette(\"colorblind\")\n",
    "\n",
    "\n",
    "plt.rcParams.update({'font.size': 20, 'lines.linewidth':4, 'lines.markersize':12, \n",
    "                         'xtick.labelsize':15, 'ytick.labelsize':15, 'axes.labelsize':20,\n",
    "                         'axes.titlesize': 20, 'legend.fontsize':20,\n",
    "                         'pdf.fonttype': 42, 'ps.fonttype':42,\n",
    "                        'image.interpolation':'nearest', 'figure.figsize': (6,4),\n",
    "                     'text.usetex': True\n",
    "                     \n",
    "                    })\n",
    "tqdm.tqdm.pandas()\n",
    "# logging.getLogger().setLevel(logging.CRITICAL)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "swiss-think",
   "metadata": {},
   "source": [
    "### Table 4: Covergage of $C$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "thorough-profit",
   "metadata": {},
   "outputs": [],
   "source": [
    "eo_C_df=(show_agg_df(bld_sweeps_df,added_cols=['max_m'])\n",
    " .query(\"constraint=='eo'\").query(\"use_drw==0\").query('loss_type!=\"standard\"')\n",
    " .reset_index()\n",
    " [['constraint', 'violation_eps', 'loss_type', 'max_m']]\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 781,
   "id": "alpha-investigation",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ax=plt.gca()\n",
    "\n",
    "\n",
    "\n",
    "sns.histplot(data=(bld_sweeps_df.drop_duplicates('exp_id')\n",
    "                   .query(\"constraint=='eo'\")\n",
    "                   .query(\"loss_type=='fdam'\").reset_index()\n",
    "                  ),\n",
    "             x='max_m',\n",
    "             stat='density',\n",
    "             color='C0',\n",
    "             bins=25,\n",
    "             log_scale=(True, False),\n",
    "             element='step',cumulative=True,\n",
    "             alpha=0.2,\n",
    "\n",
    "             ax=ax)\n",
    "\n",
    "sns.histplot(data=(bld_sweeps_df.drop_duplicates('exp_id')\n",
    "                   .query(\"constraint=='eo'\")\n",
    "                   .query(\"loss_type=='ldam'\").reset_index()\n",
    "                  ),\n",
    "             x='max_m',\n",
    "             stat='density',\n",
    "             color='C1',\n",
    "             bins=25,\n",
    "             log_scale=(True, False),\n",
    "             element='step',cumulative=True,\n",
    "             alpha=0.2,\n",
    "             ax=ax)\n",
    "for rid, row in eo_C_df.iterrows():\n",
    "\n",
    "    ax.axvline(x=row['max_m'], ymin=0., ymax = 1.5, linewidth=1.5, color=f\"C{0 if row['loss_type']=='fdam' else 1}\")\n",
    "\n",
    "\n",
    "ax.set_xlabel(r'$C$')\n",
    "ax.legend(title=r'\\textbf{Method}', loc='upper left', labels=['FIFA', 'LDAM'], fancybox=False, shadow=True)\n",
    "plt.title(r\"\\textbf{Histogram of $C$ in EO-Constrained Sweeps}\", fontsize=18)\n",
    "plt.tight_layout()\n",
    "plt.savefig('./figs/C_histogram.png', bbox_inches='tight')\n",
    "plt.savefig('./figs/C_histogram.pdf', bbox_inches='tight')\n",
    "# ax.set_ylabel(r'Combined Loss Generalization Gap')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 707,
   "id": "intended-cholesterol",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>loss_type</th>\n",
       "      <th>train_balanced_loss</th>\n",
       "      <th>test_balanced_loss</th>\n",
       "      <th>bal_loss_gap</th>\n",
       "      <th>train_violation</th>\n",
       "      <th>test_violation</th>\n",
       "      <th>violation_gap</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>157</th>\n",
       "      <td>ldam</td>\n",
       "      <td>5.47%</td>\n",
       "      <td>7.38%</td>\n",
       "      <td>1.91%</td>\n",
       "      <td>2.57%</td>\n",
       "      <td>5.57%</td>\n",
       "      <td>3.00%</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    loss_type  train_balanced_loss  test_balanced_loss  bal_loss_gap  \\\n",
       "157      ldam                5.47%               7.38%         1.91%   \n",
       "\n",
       "     train_violation  test_violation  violation_gap  \n",
       "157            2.57%           5.57%          3.00%  "
      ]
     },
     "execution_count": 707,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(rep_df.query('violation_eps==0.05').query('loss_type==\"ldam\"')[['loss_type',\n",
    "                                                                  'train_balanced_loss',\n",
    "                                                                 'test_balanced_loss', \n",
    "                                                                 'bal_loss_gap',\n",
    "                                                                 'train_violation',\n",
    "                                                                 'test_violation',\n",
    "                                                                 'violation_gap']]\n",
    " .query('test_balanced_loss < 0.0798')\n",
    "#  .sort_values('test_balanced_loss')\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "armed-exemption",
   "metadata": {},
   "source": [
    "### Figure 6: CelebA Generalization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 791,
   "id": "proper-carolina",
   "metadata": {},
   "outputs": [],
   "source": [
    "rep_df = (bld_rep_sweeps_df\n",
    "    .query(\"loss_type != 'ldam'\")\n",
    "    .rename({'test_balloss_cls_eo': 'test_balanced_loss',\n",
    "              'train_balloss_cls_eo': 'train_balanced_loss',\n",
    "              'test_eo': 'test_violation',\n",
    "              'train_eo': 'train_violation'\n",
    "             },axis=1)         \n",
    "    .assign(bal_acc_gap=lambda x :  x['train_cls_avg_acc'] - x['test_cls_avg_acc'] )\n",
    "    .assign(bal_loss_gap=lambda x :  x['test_balanced_loss'] - x['train_balanced_loss'] )\n",
    "    .assign(violation_gap=lambda x :  x['test_violation'] - x['train_violation'] )\n",
    "\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 782,
   "id": "corporate-closing",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for eps in [0.01, 0.05, 0.1]:\n",
    "    plt.figure()\n",
    "    ax = plt.gca()\n",
    "    for ls_idx, ls in enumerate(['standard', 'fdam']):\n",
    "        plt_dt = rep_df.query(rf\"violation_eps=={eps}\").query(rf\"loss_type=='{ls}'\").reset_index()\n",
    "        plt.scatter(plt_dt['train_balanced_loss'].values, plt_dt['train_violation'].values, \n",
    "                label=rf'{[\"Vanilla\", \"FIFA\"][ls_idx]} (Train)',\n",
    "                alpha=0.5,\n",
    "               color=f\"C{ls_idx}\",\n",
    "                   )\n",
    "        plt.scatter(plt_dt['test_balanced_loss'].values, plt_dt['test_violation'].values, \n",
    "                label=rf'{[\"Vanilla\", \"FIFA\"][ls_idx]} (Test)',\n",
    "                alpha=0.5,\n",
    "               color=f\"C{ls_idx}\", marker='+',\n",
    "                   )\n",
    "    ax.legend(ncol=1, fontsize=15, fancybox=False)\n",
    "    \n",
    "    ax.set_xlim(-0.005, 0.31)\n",
    "    ax.set_ylim(-0.05,0.61)\n",
    "\n",
    "    ax.set_xlabel(r\"Balanced Classification Error\")\n",
    "    ax.set_ylabel(r\"Fairness (EO) Violation\")\n",
    "\n",
    "    ax.set_title(r\"\\textbf{Pareto Frontier ($\\epsilon={\"+f\"{eps}\"+r\"}$)}\", fontsize=24)\n",
    "    plt.tight_layout()\n",
    "    plt.savefig('./figs/pareto_'+f'{eps}'+'.png', bbox_inches='tight')\n",
    "    plt.savefig('./figs/pareto_'+f'{eps}'+'.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5cc26392-3593-4474-8373-700c8a123756",
   "metadata": {},
   "source": [
    "### Figure 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 792,
   "id": "taken-party",
   "metadata": {},
   "outputs": [],
   "source": [
    "def viz_gap(data, col, title, ylabel='Generalization Gap', filename=None):\n",
    "    ax = plt.gca()\n",
    "    sns.lineplot(data=rep_df.reset_index(),\n",
    "                 x='violation_eps', \n",
    "                 y=col,\n",
    "                 hue='loss_type',\n",
    "                 style='loss_type',\n",
    "                 ci=95,\n",
    "                 err_style=\"bars\",\n",
    "                 ax=ax\n",
    "                )\n",
    "    ax.set_xlabel(r'$\\epsilon$')\n",
    "    ax.set_ylabel(rf'{ylabel}')\n",
    "    ax.legend(title=r'\\textbf{Method}', loc='upper right', labels=['Vanilla', 'FIFA'], fancybox=False, shadow=False)\n",
    "    plt.title(r'\\textbf{'+title+'}', fontsize=18)\n",
    "    plt.tight_layout()\n",
    "    if filename is not None:\n",
    "        plt.savefig(filename+'.png', bbox_inches='tight')\n",
    "        plt.savefig(filename+'.pdf', bbox_inches='tight')\n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 793,
   "id": "satellite-realtor",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "viz_gap(rep_df, 'test_balanced_loss', title='Test Combined Loss', ylabel='', filename='./figs/blond_test_comb_loss')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 794,
   "id": "dental-trial",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "viz_gap(rep_df, 'test_violation', title='Test Fairness Violation', ylabel='', filename='./figs/blond_test_fair')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 795,
   "id": "persistent-logging",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "viz_gap(rep_df, 'bal_acc_gap', 'Balanced Error Generalization Gap', ylabel='', filename='./figs/blond_bal_err_gap')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 796,
   "id": "unusual-scope",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZMAAAEDCAYAAADweukiAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAxwElEQVR4nO3dfXAb530n8C9IgiIlYQnZkizbXNlpJTIWoDQvkq+GOje1pYso9dKp2JzAqS+tOBWltolNzw2Zpp0IvYN8bcbkzYTqy1WEUvHuJlfCl2OaS8+EMpKTvmg9F7VJE+5alqPEtpa29S7sQiIlUuTeH+SuAGLxQi5eCPL7mdGI3H2w++DBcn94XtdlGIYBIiIiB6rKnQEiIqp8DCZEROQYgwkRETnGYEJERI4xmBARkWM15c7AYqHrOo4fP45Tp04BAERRBAAEg0G0tLQgEolAEAQEg8GS5UmSJIRCIWiaBr/fj5MnT2ZNrygKOjs7sXv3bnR3d5colzNCoRCGh4eh6zr6+vrQ0tKSNb0kSejt7YWu61BVFQAQCASgaRq6uroQCARKkW1HzGvmzTffhKZpaGhoAAC0tLQgGAyW5ZopFlVV0d7ebr3P06dPW/vKed0tpjwkW07XhsUgY3h42Ni2bZuxb98+Q5bllH39/f3Gvn37jKamJmNwcLDkebt06ZLR1NRkHDhwIGfa/v5+o6mpydi2bVsJcpbuyJEjRlNTkzE8PJz3awYHB8ua54Uy833gwAHj0qVLaft27txZtmummOw+q1Jed2fPnrXdXu5rP9lyvTaWfc0kFouhs7MTPp8PQ0NDafs7OjoAzHzzWezMbznl+lbv8XjKct5Si0ajCIVCCAQCtrVF83MIhUKlzlpZlOq603Udvb29tn+n5b72Tcv52ljWfSa6ruPIkSMAgEOHDmVM19HRAUEQSpWtBRMEAR0dHfD5fOXOypKlqqp1I+jq6sqYLhgMWk2lS12prrvh4eGy5yGb5X5tLOtgEo1Goes6BEHI2ca/Z8+eEuWKFrNYLAZgpk8t141r9+7dpcjSsqAoCnp7e8udjayW+7WxrJu5RkZGACCvbwlmc1cySZIQiUQgiiLi8TgSiYTVYQ886BTUNA2iKGJgYADHjx9HIpGAJEkIBAIIh8OIxWKQJAmqqkJVVYTD4bTquqZpiEQiUFUV8Xgco6OjCAaDVrU5Uwfp3Dz09fVhcHAQiUQCw8PD2LNnD8LhcMq5YrEYotEoPB4PEokEPB4Puru7U8rJfO8ejwderxcAEI/H8yt4B3KVuZlmcHDQym8ikUA8HsexY8fy2p+Nec3kU1PN1BGcrXwL/XmZgzhUVcXBgwexceNGxGIxaJqGo0ePwufzWd+ozfKQZRl+vx9dXV0532e2jvnm5mYIgoBnnnkGXq8XsixDURQIgoBz585Zr8917mg0ikgkAl3XoSgKWltbAcAaqJEtD8D8/07zKXM7Tq+NfMpi7qCcQCCAkZERJBIJaJqGPXv22N6rSqLcnTblZHaEvfDCC/N+rdnhl9xhb3aWv/LKK9Y2TdOMpqYmY+fOnUZ/f7+1/ZVXXrHOndypuG3btpRORPOYc88ly7LR1NRkHDlyJCVfdp2QyXlIzpuZh+QOc3Nb8rleeeWVlGOaHYzJHYiaplnlWawO+HzK3HyvyWRZtgYw5Nqfi5NrxjDyK99Cf17mtXLgwAFjcHDQOHv2bEqZmQMnzOsw+fxzZfqs5m7XNM3Ytm2boWlayu/J55nPuc3Ped++fbblmilvC/k7zVXmmTi9NvItC/PznFuW5t/SQs/v1LJu5lpoP4iqqujt7YXP50upzprV2xMnTljDXc1zqKqa8u1548aNAGa+FSfXQhoaGqDrOnRdTznn3HOZv0ej0ZyDA5Lz0NbWZm03axRmXlVVxYkTJ9Kq6W1tbdB1HZFIBMCDzsPkYY2CIBS18zPfMjffSygUgiRJAGbKymzDzrU/Fydt3fmWb6E/L/N4siwjGAwiEAigr68Phw8fBgCrhuv3+6305jd+81zzpWkannnmGevcnZ2d0HUdBw8eTLlOinFu00L/TrOVeTZO+0HyLQszrz6fL60sRVHEqVOnyjJgaFk3c/n9fiiKgtHR0ZxpdV23qsHmB2WOHU/W2NgIRVEgSVLaGHK7i23Lli0pv5sXiqZpOYOdeS5ZlvPueEzOg3l8s3kq+QLs6elJe62qqlaaUnUghkIhBINB648pnzI3g2w0GgUAqzkRSA3Cdvtz2bJlCyRJsr1mYrEY+vv7ASClnLZs2YJjx47lVb5zOf28Mh0r+YuNz+dDOByGqqqQJAmaplmvnfulJl+iKOLll18GAEQiEUiSBJ/Pl9a8U4xzmwrxdzq3zLNxcm0AhSkLURShquq87gmFsqyDSUtLS17f7AHg+PHj2LFjx4JvoothNFi+eRBFMe2P3vy91N94ZFlGV1fXvL6lDg0NWf1QsixDkiS0trZa7fS59mezd+9enDhxAoqiWIM3TC0tLdZNevv27dB1HR0dHbY3q0zlm6wQn1cyu5sq8KAdXhRFtLS0IBAIIBaLOa4ZCIJgdZwLgoCBgQEAM30gZpk4ObeqqgX/UuPk79TptVGsz6FUlnUzVyAQsD5Mu292Jl3X8cYbb1hVSjPi233I5rcSs6paTOa5CtW8ZB5HlmXb/YqiZH3vhaYoitVhm2+Zm52tLS0tCIfDGBoawsmTJ63O21z7c/H5fDh48CAA4Mtf/nLGdHbfJPMp3/koxPHMzmtBEHDy5MmCDlvVdR0HDhwAAPT19Vk3V7P5zem5c83VKPXfqZNro1Cfg3ktlGO+zbIOJgAQDocRDAZx4sQJhEKhtA/aHOlx9OhRa5soijh48KBVHU1OqyiK1dRSSHPbTSVJss5VqD9+QRDQ1dUFXdetJiDTiy++CE3TADwYQ28OhQRm/kDMeQBmOidUVcWBAwesG1C+Za7rOvr7+1PKyrxh5LM/H93d3Th48CBOnTqFF198Me1mFYvFbL/h5lu++SrE8exubGaTLuDss7TrJzGbb+Z7bvMaN8takqS0JuK5yvF3utBrYyGfg/k+TOZUh3LNY3EZBp+0CMxcpObQW7P67PF4IIoiDh8+bHsBmEMyAVjDMucOOTxy5Ij1gScPBY5Go9Z5zO2tra1QVRW6rludwqIoor29HUNDQ9awYnNo8KFDh6xzmcMKkzuVh4aGMuZhcHAQp06dSssD8GAopaZpaGxsBDDTqZv8bcdsA25sbITX64XH48Gbb74JSZKsm1y2dYfs1uYy/7Dnbkue8ZyrzOcOA/V6vYjH4zh8+DB8Pl/O/fMx95oRBAENDQ0IBALo6OhAJBJJ6yTNVb6F/rzMcjZreOZQ0+T3avYfNTQ0YMuWLfB6vWhpabGCwe7du9HW1pZ2fQ0MDEDTNNvrzlxZAngwp2J0dBSKokAURWv4bj7nNpvsYrEYent7rb/Nl19+GYIgZLz2871mFlLmxbg28i0LVVWxa9cuiKKI3bt3Z7wnlBqDCRFRBTGDSaYloMpl2TdzERGRcwwmRETkGIMJEVGFkCTJ6otSVdVaWmYxYJ8JERE5VjGTFu/evQtZlrFu3TpUV1eXOztERMvK1NQUrl27Br/fj7q6urT9FRNMZFnG888/X+5sEBEta1//+texbdu2tO05g4k5Icpc8yUQCGQdj6+qKnp6etLmJZizj4GZpZrn7s9l3bp11hvZsGFD3q8jIiLnLl++jOeff966F8+VM5h0dnYiHA5bMyrb29tTlkZIZgYLu4XOJEmy1tnXdR07d+7EwMBA3hPFzKatDRs2WBOziIiotDJ1M2QdzWXORE6emm8+cMdOIBBAIBBIW1BOURRrxUwA1kzcTMchIqLKkjWYyLKcVgPxeDzzDgI+nw99fX0p28wlBoiIqPLlrJnMrWWYaxnNV3L/iKqq1iMmiYio8uWctFiIFWDnCoVCGBgYYM2EiGiJyBpMBEFIWxrZXGl1oSKRCDo6Okr+FDAiouXquxevo/krr6P5K6/juxevF+UcWYOJ3+9Pq5nMfWb5fMRiMauTHijNA5aIiJa7zw+N4CfX7+An1+/gC0MjRTlHzpqJ3+9PuenLspwSDPINCOZzLpKfWVGOh94TES03b129bf18PunnQso5z6Svr8+atKhpGo4ePWr1dQwODiKRSFgPjDEnJsqybD0YJhgMWo+knGsxrcVPtJxdvHgRk5OT5c4GFclrrY+l/H7+/PmU391uNzZt2uToHBWz0OPo6Ch27tyJM2fOcNIiUYGdP38eTz31VLmzQUXyT2o85fdtojfl93w+/1z3YC5BT0REjjGYEBGRYwwmRETkGIMJERE5xmBCRESOMZgQEZFjDCZEVDaKoqC1tRW7du1Cc3Mzmpubc65KrqqqlXb79u1obW0t2OMsFEXBrl27sH37duzatasgx8wmFAph+/btaG5uRiwWK/r5ionBhIjKxufzYWhoCF1dXdbqGJFIJOtrIpGItQrHoUOHMDQ0tKAlnuwCkM/nw+nTp9PWJCyWcDi8ZFZPZzAhokVhz549EAQBkiRlXKbJvMl7PB5H59J1Hb29vY6OUShO30uy6WkDdyenoN+dxPU79/CBdhfv3hwr2PGzYTAhokXj0KFDAGaWarITjUYRDAYdn2d4eNjxMUrNMAxM3J/G7Xv3cXNsApcTd3Hp1jguXr+DN68k8C/va/jB+xrkywm8fe0O3r05jg/0u7h+Z6Ik+WMwIaJFwwwUr776qu3+kZERx4+vUBRl0dRKkk0ZBsYmphAfn8TV2/cwqo3jZzfu4K2rtzHyoY4fvK/hxx/qeOvqbfzsxhhG43dx9fY9xMcnMTYxhfvT5V0ZK+dCj0REpSIIAnbv3o1Tp06l1UIkScLevXtzHiMWiyEajcLj8SCRSMDj8aC7uxuiKCIajSISiVirlre2tgIAurq6bPtdVFW1FrQdHh7Gnj17rIVtk/MViUQgiiLi8TgSiQSCwSBaWlqsNNOGgcmpafzDP57FwF99DStXe7BqtYBpw7Ae8/HuzTG8eSWxoHJbDBhMiGhROXz4ME6dOoVIJJISTGKxWNqNfK6enh6cOHECQ0NDVg2mp6cHra2tOHfuHILBIAKBAHbt2mV1/meiaRoGBwfR3d0NYKZv48SJEwgEAlagiEQi6O3txavf+AY2NT2FialpvPueirZf24vPPv9b+PeHX8DE1DQmpwy8/rffxNe++hX89ktfwnP/dh8A4M7tBL78u7/lqLzmqq2uQm2Na+b/2X+X4uMFPYcdNnMRZVGKJ9RRKp/PB5/PB1VVrWceqaqas6NaVVWcOHECoiimNIW1tbVB1/Wco8Tm0nUdbW1tmJo2MD45hbrVM4/eUH7yM7xzcwx/9y9vobe3F09ubsakV8T5q7fx0xtjmFr9MJ7c3IxvfP2/4Z13L2Fyaqb56Wtf/QoAWIEEAFat9sD/ye1556mmyoWV7mp4691Yt7oWjzfU4SMPr0Tz+tXY+qgHn2pswMceE/DR9R783MOr0Oitx3rPinm974VizYQoC/MJdQDwhaERKF98tsw5Wh4OHTqEzs5OHD9+HMeOHcPg4CAOHz6c9TXJD9vr6elJ2283QsxsfpqYmuncnpia+We6USXgyvszzVDjqAUAfHDtJm7cmYA8e77Vnoa0465/9HG8+5MLkH/wfTz32D6885O3rO2ZuACsqJmpSayoqYK7erZ2UfOghlFd5cpaBuXEYEKURSmeUEfpWlpaIAgCTp06BVVVkUgkrIfy5SKKIrq7u2EYBu5PzwSLji+8hHv3pzEaH8elWzNDZccmpvCD0ZlAcfWD97H+sdQb/crVnoJ3artcwJp6d1KAcMFb7wYAfOShldj6aH7vcTFiMxcRLUr79+8HALS3t6d0Zie7P21Ycyp+zv9JAMCPfjwC+UMdP3xfw48+0PHmldu4eP0O/v7cD3E5cQ/a+H0AgIEHgcJsgpqPj2z6KADg6ofvo7rKhXp3NRrqarBuVS3iVz8EADz7i5/E1kc9+PVn/xUA4MoH7+Pn166C6K3HI54VWLOyFu7qmduwy7V4ax35WBbBhO3eRIubOaLJZBgG2n+7A8BMU9TPbf1kypyK+PjMI4YvJ+5Zcyp0oxZtHV/AndsJvPY3/xvJlYq+8B/gzuyER7MGcvXDDwAA8j9/H09ubs6YN5drpvlphbsaALC6thpPrKnHjo814UD7b+Pqh+9j/D0Fvg0ebF63Grc/fAdvv3UewWAQ2z/xC1hRU40qlwtdXV0AkLJsiq7r1pyXuWVQaZZFMxfbvYkWD8MwMDVtYGLKwI9lGf/5P/0RPnh/FADwzf/zt/iNQ1/AU5/YDsMAnvuVX4P/U09jNH4XAPD6334T/+/vX8fP3j5v/S7/8/fxmeDn4P/U0/hM8HP4yKZmfDv6P3Dm/37T6qPY+Sv74P/U01YeXgz9MQYjf44/+eILWO1ZjS988Qi89W68d/ECvvonMyPGxm4n8KdHXsLRcBjRv47i1KlTAICz3zsDY2Ic4XAYf/ClL+ITH/8YIpEIIpGINRy5r68vrTbV0dEBURTR39+P1157DV6vFx6PB36/H5IkWXNfCjEpsxyWxTPgq7q+nfL7dO9nCpk1WsKWy7VTyGfATxvJndnGzP+zv09OTePelIHpEk2wq3K5UofJJvVVmNuqFnGndqGU4hnwy6JmQkSFYXZqT9yfxr3Z4DB3JJQ5FLbYXC7AXVWVNVhUV7kqvi+iUjCYEJFlpvlpOiU4TNw3Hvw8NY1StWXUVCUPjU0fJuuuZqBYTBhMiJaJyalpvK/NLA6oauO4dGscl+LjGI2P4yV/Le6+r2GqZM1PSAkO7tnaxMz8isU/p4LS5Qwmuq4jGo1CFEWoqopAIJB1oTVVVdHT04O2traUtW7mexwiyp9hGLh+ZwJqfCZAPAgUd63fP0zczVir+PxTjxU0kJjBIbkmkdwcVcPmpyUnZzDp7OxEOByGKIoAZsZ89/X12U4gMh82Mzo66ug4RJRqbOI+1KTAYAYNdfbfpVvjuHt/OveBCqDabH6aGyxmA4a7ugpVDBSLSp27Cncnp62fiyFrMNF1HaqqWgEAmJldKkmS7SQisybS0JC6vMB8j0O0nExNG/hQzx4oboxNliQvLrP5yaY2YfZdVFcti+lpS8pGbz0u3Rq3fi6GrMFEluW0moPH45l3ECjUcYgqjWEYiI9PJgWKu2mB4n39bsn6Kh7xrMBGbz1Ebx1Ebz02rqmH2FCPDVW34HtMYPPTEiXUueF/1F3Uc+SsmcytZXi93oyP1Cz2cYgWm7uTUxg1O7XN/orZTm2z3+LOxFRJ8rJ6RfVsoKhPCRQb19Rjo7cejd46rKiptn3t+fOatawH0ULk7DMp1BT/Sl8qoFKZc1INA9ZKRIZhJP08+z+MpJ9TX/dgW460Scc0z2AYqcewO39K2qz5Tk1rd37bPOaRNlsZJXvpW3JKoLh6uzSPRK2ucqGxYbY24a2HOCdQiN46eOvdrFVQ2WQNJoIgQJ9dz8YUj8fh9XrndZJCHadQNv/JGQBzblJ532Tmc/Ozu2nP5+Y396adLV/p56LCO/YP7xTluGtX1T5oflqz0vp542wNY4OnjkNlaVHLGkz8fn9ajSKRSNg+3rIUx1mIG3fSvzn+9MZY0c9LZKp3Vz1ofrJqEvVWoGhsqMPKWk75osqWs2bi9/tTRmLJsmytfmn2eSSP0lrIcYppbLI07dW0PFW5gEeFuqTA8KDpaeOamdrFwytr2fxES17Or0N9fX3WZENN03D06FFrZNbg4CASiYT1XGZFUSBJEmRZRiQSgaqq1gqY2Y5TTGKRhsFVIpdr5mluMz+7kn6e/R+upJ9Tt1uvz5DW7phZz5WW1pW6P2u+7NK6bF6X57nmbEtO+8P3U5tn/3jvR1NqFo811LHjmgh5BBNBENDR0WG7r7u7O+V389nNdumzHafULvz+syk3HyD7DWXm/8w3pOSblnnMTDeqB/vtbn72588/rf1NmxZu7qrBX3puc5lyQsUUjUYRjUahKAoCgUDKBOu56UKhEHw+H7q6ugrWVK+qKmKxmHWPVFUVoVAIkiThwoULGbctJsuyoXbzutXlzgIRLSLBYBB79uzB9u3breeOZEqnKIrVGlMokiQhGo1awUQURZw8eRLNzQ8e2mW3bTFh/ZyICDOtJ4FAAIODg1nTFWNNwWAwiNOnTxf8uKXEYEJENCsYDFpPVLQTi8WwZ8+eEuaocjCYEBHNamlpgSAIiEajtvtVVeXitBksyz4TIsrPdy9ex+eHRvDW1dvlzkpWH12/Gn/euhXPblrr+Fh79uxBNBpNexa7qqppTVyxWAzAzAofly5dShmUpCgKent7IUkSzp07Z62qPjIygq1bt1rrEhaiYz1bPkqFNRMiyuh3vvHjRR9IAOCtq7fxO9/4cUGOZXayz107UJKklNFbkiTB5/OhpaUFwWAQW7duRXt7u7Xf5/Ph5MmTVtqWlha0tLSgu7sbnZ2dVjqzY32hcuWjVBhMiIiS+Hw+iKKYsyM+FoshEolYv7e0tFi1j7nmjg4TRRGKojjP7DzzUUwMJkSU0V9+9mN4av3iH0r/1PrV+MvPfqxgxwsGg3j11Vet3+fWSgCgo6MjrSnMbh1CIPcqIU7MJx/FxD4TIsro2U1roXzx2XJno+SCwaDV3xEIBKxHjSczaxeRSASCIEAUxYw38GJ22s8nH8XEYEJENEfynBO/35/2PCYAiEQikCQppb+jHCO9Fks+GEyIiGwEg0F0dnZi69attktB9fb2pk001HUdmqZZi9qW4qa+WPKxLPpMPprU5lsJ7b9EVH7mnBO7J8KazUjJNRZFUawmJk3TUm7gxWp2mm8+imlZBJM/b92KzWtXYfPaVfiz1q3lzg4RVYj9+/db80GSCYKAvr4+9Pb2IhaLQVEUCIKAcDiM1157DbquW/NHAODLX/4yFEWBruvo6emBqqpWn0xyulAolPbaUChkDVWeuy2ffJSKyzAq47l8o6Oj2LlzJ86cOYPGxsZyZ4eWiS2vfNeaZ/HU+tVLtjP6/PnzeOqpp8qdDSqTfD7/XPfgZVEzIVoo1mqJ8sMOeKIsnt20Fhe+9Fy5s0G06LFmQkREjjGYEBGRYwwmRETkGIMJERE5xmBCRESOMZgQEZFjDCZERORYznkmuq4jGo1CFEVrGea5j67MJ62u6xgeHrbSiqKYtqQzERFVppzBpLOzE+Fw2Hq4S3t7O/r6+mwXD8uWNhqNpqy82dPTA7/fX5alkomIqLCyNnOZC44lPyVMFEXbR0LmSptcKwEAr9druxonERFVnqzBRJbltJqDx+OxDSa50jY2NqK1tRWqqkJVVcTj8YzNZUREVFmyNnPpup72hLFMNYpcaY8dO4YXX3wRu3btQiAQSHkqGBFROfX09OCNN96AoigIBoPweDzWvjfffBOyLEMURQwNDdmmb2lpsfqA53us5Dzs3bu3Yr9k5+wz0TQt74NlSxuLxbBjxw60tbUhFAqhtbUVAwMD7DMhorLr7u5GNBpFb28vwuFw2n5VVdHe3p5X+vkey/Tqq68ikUjYvqYSZG3mEgQh7eEq8XgcXq93XmlVVcXIyAiCwSACgQBOnz6NxsZGHD9+3Pk7ICIqMlEUsXv37qIdS5Ik7N+/P61vuZJkDSZ+vz+ttpFIJGyH9GZLqygKtm5NfRbEyy+/jEQisdB8ExGV1I4dOwr25MK5x1JVFd3d3dB1HbFYrCDnKLWcNRO/35/SRyLLshVMzM70XGkDgUBap70sy7aPwyQiWiyS72d2X5gLdSyzv3n37t147bXXFnyOcsrZZ9LX12dNRNQ0DUePHrX6OQYHB1Pa+LKlDQaDiEQi1u8NDQ0MJkQV4p2v1jp6/UdemijpcQtFURRruoMgCI76eDMdS5Ik6wt6W1ubbX9KJcgZTARBSJlsmKy7uzvvtD6fr2JHKRDR8qPrOvr7+wvypTfbsczVQgAgEAhYk7yDwaDj85YSH9tLRDRL13X09PQAmLnJK4pS1GPpup4y0RsA9u/fj1gsxmBCRFSpBEFIaXGJRCJFPdbw8DAuXbqUEmhUVYUkSdB1vaKmTjCYEFFOxeqbKHafh1OFbJq3O1ZDQ0NadwEA7Nq1K209w8WOS9ATEWVQyJXN5x4rW81j9+7dFTfnhMGEiKgMhoeHMwartrY2KIpSUYvhMpgQEZVBts59URQhiiIGBwdLmCNnGEyIaNmLRCKIRqPQdR2hUChnx3tPT09K+uRJ2bmOJUkSWltbEY1GEY1GMx5fVVWcOHHC+nmxcxmGYZQ7E/kYHR3Fzp07cebMGTQ2NpY7O0RLyvnz5/HUU0+VOxtUJvl8/rnuwayZEBGRYwwmRETkGIMJERE5xmBCRESOMZgQEZFjDCZEROQYgwkRETnGYEJERI4xmBARkWMMJkRE5BiDCREROcaHYxER3G43zp8/X+5sUJm43W7Hx2AwISJs2rSp3FmgCsdmLiIicozBhIiIHMvZzKXrOqLRKERRhKqqCAQC8Pl8C0qrKAokSYIoitA0DcFgsHDvhIiIyiZnMOns7EQ4HIYoigCA9vZ29PX1QRCEeaVVFAXHjx/HsWPHAACtra3w+/0ZAxMREVWOrM1cuq5DVVUrOAAzzyZOfkRlvmmPHDmC7u5ua9/AwAADCRHREpE1mMiynFYD8Xg8tsEkW9rkQKMoClRVta3ZEBFRZcpZM2loaEjZ5vV6EY/H55VWlmU0NDQgFotZ/SmhUMh57omIaFHIOZpL07S8D5YprVkzCQQCEAQBgUAAqqoiFovln1MiIlq0sgYTQRCg63rKtng8Dq/XO6+0giBY/0yZ+l6IiKjyZA0mfr8/rbaRSCQQCATmldbv99se3+PxzDe/RES0COWsmfj9fqiqam2TZdkKJqqqWvuypRUEAc8880zavr179xb0zRARUXm4DMMwsiVInoioaVrK3JCenh4kEgmEw+GcaXVdx/Hjx61O+R07dtjWcDIZHR3Fzp07cebMGTQ2Ni70/RIR0QLkugfnDCaLBYMJEVH55LoHc20uoizG1e9BHdgCdWALxtXvlTk3RIsXgwlRFjdefwH34xdxP34RN777YrmzQ7RoMZgQZTF568KDn2++VcacEC1uDCZEROQYgwkRETnGYEJERI4xmBARkWMMJkRE5BiDCREROcZgQkREjjGYEBGRYwwmRETkGIMJERE5xmBCRESOMZgQEZFjDCZEROQYgwkRETnGYEJERI4xmBARkWMMJkRzGIaB+4lRjF96PW3f2DsxTN/TypArosWtptwZICqX6ckxTN56O+nfBetnY/KO7WuufOtX8dhvfB8r1n88bd9NKQRjcgzVK9ejeuUjM/9WPTLze/16uKrdRX5HROXDYELLijE1iSvf+jVM3LqAqcSlBR2jetUjtttvn/+fWY9ZVffwg0CzajbYJAWeusZ/jSr3ygXliSibcfV7uH7m9wAAa3f+BerFXy74ORhMaEmYvj/+oIZxc6aGsXbXf0WVe1VKOle1GxM3ZEzd+XCBZ3Khun5d2lbDMDA1djl7Hu/ewPTdG5i8ed52v9jxnm0wufHdl4CqmqTAsx7VqzawxkN5u/H6C7gfvzjz83dfRONv/rjg58gZTHRdRzQahSiKUFUVgUAAPp/PUVpJkqDrOlpaWpy/A1o2DMPA1J0PUgKG+fP9xCUARkr6hk/9B9vmKPeappzBxFUrwL2mCRNX/ill+8qf/1W4qtL/bKbvacDUxLzfU9IZMwaphPw1GFP3Mr6yqu6h2UCzwTbg1D/xb2zzTMvH5K0LD36++VZRzpHzCuvs7EQ4HIYoigCA9vZ29PX1QRCEBaXVdR2hUAgdHR2Feg+0RI29+x3cu3IuJXgYk7fzfv3krbczBJNm3B39OwAu1AhPwv1QM9xrmuBeM/v/Q02oXrkBLpcL73y1NuW1j3zmf9mey1Vdi7WfPoGpsauz/65g6s6Vmf/HrmJ6/DrmBrtkVfVrMwapbIEEAKbv3sT03ZsZbhIuPPliev+PYRi4duoAquvWzgaeRx7086xcj+qV6+GqrrU5HpG9rMFE13WoqmoFBwAQRRGSJKXVKvJNOzw8jEAgUKj856UU7YU0PzO1jA8xeettuNc0oWb1Y2lp9B/9BcbfeW3B50j+Npas4VMvQfiFw6jxbkJVTf2Cj5+syr0Sni2/mXG/MX0fU+PXZgPMVUyNXX4QeO5chitDPqbGrjjLV5Ygdeetv87+WqvGMyfQrNqA6lUbsPLJ3Y7yRktL1mAiy3JaDcTj8dgGk3zSSpKEQCAARVEKkfe8laK9kOxN37+L+/GfYPLmBUzMHTE1kQAArN11HB5/e9prax/66DyCydxaRhPqHt9hm9Lt3bTQt7Ngrqoa1Kx6FDWrHp3X66pXrndU46leud52ez5BKluNp6p+LZ44/EH6ayYSuH76d9P7dljjWfJy1kwaGhpStnm9XqiqOu+0uq5D1/WUmkuplKK9cDlLrmWk9mdcwH39PWS72QGZaxDuNU1p21y1npQmqdrZ4FHIWsZiUl23Jo8az3VM3bn8INhY/19Bzar0Gh8ATI1ddZavlfYj2u7f/gB33n4162uz9fHUCBtRLz7rKG9UHjn7TDQt/wla2dLa1WaoshiGAZfLlbZdO/cV3JL+aMHHzRRMVmx4GsLHX0ipbVSvetQ2D8vVTI1nA2pWbZjX69xrNmPtp7+WVONJDUbTY9eQvcZjH0zyCVLZajzuh31o/NwP07bf1y/h5j/+YVLgYR/PYpM1mAiCAF3XU7bF43F4vd55pVUUJeMIMFpczCGukzdTm6Qmb15A/ZO7sfa5Y2mvqWn4+QWdy+VebdUy7NSu9ePhX/4vCzo2ZVezagM8Wz6Xcb9V45nTrGYGntqH7f+ecw2PziVTkJrU351HjSd1/k71qkfg9m5C3eO/5ChvlF3WYOL3+9NqG4lEwrYDPVtaTdMgy7K1XZIkxONxAEAwGFxo3smBmb6MiykzvyfMEVMTuu1rMs2PsGuOesCFGuGJtNFS7jXNrGUsYik1nvQRyxmt2PC0wxpPcfp46sTn8Oivx9K237v2I2jnXklfsSCp1sMaT35y1kz8fn/KKC1ZltHV1QUAVn+IKIpZ087tmD979ix27NjBQFJiEzfP4+bff2m2L+NdwJie1+snb71tu929pmlmXoZ3k9UkVTsbOGrWbF6SfRlkzy08AXe+NZ6UAQUzP9c9Zj9ownkfj32Qmrz1Nu68bT/c21S1Yo3tigXVqx6B+6EtqHv0aUd5Wypy9pn09fVZExE1TcPRo0et4DA4OIhEIoFwOJwzrSkajeKNN95AIpFAQ0MD+1EKwLh/D5PaRas5ypi6hzXPpPdhuKpqMf7u8ILPM3XnMqYnEqiq9aRsr3KvxBO/e421DMppoX08K5/4NKp2/xWmx67ifvJotrEruD92JXeNJ8P58urjuXcL0/du2dZ4VjW3oe7R/562fVz9OyRG+rOMantkydV4cgYTQRAyTjDs7u7OO60pGAyyRrIAhmFgeuwqJsx+jKQZ4Pf1d1JqGS73anh/MZR2c68RngSqa3PO1Ha5V81plpr937s549pRDCRUTO41m+FesznjfmN6CtPj13E/qVktOfCs2LDd9nVO5/Fk6uOZuCHnV+OxWyJn5SOoXf9xrFj/CUd5KzWusbAIGcY0xn76rQcBY/b/6Yn8RtYZk7cxdefDtImArqpquL2bMHnjTQBAtWfjTHPUQ0mBY00Tqlc/zuBAFcVVVT3TFJVhEc5MVjcH4V7TlFbjMft6ctd4Mo1qy6OPx6zx2IxmFD75km0wuXPxb3DnwqupNZ05TXDlqvEwmJTBg1rG26h77BmbGcouXP/OobyDh53JW2/bzipfu/Mv4KpZCfeazWmLIBItN7UP+zKOTAPsazzJfTwr1n3c9nXF6uO5d+Wfcecn38j62pQaz2ygKQUGkyIypiYwGb+YNpFv8tbbmL4XBwA0/pacNhrK5XLB/VAz7l3+ft7nqvZsnO34nm2W8toP1617rLRL2RBVsoXWeISPHUbd479k28czNXYVU+PXsg6AyTyqbR59PBnmbxULg4lDhmFgevxaytBaM2Dc194BjKmsr5+4ecF2aK17TVNaMJmpUTSlTOKbaZ5iLYNoMVmx/hNZ+zzMGo8ZZO6PXcZ00pI5mefxOOvjKSYGE4eufvuzGPvZtxf8+kzDbeufbEFVrZA6+3v143C5+KRlokq30BqP9+k/xOqmfzdnaHXSfJ4cNZ5iYjBJkq2WseaZ/4jVzfvTXlPtaVzQucxaRlVt+lL+ALC6eb/t+Yho+ap79Gkgy7wWY3oK03dvpK3VdvMffr/oeVuWwcSYmsCk9tPUJUPMEVP3btm+ZvLmm7bbs8/+BqpXN6ZN5HM/1MxaBhEVnKuq2lqrLBmDSZG8+2cNOfsy5pq8ad8cVbumGa6a+jl9GGYn+GZU1a4uRJaJiBa1ZRlM5htIgMwr29aJz+KJz99iLWOJcq9ptj5790MfLXNuiBav5RlMsnBV1z2oZaQ8ztV+9q2rqrrEOaRSevi5P7We0vnws+krJhPRjGUbTKpXP267ZEiNR2Qtgyz14i9DPGDfX0ZEDyzLYPLE791IW6yQiIgWbll+BWcgISIqrGUZTIiIqLAYTIiIyDEGEyIicozBhIiIHGMwISIixxhMiIjIMQYTIiJyjMGEiIgcYzAhIlri3GuaH/xcpAVLGUyIiJa4h5/7U9R4N6HGu6loC5bmXJtL13VEo1GIoghVVREIBODz2T+fOFtaRVEgSRIAYGRkBG1tbQgEAgV8K0REZKcUC5bmDCadnZ0Ih8MQRREA0N7ejr6+PghC+uNms6WVJAkdHR0AZoLOzp07MTAwkDEwERFR5cjazKXrOlRVtYIDAIiiaNUw8k2rKAr6+/ut7YIgwO/32x6HiIgqT9ZgIstyWg3E4/HYBoFsaX0+H/r6+lL2qapqW7sphlJ0PhERLWc5ayYNDQ0p27xeL+Lx+LzTJvePqKoKTdOwZ8+eBWZ7fkrR+UREtJzl7DPRNC3vg+WbNhQKYWBgoGQ1Ez4tj4iouLLWTARBgK7rKdvi8Ti8Xu+C00YiEXR0dLDjnYhoCckaTPx+f1ptI5FI2A7pzSdtLBZDIBCwtqmquuCMExHR4pGzZuL3+1Nu+rIspwQDc1+utJIkQRAEq0ai6zoURSnsuyEiorLI2WfS19dnTUTUNA1Hjx61+joGBweRSCQQDoezplVVFe3t7WnHHhoaKvDbISKicnAZhmGUOxP5eO+99/DpT38aX//617Fhw4ZyZ4eIaFm5fPkynn/+eXznO9/BE088kbY/Z81ksbh27RoA4Pnnny9zToiIlq9r167ZBpOKqZncvXsXsixj3bp1qK6uLnd2iIiWlampKVy7dg1+vx91dXVp+ysmmBAR0eLFJeiJiMgxBhMiInKMwYSIiBxjMCEiIscYTIiIyDEGEyIicozBhIiIHKuYGfCLna7r1rpkqqoiEAhkXGY/W1pFUawnWY6MjKCtrc12leZKU6jySSZJEnRdR0tLS7GzX1SFLBvz+jHXxwsGg6V6G0VTqPLRdR3Dw8NWWlEUK/5vaz5lA8wsztvT05N2X5nvcWwZVBAHDhwwLl26lPK7pmnzTtvf329t1zTN2LZtmyHLcpFyXTqFKh+TpmnGzp07jcHBweJkuIQKVTayLBsvvPCCtW/fvn28djL8bRmGYbzyyisZj1Mp5lM2Z8+eNc6ePWvs27fPOHv27IKPkwmbuQpA13WoqgpRFK1toihaNYx80yqKgv7+fmu7uay/3XEqSaHKJ9nw8HDFf6sECls2R44cQXd3t7VvYGCg4h9CV8jySa6VADOPFa/kZyrNp2wAWM+Smvt49fkeJxMGkwKQZTntEcQej8f2w8iW1ufzoa+vL2Wfqqole7xxsRSqfEySJC2JQAIUrmySbwiKoiyJ6wYo7LXT2NiI1tZW6zlM8Xi8ooPtfMqmFMdhMCkAXdfTor3X60U8Hp932uSbpKqq0DQNe/bsKXieS6mQ5aPrOnRdT/kWVckKVTayLKOhoQGxWMxq9w6FQsXMekkU8to5duwYGhsbsWvXLoRCoZRaXCWaT9mU4jgMJgUy95HFhUgbCoUwMDCwJL5hFqp8JEmq+A73uQpRNmbNJBAIQBAEBAIBqKqKWCxWqGyWTaGunVgshh07duDkyZNQVRWtra3Qdb0QWSyb+ZRNsY/DYFIAgiCkXZTxeBxer3fBaSORCDo6Oiq6Gm4qVPkoirIkyiNZocpGEATrn2kh7d6LTaHKR1VVjIyMIBgMIhAI4PTp02hsbMTx48eLmf2imk/ZlOI4HBpcAH6/Py2yJxIJ23b9fNLGYrGUoXlzO8cqTaHKR9M0yLJsbZckyaqKV+oQ2EKVjd/vtz2+x+MpXGbLoFDloygKtm7dmrLv5ZdfRm9vb+EzXSLzKZtSHIc1kwIwR10ljwyRZdn6MMwOv3zSSpIEQRBSxsYrilKqt1IUhSqfQCCAYDBo/duyZQt27NhRsYEEKFzZCIKAZ555Jm3f3r17S/ROiqOQ187cWposyxXdZDqfsnFynHzx4VgFkjzpR9M0+P1+KyD09PQgkUggHA5nTauqKnbt2pV27KGhoYpv3ilE+SSLRqPo7e2F3+9HMBis6JtCocpG13UcP37c6jzdsWPHkhj1VqjyMSd0mk2BDQ0NFX3dAPMrG/P99/f3w+/3o6Wlxfoils/fXC4MJkRE5BibuYiIyDEGEyIicozBhIiIHGMwISIixxhMiIjIMQYTIiJyjMGEiIgcYzAhIiLHGEyIiMgxBhMiInKMwYSIiBzjEvREJaAoCqLRqPV7V1fXknjoGZGJwYSoyCKRCCRJQl9fHwMILVlcNZioiCRJQnt7O86dO8dAQksagwlREbW2tkJVVezfv9/a1tbWVtFPziSyw2BCVETNzc0Ih8MV/TRIonxwNBdRkbEWQssBgwlREYmiCF3Xy50NoqJjMCEqoq6uLrz22msp2xhcaClinwlRkcViMaiqao3mEkURgUCgzLkiKiwGEyIicozNXERE5BiDCREROcZgQkREjjGYEBGRYwwmRETkGIMJERE5xmBCRESOMZgQEZFjDCZEROQYgwkRETn2/wGCOb07YbcvVAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "viz_gap(rep_df, 'bal_loss_gap', 'Combined Loss Generalization Gap', ylabel='', filename='./figs/blond_comb_gap')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 797,
   "id": "short-screen",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "viz_gap(rep_df, 'violation_gap', 'Fairness Violation Generalization Gap', ylabel='', filename='./figs/blond_fair_gap')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "coordinated-toyota",
   "metadata": {},
   "source": [
    "### Figure 1: Teaser"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 489,
   "id": "involved-mainland",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.patches\n",
    "\n",
    "teaser_df = pd.read_csv('./csv_data/celeba_gen.csv',)\n",
    "teaser_df = teaser_df[teaser_df._step == teaser_df.groupby('train.eps')._step.transform('max')].reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 490,
   "id": "norwegian-level",
   "metadata": {},
   "outputs": [],
   "source": [
    "treaser_tr = teaser_df[['exp_id','train.eps', 'train.eo', 'train.err']].copy().rename({\n",
    "    'train.eps': 'eps',\n",
    "    'train.eo': 'EO Violation',\n",
    "    'train.err': 'Classification Error'\n",
    "},axis=1)\n",
    "treaser_tr['Data'] = 'Train'\n",
    "treaser_te = teaser_df[['exp_id','train.eps', 'test.eo', 'test.err']].copy().rename({\n",
    "    'train.eps': 'eps',\n",
    "    'test.eo': 'EO Violation',\n",
    "    'test.err': 'Classification Error'\n",
    "},axis=1)\n",
    "treaser_te['Data'] = 'Test'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 845,
   "id": "quality-qatar",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure()\n",
    "ax = plt.gca()\n",
    "plt.scatter(treaser_tr['Classification Error'].values, treaser_tr['EO Violation'].values, \n",
    "            label=r'Train',alpha=0.5, marker='o',\n",
    "           color='C0')\n",
    "plt.scatter(treaser_te['Classification Error'].values, treaser_te['EO Violation'].values, \n",
    "            label=r'Test',alpha=0.5, marker='+',\n",
    "           color='C1')\n",
    "ax.legend(loc=1, #bbox_to_anchor=(0.5, -0.05),\n",
    "          fancybox=False, shadow=True, \n",
    "          ncol=1)\n",
    "ax.set_xlim(-0.02,0.5)\n",
    "\n",
    "\n",
    "ax.set_xlabel(r\"Classification Error\")\n",
    "ax.set_ylabel(r\"Fairness (EO) Violation\")\n",
    "rect = matplotlib.patches.Rectangle((0.03, 0.54), 0.03, 0.09, linewidth=1, edgecolor='k', facecolor='none')\n",
    "ax.add_patch(rect)\n",
    "\n",
    "plt.plot([0.03, 0.096], [0.54, 0.341], 'k-', lw=1)\n",
    "plt.plot([0.06, 0.48618], [0.54, 0.34], 'k-', lw=1)\n",
    "\n",
    "inset_axes = mpl_toolkits.axes_grid.inset_locator.inset_axes(ax, \n",
    "                    width=\"75%\", # width = 30% of parent_bbox\n",
    "                    height=1.5, # height : 1 inch\n",
    "                    loc=4)\n",
    "inset_axes.scatter(treaser_te['Classification Error'].values, treaser_te['EO Violation'].values, \n",
    "            label=r'Test',alpha=0.5, marker='+',\n",
    "           color='C1')\n",
    "inset_axes.set_ylim([0.558,0.61])\n",
    "inset_axes.set_yticks([0.56,0.58,0.60])\n",
    "inset_axes.set_xticks([0.046, 0.0465, 0.047])\n",
    "inset_axes.xaxis.tick_top()\n",
    "inset_axes.tick_params(axis=\"both\",labelsize=10)\n",
    "\n",
    "\n",
    "\n",
    "# plt.tight_layout()\n",
    "plt.savefig('./figs/teaser'+'.png', bbox_inches='tight')\n",
    "plt.savefig('./figs/teaser'+'.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "static-adventure",
   "metadata": {},
   "source": [
    "## Figure 7: Trajectory"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1079,
   "id": "effective-acquisition",
   "metadata": {},
   "outputs": [],
   "source": [
    "def viz_traj(data, col, col_name, legend_loc=2, filename=None):\n",
    "    ax = plt.gca()\n",
    "    dt = (data.melt(id_vars=['exp_id','n_iters', 'loss_type'],\n",
    "                   value_vars=['train_'+col, 'test_'+col],\n",
    "        var_name='Split', value_name=col_name)\n",
    "          .rename({'loss_type':'Method'},axis=1)\n",
    "          .replace({'Split':{\n",
    "              'train_'+col:'Train',\n",
    "              'test_'+col: 'Test'\n",
    "          },  'Method': {\n",
    "              'standard':'Vanilla',\n",
    "              'fdam':'FIFA',\n",
    "          }\n",
    "                   })\n",
    "         )\n",
    "    sns.lineplot(data=dt.reset_index(),\n",
    "                 x='n_iters', \n",
    "                 y=col_name,\n",
    "                 hue='Method',\n",
    "                 style='Split',\n",
    "                 hue_order=['Vanilla','FIFA'],\n",
    "                 ci=95,\n",
    "                 err_style=\"bars\",\n",
    "                 ax=ax,\n",
    "                 lw=3,err_kws={'lw':1.5}\n",
    "                )\n",
    "    ax.set_xlabel(r'$t$')\n",
    "    ax.set_ylabel(col_name)\n",
    "    ax.set_xscale('log')\n",
    "#     ax.legend(title=r'\\textbf{Method}', loc='upper right', labels=['Vanilla', 'FIFA'], fancybox=False, shadow=False)\n",
    "    sns.move_legend(ax, legend_loc, ncol=2,fancybox=False, fontsize=14, title_fontsize=18)\n",
    "#     plt.title(r'\\textbf{'+title+'}', fontsize=18)\n",
    "    plt.tight_layout()\n",
    "    if filename is not None:\n",
    "        plt.savefig(filename+'.png', bbox_inches='tight')\n",
    "        plt.savefig(filename+'.pdf', bbox_inches='tight')\n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1080,
   "id": "interested-bargain",
   "metadata": {},
   "outputs": [],
   "source": [
    "traj_sweeps_df = pd.read_csv(\"./csv_data/trajectory.csv\", )\n",
    "traj_sweeps_df['train_bal_err']=1. - traj_sweeps_df['train_cls_avg_acc']\n",
    "traj_sweeps_df['test_bal_err']=1. - traj_sweeps_df['test_cls_avg_acc']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1089,
   "id": "prime-ecology",
   "metadata": {},
   "outputs": [],
   "source": [
    "traj_sweeps_df.loc[traj_sweeps_df._step==0, '_step']=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1091,
   "id": "french-reduction",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "viz_traj(traj_sweeps_df, 'acc', 'Total Accuracy', legend_loc=4, filename='./figs/traj_total_acc')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1092,
   "id": "behind-writing",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "viz_traj(traj_sweeps_df, 'bal_err', 'Balanced Classification Error', legend_loc=1, filename='./figs/traj_bal_err')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1093,
   "id": "based-binary",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "viz_traj(traj_sweeps_df, 'eo', 'Fairness (EO) Violation', legend_loc=2, filename='./figs/traj_eo')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1094,
   "id": "proprietary-bidding",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "viz_traj(traj_sweeps_df, 'balloss_cls_eo', 'Combined Loss', legend_loc=2, filename='./figs/traj_comb')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "favorite-increase",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "rubber-civilian",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
