{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import fairlib\n",
    "import torch\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:root:Unexpected args: ['--ip=127.0.0.1', '--stdin=9003', '--control=9001', '--hb=9000', '--Session.signature_scheme=\"hmac-sha256\"', '--Session.key=b\"1c3f633d-61c6-40ca-bf26-fac770577489\"', '--shell=9002', '--transport=\"tcp\"', '--iopub=9004']\n",
      "INFO:root:Logging to ./results/dev\\Moji\\knn\\output.log\n",
      "WARNING:root:Log file already exists, will append\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2022-09-20 11:15:42 [INFO ]  ======================================== 2022-09-20 11:15:42 ========================================\n",
      "2022-09-20 11:15:42 [INFO ]  Base directory is ./results/dev\\Moji\\knn\n",
      "2022-09-20 11:15:42 [WARNING]  ./results/dev\\Moji\\knn\\opt.yaml already exists, moved to ./results/dev\\Moji\\knn\\old_opts\\opt_2022_09_20__11_14_14.yaml\n",
      "{'Moji': {'emb_size': 2304, 'num_classes': 2, 'num_groups': 2}, 'Bios_both': {'emb_size': 768, 'num_classes': 28, 'num_groups': 4}, 'Bios_intersection': {'emb_size': 768, 'num_classes': 28, 'num_groups': 4}, 'Bios_gender': {'emb_size': 768, 'num_classes': 28, 'num_groups': 2}, 'Bios_economy': {'emb_size': 768, 'num_classes': 28, 'num_groups': 2}, 'Trustpilot_gender': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_age': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_country': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_intersection': {'emb_size': 768, 'num_classes': 5, 'num_groups': 8}, 'Adult_gender': {'emb_size': 101, 'num_classes': 2, 'num_groups': 2}, 'Adult_race': {'emb_size': 101, 'num_classes': 2, 'num_groups': 2}, 'Adult_intersection': {'emb_size': 101, 'num_classes': 2, 'num_groups': 4}, 'COMPAS_gender': {'emb_size': 447, 'num_classes': 2, 'num_groups': 2}, 'COMPAS_race': {'emb_size': 447, 'num_classes': 2, 'num_groups': 2}, 'COMPAS_intersection': {'emb_size': 447, 'num_classes': 2, 'num_groups': 4}, 'imSitu': {'emb_size': 2048, 'num_classes': 211, 'num_groups': 2}, 'MNIST': {'emb_size': 800, 'num_classes': 10, 'num_groups': 2, 'encoder_architecture': 'MNIST'}}\n",
      "Loaded data shapes: (99998, 2304), (99998,), (99998,)\n",
      "Loaded data shapes: (8000, 2304), (8000,), (8000,)\n",
      "Loaded data shapes: (7998, 2304), (7998,), (7998,)\n"
     ]
    }
   ],
   "source": [
    "args = {\n",
    "    # The name of the dataset, corresponding dataloader will be used,\n",
    "    \"dataset\":  \"Moji\",\n",
    "\n",
    "    # Give a name to the exp, which will be used in the path\n",
    "    \"exp_id\":\"knn\",\n",
    "}\n",
    "\n",
    "# Init the argument\n",
    "options = fairlib.BaseOptions()\n",
    "state = options.get_state(args=args, silence=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2022-09-20 11:15:43 [INFO ]  MLP( \n",
      "2022-09-20 11:15:43 [INFO ]    (output_layer): Linear(in_features=300, out_features=2, bias=True)\n",
      "2022-09-20 11:15:43 [INFO ]    (AF): Tanh()\n",
      "2022-09-20 11:15:43 [INFO ]    (hidden_layers): ModuleList(\n",
      "2022-09-20 11:15:43 [INFO ]      (0): Linear(in_features=2304, out_features=300, bias=True)\n",
      "2022-09-20 11:15:43 [INFO ]      (1): Tanh()\n",
      "2022-09-20 11:15:43 [INFO ]      (2): Linear(in_features=300, out_features=300, bias=True)\n",
      "2022-09-20 11:15:43 [INFO ]      (3): Tanh()\n",
      "2022-09-20 11:15:43 [INFO ]    )\n",
      "2022-09-20 11:15:43 [INFO ]    (criterion): CrossEntropyLoss()\n",
      "2022-09-20 11:15:43 [INFO ]  )\n",
      "2022-09-20 11:15:43 [INFO ]  Total number of parameters: 782402 \n",
      "\n"
     ]
    }
   ],
   "source": [
    "fairlib.utils.seed_everything(2022)\n",
    "\n",
    "# Init Model\n",
    "model = fairlib.networks.get_main_model(state)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2022-09-20 11:15:44 [INFO ]  Epoch:    0 [      0/  99998 ( 0%)]\tLoss: 0.6913\t Data Time: 0.02s\tTrain Time: 1.59s\n",
      "2022-09-20 11:15:45 [INFO ]  Epoch:    0 [  51200/  99998 (51%)]\tLoss: 0.3782\t Data Time: 0.51s\tTrain Time: 0.10s\n",
      "2022-09-20 11:15:46 [INFO ]  Evaluation at Epoch 0\n",
      "2022-09-20 11:15:46 [INFO ]  Validation accuracy: 71.97\tmacro_fscore: 71.93\tmicro_fscore: 71.97\tTPR_GAP: 38.58\tFPR_GAP: 38.58\tPPR_GAP: 37.95\t\n",
      "2022-09-20 11:15:46 [INFO ]  Test accuracy: 71.71\tmacro_fscore: 71.67\tmicro_fscore: 71.71\tTPR_GAP: 40.99\tFPR_GAP: 40.99\tPPR_GAP: 40.39\t\n",
      "2022-09-20 11:15:46 [INFO ]  Epoch:    1 [      0/  99998 ( 0%)]\tLoss: 0.3970\t Data Time: 0.02s\tTrain Time: 0.00s\n",
      "2022-09-20 11:15:47 [INFO ]  Epoch:    1 [  51200/  99998 (51%)]\tLoss: 0.3711\t Data Time: 0.55s\tTrain Time: 0.10s\n",
      "2022-09-20 11:15:47 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 11:15:47 [INFO ]  Evaluation at Epoch 1\n",
      "2022-09-20 11:15:47 [INFO ]  Validation accuracy: 72.04\tmacro_fscore: 72.02\tmicro_fscore: 72.04\tTPR_GAP: 39.06\tFPR_GAP: 39.06\tPPR_GAP: 38.47\t\n",
      "2022-09-20 11:15:47 [INFO ]  Test accuracy: 71.68\tmacro_fscore: 71.66\tmicro_fscore: 71.68\tTPR_GAP: 40.48\tFPR_GAP: 40.48\tPPR_GAP: 39.84\t\n",
      "2022-09-20 11:15:47 [INFO ]  Epoch:    2 [      0/  99998 ( 0%)]\tLoss: 0.3688\t Data Time: 0.02s\tTrain Time: 0.00s\n",
      "2022-09-20 11:15:48 [INFO ]  Epoch:    2 [  51200/  99998 (51%)]\tLoss: 0.3719\t Data Time: 0.51s\tTrain Time: 0.09s\n",
      "2022-09-20 11:15:49 [INFO ]  Epochs since last improvement: 2\n",
      "2022-09-20 11:15:49 [INFO ]  Evaluation at Epoch 2\n",
      "2022-09-20 11:15:49 [INFO ]  Validation accuracy: 71.84\tmacro_fscore: 71.78\tmicro_fscore: 71.84\tTPR_GAP: 39.81\tFPR_GAP: 39.81\tPPR_GAP: 38.97\t\n",
      "2022-09-20 11:15:49 [INFO ]  Test accuracy: 71.43\tmacro_fscore: 71.38\tmicro_fscore: 71.43\tTPR_GAP: 42.09\tFPR_GAP: 42.09\tPPR_GAP: 41.24\t\n",
      "2022-09-20 11:15:49 [INFO ]  Epoch:    3 [      0/  99998 ( 0%)]\tLoss: 0.3634\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 11:15:49 [INFO ]  Epoch:    3 [  51200/  99998 (51%)]\tLoss: 0.3575\t Data Time: 0.51s\tTrain Time: 0.09s\n",
      "2022-09-20 11:15:50 [INFO ]  Epochs since last improvement: 3\n",
      "2022-09-20 11:15:50 [INFO ]  Evaluation at Epoch 3\n",
      "2022-09-20 11:15:50 [INFO ]  Validation accuracy: 71.33\tmacro_fscore: 71.06\tmicro_fscore: 71.33\tTPR_GAP: 42.16\tFPR_GAP: 42.16\tPPR_GAP: 40.30\t\n",
      "2022-09-20 11:15:50 [INFO ]  Test accuracy: 71.11\tmacro_fscore: 70.88\tmicro_fscore: 71.11\tTPR_GAP: 43.72\tFPR_GAP: 43.72\tPPR_GAP: 42.04\t\n",
      "2022-09-20 11:15:50 [INFO ]  Epoch:    4 [      0/  99998 ( 0%)]\tLoss: 0.3521\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 11:15:51 [INFO ]  Epoch:    4 [  51200/  99998 (51%)]\tLoss: 0.3770\t Data Time: 0.52s\tTrain Time: 0.09s\n",
      "2022-09-20 11:15:52 [INFO ]  Epochs since last improvement: 4\n",
      "2022-09-20 11:15:52 [INFO ]  Evaluation at Epoch 4\n",
      "2022-09-20 11:15:52 [INFO ]  Validation accuracy: 71.78\tmacro_fscore: 71.70\tmicro_fscore: 71.78\tTPR_GAP: 41.59\tFPR_GAP: 41.59\tPPR_GAP: 40.65\t\n",
      "2022-09-20 11:15:52 [INFO ]  Test accuracy: 71.17\tmacro_fscore: 71.10\tmicro_fscore: 71.17\tTPR_GAP: 43.25\tFPR_GAP: 43.25\tPPR_GAP: 42.31\t\n",
      "2022-09-20 11:15:52 [INFO ]  Epoch:    5 [      0/  99998 ( 0%)]\tLoss: 0.4022\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 11:15:52 [INFO ]  Epoch:    5 [  51200/  99998 (51%)]\tLoss: 0.3662\t Data Time: 0.53s\tTrain Time: 0.10s\n",
      "2022-09-20 11:15:53 [INFO ]  Epochs since last improvement: 5\n",
      "2022-09-20 11:15:53 [INFO ]  Evaluation at Epoch 5\n",
      "2022-09-20 11:15:53 [INFO ]  Validation accuracy: 71.97\tmacro_fscore: 71.92\tmicro_fscore: 71.97\tTPR_GAP: 39.70\tFPR_GAP: 39.70\tPPR_GAP: 38.95\t\n",
      "2022-09-20 11:15:53 [INFO ]  Test accuracy: 71.76\tmacro_fscore: 71.70\tmicro_fscore: 71.76\tTPR_GAP: 41.43\tFPR_GAP: 41.43\tPPR_GAP: 40.64\t\n"
     ]
    }
   ],
   "source": [
    "model.train_self()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# KNN based labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "from fairlib.src.networks.knn_labels import KNN_labels\n",
    "from sklearn.metrics import mutual_info_score\n",
    "from collections import Counter\n",
    "\n",
    "import pandas as pd\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "criterion = torch.nn.CrossEntropyLoss()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def k1_ratio_analysis(knn_labels, group_labels, class_labels, metadata = {}, silence = True):\n",
    "    # Within a class, what is the ratio of being assigned knn label 1 of each group\n",
    "    tuple_g_labels = [(knn_g, g, y) for knn_g, g, y in zip(knn_labels, group_labels,class_labels)]\n",
    "    counts = Counter(tuple_g_labels)\n",
    "    \n",
    "    k1_y_g_ratio_list = []\n",
    "    for _y_label in set(class_labels):\n",
    "        for _g_label in set(group_labels):\n",
    "            k1_y_g_ratio = counts[(1, _g_label, _y_label)] / (counts[(1, _g_label, _y_label)]+counts[(0, _g_label, _y_label)])\n",
    "            if not silence:\n",
    "                print(\"Target class {}, protected group {}:\".format(_y_label, _g_label), k1_y_g_ratio)\n",
    "            \n",
    "            k1_y_g_ratio_dict = metadata.copy()\n",
    "            k1_y_g_ratio_dict[\"target\"] = _y_label\n",
    "            k1_y_g_ratio_dict[\"group\"] = _g_label\n",
    "            k1_y_g_ratio_dict[\"ratio\"] = k1_y_g_ratio\n",
    "            \n",
    "            k1_y_g_ratio_list.append(k1_y_g_ratio_dict)\n",
    "    return k1_y_g_ratio_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def vary_hyperparameters(criterion, tags, text, model, predictions, loss, batch, p = 2, k = 5, average_first = False):\n",
    "\n",
    "    knn_g_labels = KNN_labels(\n",
    "        criterion = criterion, tags = tags, text = text, model = model, \n",
    "        predictions = predictions, loss = loss, p = p, k = k, average_first = average_first)\n",
    "        \n",
    "    return list(knn_g_labels.detach().cpu().numpy()), list(batch[1].cpu().numpy()), list(batch[2].cpu().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def mutual_information_analysis(p, k, batch_iterator = state.train_generator):\n",
    "\n",
    "    knn_label_list = []\n",
    "    class_label_list = []\n",
    "    group_label_list = []\n",
    "    prediction_list = []\n",
    "\n",
    "    for batch in batch_iterator:\n",
    "\n",
    "        text = batch[0].squeeze()\n",
    "        tags = batch[1].long().squeeze()\n",
    "\n",
    "        text = text.to(state.device)\n",
    "        tags = tags.to(state.device)\n",
    "\n",
    "        predictions = model(text)\n",
    "        loss = criterion(predictions, tags)\n",
    "\n",
    "        knn_label, class_label, group_label = vary_hyperparameters(\n",
    "                criterion = criterion, tags = tags, text = text, model = model, loss = loss,\n",
    "                predictions = predictions, batch = batch, p = 2, k = 1,  average_first=True\n",
    "                )\n",
    "\n",
    "        # k1_ratio_analysis(\n",
    "        #     knn_labels = knn_label, \n",
    "        #     group_labels = group_label, \n",
    "        #     class_labels = class_label, metadata = {\"p\":p,\"k\":k}, silence = False)\n",
    "\n",
    "        knn_label_list = knn_label_list + knn_label\n",
    "        class_label_list = class_label_list + class_label\n",
    "        group_label_list = group_label_list + group_label\n",
    "        prediction_list = prediction_list + list(torch.argmax(predictions, axis=1).detach().cpu().numpy())\n",
    "\n",
    "    k1_y_g_ratio_list = k1_ratio_analysis(\n",
    "            knn_labels = knn_label_list, \n",
    "            group_labels = group_label_list, \n",
    "            class_labels = class_label_list, metadata = {\"p\":p,\"k\":k}, silence = False)\n",
    "\n",
    "\n",
    "    # knn_label = np.array(knn_label_list)\n",
    "    # class_label = np.array(class_label_list)\n",
    "    # group_label = np.array(group_label_list)\n",
    "\n",
    "    # z_y1_array = knn_label[class_label==1]\n",
    "    # g_y1_array = group_label[class_label==1]\n",
    "\n",
    "    # z_y0_array = knn_label[class_label==0]\n",
    "    # g_y0_array = group_label[class_label==0]\n",
    "\n",
    "    # mi1 = mutual_info_score(g_y1_array, z_y1_array)\n",
    "    # mi0 = mutual_info_score(g_y0_array, z_y0_array)\n",
    "    \n",
    "    # print(mi1, mi0)\n",
    "    # return mi1, mi0, pd.DataFrame(k1_y_g_ratio_list)\n",
    "\n",
    "    return pd.DataFrame(k1_y_g_ratio_list), knn_label_list, class_label_list, group_label_list, prediction_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Target class 0, protected group 0: 0.156975\n",
      "Target class 0, protected group 1: 0.6760676067606761\n",
      "Target class 1, protected group 0: 0.5915591559155916\n",
      "Target class 1, protected group 1: 0.180425\n"
     ]
    }
   ],
   "source": [
    "k1_y_g_ratio_list, knn_label, class_label, group_label, prediction = mutual_information_analysis(p=2, k=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "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>p</th>\n",
       "      <th>k</th>\n",
       "      <th>target</th>\n",
       "      <th>group</th>\n",
       "      <th>ratio</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2</td>\n",
       "      <td>14</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0.157850</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>14</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0.675368</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>14</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0.588759</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2</td>\n",
       "      <td>14</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.180575</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   p   k  target  group     ratio\n",
       "0  2  14       0      0  0.157850\n",
       "1  2  14       0      1  0.675368\n",
       "2  2  14       1      0  0.588759\n",
       "3  2  14       1      1  0.180575"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "k1_y_g_ratio_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "from fairlib.src.evaluators import gap_eval_scores, confusion_matrix_based_scores"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "_, confs = gap_eval_scores(\n",
    "    y_pred=prediction,\n",
    "    y_true=class_label, \n",
    "    protected_attribute=group_label,\n",
    "    args = model.args,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "metrics_group0 = confusion_matrix_based_scores(confs[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "metrics_group1 = confusion_matrix_based_scores(confs[1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "metrics_results = [metrics_group0, metrics_group1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'TPR': array([0.45954595, 0.92505   ]),\n",
       " 'TNR': array([0.92505   , 0.45954595]),\n",
       " 'PPV': array([0.60516265, 0.8725652 ]),\n",
       " 'NPV': array([0.8725652 , 0.60516265]),\n",
       " 'FPR': array([0.07495   , 0.54045405]),\n",
       " 'FNR': array([0.54045405, 0.07495   ]),\n",
       " 'FDR': array([0.39483735, 0.1274348 ]),\n",
       " 'ACC': array([0.83195664, 0.83195664]),\n",
       " 'PPR': array([0.15186304, 0.84813696])}"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "metrics_group1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "merics_y_g = []\n",
    "for _target_class in [0,1]:\n",
    "    for _group_class in [0,1]:\n",
    "        merics_y_g.append(\n",
    "            {\n",
    "                \"target\": _target_class,\n",
    "                \"group\":_group_class,\n",
    "                \"PPR\": metrics_results[_group_class]['PPR'][_target_class],\n",
    "                \"TPR\": metrics_results[_group_class]['TPR'][_target_class],\n",
    "                \"FPR\": metrics_results[_group_class]['FPR'][_target_class],\n",
    "                \"PPV\": metrics_results[_group_class]['PPV'][_target_class],\n",
    "                \"NPV\": metrics_results[_group_class]['NPV'][_target_class],\n",
    "            }\n",
    "        )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{rrrrrrr}\n",
      "\\toprule\n",
      " class &  group &      PPR &      TPR &      FPR &      PPV &      NPV \\\\\n",
      "\\midrule\n",
      "     0 &      0 & 0.808656 & 0.913475 & 0.389339 & 0.903715 & 0.638236 \\\\\n",
      "     0 &      1 & 0.151863 & 0.459546 & 0.074950 & 0.605163 & 0.872565 \\\\\n",
      "     1 &      0 & 0.191344 & 0.610661 & 0.086525 & 0.638236 & 0.903715 \\\\\n",
      "     1 &      1 & 0.848137 & 0.925050 & 0.540454 & 0.872565 & 0.605163 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(pd.DataFrame(merics_y_g).to_latex(index=False))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Target class 0, protected group 0: 0.15785\n",
      "Target class 0, protected group 1: 0.6752675267526753\n",
      "Target class 1, protected group 0: 0.5887588758875888\n",
      "Target class 1, protected group 1: 0.1807\n",
      "Target class 0, protected group 0: 0.15775\n",
      "Target class 0, protected group 1: 0.6738673867386739\n",
      "Target class 1, protected group 0: 0.5890589058905891\n",
      "Target class 1, protected group 1: 0.18\n",
      "Target class 0, protected group 0: 0.15815\n",
      "Target class 0, protected group 1: 0.6753675367536753\n",
      "Target class 1, protected group 0: 0.5905590559055905\n",
      "Target class 1, protected group 1: 0.180175\n",
      "Target class 0, protected group 0: 0.157425\n",
      "Target class 0, protected group 1: 0.6748674867486749\n",
      "Target class 1, protected group 0: 0.5892589258925892\n",
      "Target class 1, protected group 1: 0.17995\n",
      "Target class 0, protected group 0: 0.15805\n",
      "Target class 0, protected group 1: 0.6757675767576757\n",
      "Target class 1, protected group 0: 0.5905590559055905\n",
      "Target class 1, protected group 1: 0.1808\n",
      "Target class 0, protected group 0: 0.1582\n",
      "Target class 0, protected group 1: 0.6753675367536753\n",
      "Target class 1, protected group 0: 0.5895589558955896\n",
      "Target class 1, protected group 1: 0.179875\n",
      "Target class 0, protected group 0: 0.1583\n",
      "Target class 0, protected group 1: 0.6755675567556756\n",
      "Target class 1, protected group 0: 0.59005900590059\n",
      "Target class 1, protected group 1: 0.181125\n",
      "Target class 0, protected group 0: 0.1578\n",
      "Target class 0, protected group 1: 0.6751675167516752\n",
      "Target class 1, protected group 0: 0.5892589258925892\n",
      "Target class 1, protected group 1: 0.18105\n",
      "Target class 0, protected group 0: 0.157525\n",
      "Target class 0, protected group 1: 0.6761676167616761\n",
      "Target class 1, protected group 0: 0.5913591359135913\n",
      "Target class 1, protected group 1: 0.179725\n",
      "Target class 0, protected group 0: 0.157725\n",
      "Target class 0, protected group 1: 0.6757675767576757\n",
      "Target class 1, protected group 0: 0.588058805880588\n",
      "Target class 1, protected group 1: 0.180425\n",
      "Target class 0, protected group 0: 0.15775\n",
      "Target class 0, protected group 1: 0.673967396739674\n",
      "Target class 1, protected group 0: 0.5893589358935893\n",
      "Target class 1, protected group 1: 0.180475\n",
      "Target class 0, protected group 0: 0.157125\n",
      "Target class 0, protected group 1: 0.6756675667566757\n",
      "Target class 1, protected group 0: 0.5898589858985899\n",
      "Target class 1, protected group 1: 0.18065\n",
      "Target class 0, protected group 0: 0.1575\n",
      "Target class 0, protected group 1: 0.6756675667566757\n",
      "Target class 1, protected group 0: 0.5901590159015901\n",
      "Target class 1, protected group 1: 0.1801\n",
      "Target class 0, protected group 0: 0.15785\n",
      "Target class 0, protected group 1: 0.6753675367536753\n",
      "Target class 1, protected group 0: 0.5887588758875888\n",
      "Target class 1, protected group 1: 0.180575\n"
     ]
    }
   ],
   "source": [
    "k1_ratio_list = []\n",
    "\n",
    "for _k_value in range(1,15):\n",
    "    k1_y_g_ratio_list, _,_,_,_ = mutual_information_analysis(p=2, k=_k_value)\n",
    "    k1_ratio_list.append(k1_y_g_ratio_list)\n",
    "\n",
    "k1_ratio_df = pd.concat(k1_ratio_list).reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='k', ylabel='ratio'>"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.lineplot(\n",
    "    x = \"k\",\n",
    "    y=\"ratio\",\n",
    "    style=\"target\",\n",
    "    hue = \"group\",\n",
    "    data = k1_ratio_df\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2022-09-20 13:20:21 [INFO ]  Unexpected args: ['--ip=127.0.0.1', '--stdin=9003', '--control=9001', '--hb=9000', '--Session.signature_scheme=\"hmac-sha256\"', '--Session.key=b\"1c3f633d-61c6-40ca-bf26-fac770577489\"', '--shell=9002', '--transport=\"tcp\"', '--iopub=9004']\n",
      "2022-09-20 13:20:21 [INFO ]  Logging to ./results/dev\\Moji\\knn\\output.log\n",
      "2022-09-20 13:20:21 [WARNING]  Log file already exists, will append\n",
      "2022-09-20 13:20:21 [INFO ]  ======================================== 2022-09-20 13:20:21 ========================================\n",
      "2022-09-20 13:20:21 [INFO ]  Base directory is ./results/dev\\Moji\\knn\n",
      "2022-09-20 13:20:21 [WARNING]  ./results/dev\\Moji\\knn\\opt.yaml already exists, moved to ./results/dev\\Moji\\knn\\old_opts\\opt_2022_09_20__13_19_25.yaml\n",
      "{'Moji': {'emb_size': 2304, 'num_classes': 2, 'num_groups': 2}, 'Bios_both': {'emb_size': 768, 'num_classes': 28, 'num_groups': 4}, 'Bios_intersection': {'emb_size': 768, 'num_classes': 28, 'num_groups': 4}, 'Bios_gender': {'emb_size': 768, 'num_classes': 28, 'num_groups': 2}, 'Bios_economy': {'emb_size': 768, 'num_classes': 28, 'num_groups': 2}, 'Trustpilot_gender': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_age': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_country': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_intersection': {'emb_size': 768, 'num_classes': 5, 'num_groups': 8}, 'Adult_gender': {'emb_size': 101, 'num_classes': 2, 'num_groups': 2}, 'Adult_race': {'emb_size': 101, 'num_classes': 2, 'num_groups': 2}, 'Adult_intersection': {'emb_size': 101, 'num_classes': 2, 'num_groups': 4}, 'COMPAS_gender': {'emb_size': 447, 'num_classes': 2, 'num_groups': 2}, 'COMPAS_race': {'emb_size': 447, 'num_classes': 2, 'num_groups': 2}, 'COMPAS_intersection': {'emb_size': 447, 'num_classes': 2, 'num_groups': 4}, 'imSitu': {'emb_size': 2048, 'num_classes': 211, 'num_groups': 2}, 'MNIST': {'emb_size': 800, 'num_classes': 10, 'num_groups': 2, 'encoder_architecture': 'MNIST'}}\n",
      "Loaded data shapes: (99998, 2304), (99998,), (99998,)\n",
      "Loaded data shapes: (8000, 2304), (8000,), (8000,)\n",
      "Loaded data shapes: (7998, 2304), (7998,), (7998,)\n",
      "2022-09-20 13:20:21 [INFO ]  MLP( \n",
      "2022-09-20 13:20:21 [INFO ]    (output_layer): Linear(in_features=300, out_features=2, bias=True)\n",
      "2022-09-20 13:20:21 [INFO ]    (AF): Tanh()\n",
      "2022-09-20 13:20:21 [INFO ]    (hidden_layers): ModuleList(\n",
      "2022-09-20 13:20:21 [INFO ]      (0): Linear(in_features=2304, out_features=300, bias=True)\n",
      "2022-09-20 13:20:21 [INFO ]      (1): Tanh()\n",
      "2022-09-20 13:20:21 [INFO ]      (2): Linear(in_features=300, out_features=300, bias=True)\n",
      "2022-09-20 13:20:21 [INFO ]      (3): Tanh()\n",
      "2022-09-20 13:20:21 [INFO ]    )\n",
      "2022-09-20 13:20:21 [INFO ]    (criterion): CrossEntropyLoss()\n",
      "2022-09-20 13:20:21 [INFO ]  )\n",
      "2022-09-20 13:20:21 [INFO ]  Total number of parameters: 782402 \n",
      "\n",
      "2022-09-20 13:20:22 [INFO ]  Epoch:    0 [      0/  99998 ( 0%)]\tLoss: 0.6913\t Data Time: 0.02s\tTrain Time: 0.02s\n",
      "2022-09-20 13:20:22 [INFO ]  Epoch:    0 [  51200/  99998 (51%)]\tLoss: 0.3782\t Data Time: 0.54s\tTrain Time: 0.16s\n",
      "2022-09-20 13:20:23 [INFO ]  Evaluation at Epoch 0\n",
      "2022-09-20 13:20:23 [INFO ]  Validation accuracy: 71.97\tmacro_fscore: 71.93\tmicro_fscore: 71.97\tTPR_GAP: 38.58\tFPR_GAP: 38.58\tPPR_GAP: 37.95\t\n",
      "2022-09-20 13:20:23 [INFO ]  Test accuracy: 71.71\tmacro_fscore: 71.67\tmicro_fscore: 71.71\tTPR_GAP: 40.99\tFPR_GAP: 40.99\tPPR_GAP: 40.39\t\n",
      "2022-09-20 13:20:23 [INFO ]  Epoch:    1 [      0/  99998 ( 0%)]\tLoss: 0.3970\t Data Time: 0.02s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:24 [INFO ]  Epoch:    1 [  51200/  99998 (51%)]\tLoss: 0.3711\t Data Time: 0.52s\tTrain Time: 0.09s\n",
      "2022-09-20 13:20:24 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 13:20:24 [INFO ]  Evaluation at Epoch 1\n",
      "2022-09-20 13:20:24 [INFO ]  Validation accuracy: 72.04\tmacro_fscore: 72.02\tmicro_fscore: 72.04\tTPR_GAP: 39.06\tFPR_GAP: 39.06\tPPR_GAP: 38.47\t\n",
      "2022-09-20 13:20:24 [INFO ]  Test accuracy: 71.68\tmacro_fscore: 71.66\tmicro_fscore: 71.68\tTPR_GAP: 40.48\tFPR_GAP: 40.48\tPPR_GAP: 39.84\t\n",
      "2022-09-20 13:20:24 [INFO ]  Epoch:    2 [      0/  99998 ( 0%)]\tLoss: 0.3688\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:25 [INFO ]  Epoch:    2 [  51200/  99998 (51%)]\tLoss: 0.3719\t Data Time: 0.56s\tTrain Time: 0.11s\n",
      "2022-09-20 13:20:26 [INFO ]  Epochs since last improvement: 2\n",
      "2022-09-20 13:20:26 [INFO ]  Evaluation at Epoch 2\n",
      "2022-09-20 13:20:26 [INFO ]  Validation accuracy: 71.84\tmacro_fscore: 71.78\tmicro_fscore: 71.84\tTPR_GAP: 39.81\tFPR_GAP: 39.81\tPPR_GAP: 38.97\t\n",
      "2022-09-20 13:20:26 [INFO ]  Test accuracy: 71.43\tmacro_fscore: 71.38\tmicro_fscore: 71.43\tTPR_GAP: 42.09\tFPR_GAP: 42.09\tPPR_GAP: 41.24\t\n",
      "2022-09-20 13:20:26 [INFO ]  Epoch:    3 [      0/  99998 ( 0%)]\tLoss: 0.3634\t Data Time: 0.02s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:27 [INFO ]  Epoch:    3 [  51200/  99998 (51%)]\tLoss: 0.3575\t Data Time: 0.53s\tTrain Time: 0.10s\n",
      "2022-09-20 13:20:27 [INFO ]  Epochs since last improvement: 3\n",
      "2022-09-20 13:20:27 [INFO ]  Evaluation at Epoch 3\n",
      "2022-09-20 13:20:27 [INFO ]  Validation accuracy: 71.33\tmacro_fscore: 71.06\tmicro_fscore: 71.33\tTPR_GAP: 42.16\tFPR_GAP: 42.16\tPPR_GAP: 40.30\t\n",
      "2022-09-20 13:20:27 [INFO ]  Test accuracy: 71.11\tmacro_fscore: 70.88\tmicro_fscore: 71.11\tTPR_GAP: 43.72\tFPR_GAP: 43.72\tPPR_GAP: 42.04\t\n",
      "2022-09-20 13:20:27 [INFO ]  Epoch:    4 [      0/  99998 ( 0%)]\tLoss: 0.3521\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:28 [INFO ]  Epoch:    4 [  51200/  99998 (51%)]\tLoss: 0.3770\t Data Time: 0.54s\tTrain Time: 0.11s\n",
      "2022-09-20 13:20:29 [INFO ]  Epochs since last improvement: 4\n",
      "2022-09-20 13:20:29 [INFO ]  Evaluation at Epoch 4\n",
      "2022-09-20 13:20:29 [INFO ]  Validation accuracy: 71.78\tmacro_fscore: 71.70\tmicro_fscore: 71.78\tTPR_GAP: 41.59\tFPR_GAP: 41.59\tPPR_GAP: 40.65\t\n",
      "2022-09-20 13:20:29 [INFO ]  Test accuracy: 71.17\tmacro_fscore: 71.10\tmicro_fscore: 71.17\tTPR_GAP: 43.25\tFPR_GAP: 43.25\tPPR_GAP: 42.31\t\n",
      "2022-09-20 13:20:29 [INFO ]  Epoch:    5 [      0/  99998 ( 0%)]\tLoss: 0.4022\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:29 [INFO ]  Epoch:    5 [  51200/  99998 (51%)]\tLoss: 0.3662\t Data Time: 0.54s\tTrain Time: 0.10s\n",
      "2022-09-20 13:20:30 [INFO ]  Epochs since last improvement: 5\n",
      "2022-09-20 13:20:30 [INFO ]  Evaluation at Epoch 5\n",
      "2022-09-20 13:20:30 [INFO ]  Validation accuracy: 71.97\tmacro_fscore: 71.92\tmicro_fscore: 71.97\tTPR_GAP: 39.70\tFPR_GAP: 39.70\tPPR_GAP: 38.95\t\n",
      "2022-09-20 13:20:30 [INFO ]  Test accuracy: 71.76\tmacro_fscore: 71.70\tmicro_fscore: 71.76\tTPR_GAP: 41.43\tFPR_GAP: 41.43\tPPR_GAP: 40.64\t\n",
      "Target class 0, protected group 0: 0.156975\n",
      "Target class 0, protected group 1: 0.6760676067606761\n",
      "Target class 1, protected group 0: 0.5915591559155916\n",
      "Target class 1, protected group 1: 0.180425\n",
      "2022-09-20 13:20:43 [INFO ]  Unexpected args: ['--ip=127.0.0.1', '--stdin=9003', '--control=9001', '--hb=9000', '--Session.signature_scheme=\"hmac-sha256\"', '--Session.key=b\"1c3f633d-61c6-40ca-bf26-fac770577489\"', '--shell=9002', '--transport=\"tcp\"', '--iopub=9004']\n",
      "2022-09-20 13:20:43 [INFO ]  Logging to ./results/dev\\Moji\\knn\\output.log\n",
      "2022-09-20 13:20:43 [WARNING]  Log file already exists, will append\n",
      "2022-09-20 13:20:43 [INFO ]  ======================================== 2022-09-20 13:20:43 ========================================\n",
      "2022-09-20 13:20:43 [INFO ]  Base directory is ./results/dev\\Moji\\knn\n",
      "2022-09-20 13:20:43 [WARNING]  ./results/dev\\Moji\\knn\\opt.yaml already exists, moved to ./results/dev\\Moji\\knn\\old_opts\\opt_2022_09_20__13_20_21.yaml\n",
      "{'Moji': {'emb_size': 2304, 'num_classes': 2, 'num_groups': 2}, 'Bios_both': {'emb_size': 768, 'num_classes': 28, 'num_groups': 4}, 'Bios_intersection': {'emb_size': 768, 'num_classes': 28, 'num_groups': 4}, 'Bios_gender': {'emb_size': 768, 'num_classes': 28, 'num_groups': 2}, 'Bios_economy': {'emb_size': 768, 'num_classes': 28, 'num_groups': 2}, 'Trustpilot_gender': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_age': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_country': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_intersection': {'emb_size': 768, 'num_classes': 5, 'num_groups': 8}, 'Adult_gender': {'emb_size': 101, 'num_classes': 2, 'num_groups': 2}, 'Adult_race': {'emb_size': 101, 'num_classes': 2, 'num_groups': 2}, 'Adult_intersection': {'emb_size': 101, 'num_classes': 2, 'num_groups': 4}, 'COMPAS_gender': {'emb_size': 447, 'num_classes': 2, 'num_groups': 2}, 'COMPAS_race': {'emb_size': 447, 'num_classes': 2, 'num_groups': 2}, 'COMPAS_intersection': {'emb_size': 447, 'num_classes': 2, 'num_groups': 4}, 'imSitu': {'emb_size': 2048, 'num_classes': 211, 'num_groups': 2}, 'MNIST': {'emb_size': 800, 'num_classes': 10, 'num_groups': 2, 'encoder_architecture': 'MNIST'}}\n",
      "Loaded data shapes: (99998, 2304), (99998,), (99998,)\n",
      "Loaded data shapes: (8000, 2304), (8000,), (8000,)\n",
      "Loaded data shapes: (7998, 2304), (7998,), (7998,)\n",
      "2022-09-20 13:20:44 [INFO ]  MLP( \n",
      "2022-09-20 13:20:44 [INFO ]    (output_layer): Linear(in_features=300, out_features=2, bias=True)\n",
      "2022-09-20 13:20:44 [INFO ]    (AF): Tanh()\n",
      "2022-09-20 13:20:44 [INFO ]    (hidden_layers): ModuleList(\n",
      "2022-09-20 13:20:44 [INFO ]      (0): Linear(in_features=2304, out_features=300, bias=True)\n",
      "2022-09-20 13:20:44 [INFO ]      (1): Tanh()\n",
      "2022-09-20 13:20:44 [INFO ]      (2): Linear(in_features=300, out_features=300, bias=True)\n",
      "2022-09-20 13:20:44 [INFO ]      (3): Tanh()\n",
      "2022-09-20 13:20:44 [INFO ]    )\n",
      "2022-09-20 13:20:44 [INFO ]    (criterion): CrossEntropyLoss()\n",
      "2022-09-20 13:20:44 [INFO ]  )\n",
      "2022-09-20 13:20:44 [INFO ]  Total number of parameters: 782402 \n",
      "\n",
      "2022-09-20 13:20:44 [INFO ]  Epoch:    0 [      0/  99998 ( 0%)]\tLoss: 0.6933\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:45 [INFO ]  Epoch:    0 [  51200/  99998 (51%)]\tLoss: 0.3806\t Data Time: 0.69s\tTrain Time: 0.12s\n",
      "2022-09-20 13:20:45 [INFO ]  Evaluation at Epoch 0\n",
      "2022-09-20 13:20:45 [INFO ]  Validation accuracy: 72.55\tmacro_fscore: 72.43\tmicro_fscore: 72.55\tTPR_GAP: 38.27\tFPR_GAP: 38.27\tPPR_GAP: 37.10\t\n",
      "2022-09-20 13:20:45 [INFO ]  Test accuracy: 72.23\tmacro_fscore: 72.12\tmicro_fscore: 72.23\tTPR_GAP: 40.45\tFPR_GAP: 40.45\tPPR_GAP: 39.19\t\n",
      "2022-09-20 13:20:45 [INFO ]  Epoch:    1 [      0/  99998 ( 0%)]\tLoss: 0.3833\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:46 [INFO ]  Epoch:    1 [  51200/  99998 (51%)]\tLoss: 0.3749\t Data Time: 0.54s\tTrain Time: 0.10s\n",
      "2022-09-20 13:20:47 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 13:20:47 [INFO ]  Evaluation at Epoch 1\n",
      "2022-09-20 13:20:47 [INFO ]  Validation accuracy: 72.06\tmacro_fscore: 71.95\tmicro_fscore: 72.06\tTPR_GAP: 39.73\tFPR_GAP: 39.73\tPPR_GAP: 38.57\t\n",
      "2022-09-20 13:20:47 [INFO ]  Test accuracy: 71.89\tmacro_fscore: 71.79\tmicro_fscore: 71.89\tTPR_GAP: 41.25\tFPR_GAP: 41.25\tPPR_GAP: 40.11\t\n",
      "2022-09-20 13:20:47 [INFO ]  Epoch:    2 [      0/  99998 ( 0%)]\tLoss: 0.4101\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:47 [INFO ]  Epoch:    2 [  51200/  99998 (51%)]\tLoss: 0.3709\t Data Time: 0.51s\tTrain Time: 0.10s\n",
      "2022-09-20 13:20:48 [INFO ]  Epochs since last improvement: 2\n",
      "2022-09-20 13:20:48 [INFO ]  Evaluation at Epoch 2\n",
      "2022-09-20 13:20:48 [INFO ]  Validation accuracy: 71.55\tmacro_fscore: 71.53\tmicro_fscore: 71.55\tTPR_GAP: 39.74\tFPR_GAP: 39.74\tPPR_GAP: 39.20\t\n",
      "2022-09-20 13:20:48 [INFO ]  Test accuracy: 71.39\tmacro_fscore: 71.38\tmicro_fscore: 71.39\tTPR_GAP: 42.07\tFPR_GAP: 42.07\tPPR_GAP: 41.51\t\n",
      "2022-09-20 13:20:48 [INFO ]  Epoch:    3 [      0/  99998 ( 0%)]\tLoss: 0.3661\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:49 [INFO ]  Epoch:    3 [  51200/  99998 (51%)]\tLoss: 0.3693\t Data Time: 0.52s\tTrain Time: 0.10s\n",
      "2022-09-20 13:20:50 [INFO ]  Evaluation at Epoch 3\n",
      "2022-09-20 13:20:50 [INFO ]  Validation accuracy: 72.29\tmacro_fscore: 72.24\tmicro_fscore: 72.29\tTPR_GAP: 37.96\tFPR_GAP: 37.96\tPPR_GAP: 37.22\t\n",
      "2022-09-20 13:20:50 [INFO ]  Test accuracy: 72.38\tmacro_fscore: 72.34\tmicro_fscore: 72.38\tTPR_GAP: 39.21\tFPR_GAP: 39.21\tPPR_GAP: 38.44\t\n",
      "2022-09-20 13:20:50 [INFO ]  Epoch:    4 [      0/  99998 ( 0%)]\tLoss: 0.3741\t Data Time: 0.02s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:50 [INFO ]  Epoch:    4 [  51200/  99998 (51%)]\tLoss: 0.3888\t Data Time: 0.61s\tTrain Time: 0.10s\n",
      "2022-09-20 13:20:51 [INFO ]  Evaluation at Epoch 4\n",
      "2022-09-20 13:20:51 [INFO ]  Validation accuracy: 72.52\tmacro_fscore: 72.47\tmicro_fscore: 72.52\tTPR_GAP: 37.17\tFPR_GAP: 37.17\tPPR_GAP: 36.20\t\n",
      "2022-09-20 13:20:51 [INFO ]  Test accuracy: 72.48\tmacro_fscore: 72.42\tmicro_fscore: 72.48\tTPR_GAP: 39.16\tFPR_GAP: 39.16\tPPR_GAP: 38.14\t\n",
      "2022-09-20 13:20:51 [INFO ]  Epoch:    5 [      0/  99998 ( 0%)]\tLoss: 0.3653\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:52 [INFO ]  Epoch:    5 [  51200/  99998 (51%)]\tLoss: 0.3638\t Data Time: 0.51s\tTrain Time: 0.10s\n",
      "2022-09-20 13:20:52 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 13:20:52 [INFO ]  Evaluation at Epoch 5\n",
      "2022-09-20 13:20:53 [INFO ]  Validation accuracy: 72.52\tmacro_fscore: 72.43\tmicro_fscore: 72.52\tTPR_GAP: 37.96\tFPR_GAP: 37.96\tPPR_GAP: 36.80\t\n",
      "2022-09-20 13:20:53 [INFO ]  Test accuracy: 72.58\tmacro_fscore: 72.49\tmicro_fscore: 72.58\tTPR_GAP: 39.58\tFPR_GAP: 39.58\tPPR_GAP: 38.44\t\n",
      "2022-09-20 13:20:53 [INFO ]  Epoch:    6 [      0/  99998 ( 0%)]\tLoss: 0.3693\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:53 [INFO ]  Epoch:    6 [  51200/  99998 (51%)]\tLoss: 0.3700\t Data Time: 0.53s\tTrain Time: 0.14s\n",
      "2022-09-20 13:20:54 [INFO ]  Epochs since last improvement: 2\n",
      "2022-09-20 13:20:54 [INFO ]  Evaluation at Epoch 6\n",
      "2022-09-20 13:20:54 [INFO ]  Validation accuracy: 72.47\tmacro_fscore: 72.38\tmicro_fscore: 72.47\tTPR_GAP: 37.73\tFPR_GAP: 37.73\tPPR_GAP: 36.70\t\n",
      "2022-09-20 13:20:54 [INFO ]  Test accuracy: 72.51\tmacro_fscore: 72.42\tmicro_fscore: 72.51\tTPR_GAP: 39.54\tFPR_GAP: 39.54\tPPR_GAP: 38.59\t\n",
      "2022-09-20 13:20:54 [INFO ]  Epoch:    7 [      0/  99998 ( 0%)]\tLoss: 0.3750\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:55 [INFO ]  Epoch:    7 [  51200/  99998 (51%)]\tLoss: 0.3825\t Data Time: 0.51s\tTrain Time: 0.09s\n",
      "2022-09-20 13:20:55 [INFO ]  Epochs since last improvement: 3\n",
      "2022-09-20 13:20:55 [INFO ]  Evaluation at Epoch 7\n",
      "2022-09-20 13:20:55 [INFO ]  Validation accuracy: 72.74\tmacro_fscore: 72.65\tmicro_fscore: 72.74\tTPR_GAP: 37.75\tFPR_GAP: 37.75\tPPR_GAP: 36.72\t\n",
      "2022-09-20 13:20:55 [INFO ]  Test accuracy: 72.43\tmacro_fscore: 72.35\tmicro_fscore: 72.43\tTPR_GAP: 39.56\tFPR_GAP: 39.56\tPPR_GAP: 38.54\t\n",
      "2022-09-20 13:20:55 [INFO ]  Epoch:    8 [      0/  99998 ( 0%)]\tLoss: 0.3755\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:56 [INFO ]  Epoch:    8 [  51200/  99998 (51%)]\tLoss: 0.3966\t Data Time: 0.62s\tTrain Time: 0.11s\n",
      "2022-09-20 13:20:57 [INFO ]  Epochs since last improvement: 4\n",
      "2022-09-20 13:20:57 [INFO ]  Evaluation at Epoch 8\n",
      "2022-09-20 13:20:57 [INFO ]  Validation accuracy: 71.92\tmacro_fscore: 71.85\tmicro_fscore: 71.92\tTPR_GAP: 39.14\tFPR_GAP: 39.14\tPPR_GAP: 38.25\t\n",
      "2022-09-20 13:20:57 [INFO ]  Test accuracy: 72.01\tmacro_fscore: 71.94\tmicro_fscore: 72.01\tTPR_GAP: 41.58\tFPR_GAP: 41.58\tPPR_GAP: 40.84\t\n",
      "2022-09-20 13:20:57 [INFO ]  Epoch:    9 [      0/  99998 ( 0%)]\tLoss: 0.3276\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:20:57 [INFO ]  Epoch:    9 [  51200/  99998 (51%)]\tLoss: 0.3494\t Data Time: 0.51s\tTrain Time: 0.09s\n",
      "2022-09-20 13:20:58 [INFO ]  Epochs since last improvement: 5\n",
      "2022-09-20 13:20:58 [INFO ]  Evaluation at Epoch 9\n",
      "2022-09-20 13:20:58 [INFO ]  Validation accuracy: 71.80\tmacro_fscore: 71.67\tmicro_fscore: 71.80\tTPR_GAP: 40.24\tFPR_GAP: 40.24\tPPR_GAP: 39.05\t\n",
      "2022-09-20 13:20:58 [INFO ]  Test accuracy: 71.83\tmacro_fscore: 71.70\tmicro_fscore: 71.83\tTPR_GAP: 42.32\tFPR_GAP: 42.32\tPPR_GAP: 40.94\t\n",
      "Target class 0, protected group 0: 0.18885\n",
      "Target class 0, protected group 1: 0.7105710571057106\n",
      "Target class 1, protected group 0: 0.5467546754675467\n",
      "Target class 1, protected group 1: 0.14235\n",
      "2022-09-20 13:21:11 [INFO ]  Unexpected args: ['--ip=127.0.0.1', '--stdin=9003', '--control=9001', '--hb=9000', '--Session.signature_scheme=\"hmac-sha256\"', '--Session.key=b\"1c3f633d-61c6-40ca-bf26-fac770577489\"', '--shell=9002', '--transport=\"tcp\"', '--iopub=9004']\n",
      "2022-09-20 13:21:11 [INFO ]  Logging to ./results/dev\\Moji\\knn\\output.log\n",
      "2022-09-20 13:21:11 [WARNING]  Log file already exists, will append\n",
      "2022-09-20 13:21:11 [INFO ]  ======================================== 2022-09-20 13:21:11 ========================================\n",
      "2022-09-20 13:21:11 [INFO ]  Base directory is ./results/dev\\Moji\\knn\n",
      "2022-09-20 13:21:11 [WARNING]  ./results/dev\\Moji\\knn\\opt.yaml already exists, moved to ./results/dev\\Moji\\knn\\old_opts\\opt_2022_09_20__13_20_43.yaml\n",
      "{'Moji': {'emb_size': 2304, 'num_classes': 2, 'num_groups': 2}, 'Bios_both': {'emb_size': 768, 'num_classes': 28, 'num_groups': 4}, 'Bios_intersection': {'emb_size': 768, 'num_classes': 28, 'num_groups': 4}, 'Bios_gender': {'emb_size': 768, 'num_classes': 28, 'num_groups': 2}, 'Bios_economy': {'emb_size': 768, 'num_classes': 28, 'num_groups': 2}, 'Trustpilot_gender': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_age': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_country': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_intersection': {'emb_size': 768, 'num_classes': 5, 'num_groups': 8}, 'Adult_gender': {'emb_size': 101, 'num_classes': 2, 'num_groups': 2}, 'Adult_race': {'emb_size': 101, 'num_classes': 2, 'num_groups': 2}, 'Adult_intersection': {'emb_size': 101, 'num_classes': 2, 'num_groups': 4}, 'COMPAS_gender': {'emb_size': 447, 'num_classes': 2, 'num_groups': 2}, 'COMPAS_race': {'emb_size': 447, 'num_classes': 2, 'num_groups': 2}, 'COMPAS_intersection': {'emb_size': 447, 'num_classes': 2, 'num_groups': 4}, 'imSitu': {'emb_size': 2048, 'num_classes': 211, 'num_groups': 2}, 'MNIST': {'emb_size': 800, 'num_classes': 10, 'num_groups': 2, 'encoder_architecture': 'MNIST'}}\n",
      "Loaded data shapes: (99998, 2304), (99998,), (99998,)\n",
      "Loaded data shapes: (8000, 2304), (8000,), (8000,)\n",
      "Loaded data shapes: (7998, 2304), (7998,), (7998,)\n",
      "2022-09-20 13:21:12 [INFO ]  MLP( \n",
      "2022-09-20 13:21:12 [INFO ]    (output_layer): Linear(in_features=300, out_features=2, bias=True)\n",
      "2022-09-20 13:21:12 [INFO ]    (AF): Tanh()\n",
      "2022-09-20 13:21:12 [INFO ]    (hidden_layers): ModuleList(\n",
      "2022-09-20 13:21:12 [INFO ]      (0): Linear(in_features=2304, out_features=300, bias=True)\n",
      "2022-09-20 13:21:12 [INFO ]      (1): Tanh()\n",
      "2022-09-20 13:21:12 [INFO ]      (2): Linear(in_features=300, out_features=300, bias=True)\n",
      "2022-09-20 13:21:12 [INFO ]      (3): Tanh()\n",
      "2022-09-20 13:21:12 [INFO ]    )\n",
      "2022-09-20 13:21:12 [INFO ]    (criterion): CrossEntropyLoss()\n",
      "2022-09-20 13:21:12 [INFO ]  )\n",
      "2022-09-20 13:21:12 [INFO ]  Total number of parameters: 782402 \n",
      "\n",
      "2022-09-20 13:21:12 [INFO ]  Epoch:    0 [      0/  99998 ( 0%)]\tLoss: 0.6928\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:12 [INFO ]  Epoch:    0 [  51200/  99998 (51%)]\tLoss: 0.3908\t Data Time: 0.55s\tTrain Time: 0.13s\n",
      "2022-09-20 13:21:13 [INFO ]  Evaluation at Epoch 0\n",
      "2022-09-20 13:21:13 [INFO ]  Validation accuracy: 72.49\tmacro_fscore: 72.37\tmicro_fscore: 72.49\tTPR_GAP: 38.24\tFPR_GAP: 38.24\tPPR_GAP: 37.07\t\n",
      "2022-09-20 13:21:13 [INFO ]  Test accuracy: 72.19\tmacro_fscore: 72.08\tmicro_fscore: 72.19\tTPR_GAP: 40.57\tFPR_GAP: 40.57\tPPR_GAP: 39.31\t\n",
      "2022-09-20 13:21:13 [INFO ]  Epoch:    1 [      0/  99998 ( 0%)]\tLoss: 0.3968\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:14 [INFO ]  Epoch:    1 [  51200/  99998 (51%)]\tLoss: 0.4059\t Data Time: 0.51s\tTrain Time: 0.09s\n",
      "2022-09-20 13:21:14 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 13:21:14 [INFO ]  Evaluation at Epoch 1\n",
      "2022-09-20 13:21:14 [INFO ]  Validation accuracy: 72.21\tmacro_fscore: 72.04\tmicro_fscore: 72.21\tTPR_GAP: 39.15\tFPR_GAP: 39.15\tPPR_GAP: 37.72\t\n",
      "2022-09-20 13:21:14 [INFO ]  Test accuracy: 72.06\tmacro_fscore: 71.89\tmicro_fscore: 72.06\tTPR_GAP: 41.29\tFPR_GAP: 41.29\tPPR_GAP: 39.84\t\n",
      "2022-09-20 13:21:14 [INFO ]  Epoch:    2 [      0/  99998 ( 0%)]\tLoss: 0.4028\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:15 [INFO ]  Epoch:    2 [  51200/  99998 (51%)]\tLoss: 0.3591\t Data Time: 0.55s\tTrain Time: 0.12s\n",
      "2022-09-20 13:21:16 [INFO ]  Epochs since last improvement: 2\n",
      "2022-09-20 13:21:16 [INFO ]  Evaluation at Epoch 2\n",
      "2022-09-20 13:21:16 [INFO ]  Validation accuracy: 72.12\tmacro_fscore: 71.99\tmicro_fscore: 72.12\tTPR_GAP: 39.53\tFPR_GAP: 39.53\tPPR_GAP: 38.20\t\n",
      "2022-09-20 13:21:16 [INFO ]  Test accuracy: 72.14\tmacro_fscore: 72.02\tmicro_fscore: 72.14\tTPR_GAP: 40.91\tFPR_GAP: 40.91\tPPR_GAP: 39.46\t\n",
      "2022-09-20 13:21:16 [INFO ]  Epoch:    3 [      0/  99998 ( 0%)]\tLoss: 0.3944\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:17 [INFO ]  Epoch:    3 [  51200/  99998 (51%)]\tLoss: 0.3807\t Data Time: 0.63s\tTrain Time: 0.09s\n",
      "2022-09-20 13:21:17 [INFO ]  Epochs since last improvement: 3\n",
      "2022-09-20 13:21:17 [INFO ]  Evaluation at Epoch 3\n",
      "2022-09-20 13:21:17 [INFO ]  Validation accuracy: 72.09\tmacro_fscore: 71.93\tmicro_fscore: 72.09\tTPR_GAP: 39.78\tFPR_GAP: 39.78\tPPR_GAP: 38.27\t\n",
      "2022-09-20 13:21:17 [INFO ]  Test accuracy: 72.11\tmacro_fscore: 71.96\tmicro_fscore: 72.11\tTPR_GAP: 41.13\tFPR_GAP: 41.13\tPPR_GAP: 39.64\t\n",
      "2022-09-20 13:21:17 [INFO ]  Epoch:    4 [      0/  99998 ( 0%)]\tLoss: 0.4009\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:18 [INFO ]  Epoch:    4 [  51200/  99998 (51%)]\tLoss: 0.3829\t Data Time: 0.53s\tTrain Time: 0.14s\n",
      "2022-09-20 13:21:19 [INFO ]  Evaluation at Epoch 4\n",
      "2022-09-20 13:21:19 [INFO ]  Validation accuracy: 72.64\tmacro_fscore: 72.58\tmicro_fscore: 72.64\tTPR_GAP: 38.05\tFPR_GAP: 38.05\tPPR_GAP: 37.07\t\n",
      "2022-09-20 13:21:19 [INFO ]  Test accuracy: 72.54\tmacro_fscore: 72.49\tmicro_fscore: 72.54\tTPR_GAP: 39.81\tFPR_GAP: 39.81\tPPR_GAP: 38.91\t\n",
      "2022-09-20 13:21:19 [INFO ]  Epoch:    5 [      0/  99998 ( 0%)]\tLoss: 0.3518\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:19 [INFO ]  Epoch:    5 [  51200/  99998 (51%)]\tLoss: 0.3736\t Data Time: 0.51s\tTrain Time: 0.09s\n",
      "2022-09-20 13:21:20 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 13:21:20 [INFO ]  Evaluation at Epoch 5\n",
      "2022-09-20 13:21:20 [INFO ]  Validation accuracy: 71.60\tmacro_fscore: 71.53\tmicro_fscore: 71.60\tTPR_GAP: 41.91\tFPR_GAP: 41.91\tPPR_GAP: 41.00\t\n",
      "2022-09-20 13:21:20 [INFO ]  Test accuracy: 70.72\tmacro_fscore: 70.66\tmicro_fscore: 70.72\tTPR_GAP: 43.74\tFPR_GAP: 43.74\tPPR_GAP: 42.91\t\n",
      "2022-09-20 13:21:20 [INFO ]  Epoch:    6 [      0/  99998 ( 0%)]\tLoss: 0.3775\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:21 [INFO ]  Epoch:    6 [  51200/  99998 (51%)]\tLoss: 0.3652\t Data Time: 0.53s\tTrain Time: 0.12s\n",
      "2022-09-20 13:21:22 [INFO ]  Evaluation at Epoch 6\n",
      "2022-09-20 13:21:22 [INFO ]  Validation accuracy: 72.95\tmacro_fscore: 72.86\tmicro_fscore: 72.95\tTPR_GAP: 35.95\tFPR_GAP: 35.95\tPPR_GAP: 34.70\t\n",
      "2022-09-20 13:21:22 [INFO ]  Test accuracy: 72.79\tmacro_fscore: 72.70\tmicro_fscore: 72.79\tTPR_GAP: 37.73\tFPR_GAP: 37.73\tPPR_GAP: 36.51\t\n",
      "2022-09-20 13:21:22 [INFO ]  Epoch:    7 [      0/  99998 ( 0%)]\tLoss: 0.3839\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:22 [INFO ]  Epoch:    7 [  51200/  99998 (51%)]\tLoss: 0.3696\t Data Time: 0.60s\tTrain Time: 0.10s\n",
      "2022-09-20 13:21:23 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 13:21:23 [INFO ]  Evaluation at Epoch 7\n",
      "2022-09-20 13:21:23 [INFO ]  Validation accuracy: 71.79\tmacro_fscore: 71.68\tmicro_fscore: 71.79\tTPR_GAP: 40.59\tFPR_GAP: 40.59\tPPR_GAP: 39.57\t\n",
      "2022-09-20 13:21:23 [INFO ]  Test accuracy: 71.62\tmacro_fscore: 71.52\tmicro_fscore: 71.62\tTPR_GAP: 42.48\tFPR_GAP: 42.48\tPPR_GAP: 41.61\t\n",
      "2022-09-20 13:21:23 [INFO ]  Epoch:    8 [      0/  99998 ( 0%)]\tLoss: 0.3531\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:24 [INFO ]  Epoch:    8 [  51200/  99998 (51%)]\tLoss: 0.3708\t Data Time: 0.52s\tTrain Time: 0.10s\n",
      "2022-09-20 13:21:24 [INFO ]  Epochs since last improvement: 2\n",
      "2022-09-20 13:21:24 [INFO ]  Evaluation at Epoch 8\n",
      "2022-09-20 13:21:25 [INFO ]  Validation accuracy: 72.25\tmacro_fscore: 72.13\tmicro_fscore: 72.25\tTPR_GAP: 40.84\tFPR_GAP: 40.84\tPPR_GAP: 39.60\t\n",
      "2022-09-20 13:21:25 [INFO ]  Test accuracy: 71.61\tmacro_fscore: 71.50\tmicro_fscore: 71.61\tTPR_GAP: 42.18\tFPR_GAP: 42.18\tPPR_GAP: 40.99\t\n",
      "2022-09-20 13:21:25 [INFO ]  Epoch:    9 [      0/  99998 ( 0%)]\tLoss: 0.3884\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:25 [INFO ]  Epoch:    9 [  51200/  99998 (51%)]\tLoss: 0.3599\t Data Time: 0.54s\tTrain Time: 0.10s\n",
      "2022-09-20 13:21:26 [INFO ]  Epochs since last improvement: 3\n",
      "2022-09-20 13:21:26 [INFO ]  Evaluation at Epoch 9\n",
      "2022-09-20 13:21:26 [INFO ]  Validation accuracy: 71.06\tmacro_fscore: 70.79\tmicro_fscore: 71.06\tTPR_GAP: 42.52\tFPR_GAP: 42.52\tPPR_GAP: 40.67\t\n",
      "2022-09-20 13:21:26 [INFO ]  Test accuracy: 70.91\tmacro_fscore: 70.65\tmicro_fscore: 70.91\tTPR_GAP: 44.51\tFPR_GAP: 44.51\tPPR_GAP: 42.54\t\n",
      "2022-09-20 13:21:26 [INFO ]  Epoch:   10 [      0/  99998 ( 0%)]\tLoss: 0.3633\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:27 [INFO ]  Epoch:   10 [  51200/  99998 (51%)]\tLoss: 0.3619\t Data Time: 0.59s\tTrain Time: 0.10s\n",
      "2022-09-20 13:21:27 [INFO ]  Epochs since last improvement: 4\n",
      "2022-09-20 13:21:27 [INFO ]  Evaluation at Epoch 10\n",
      "2022-09-20 13:21:27 [INFO ]  Validation accuracy: 72.90\tmacro_fscore: 72.87\tmicro_fscore: 72.90\tTPR_GAP: 36.70\tFPR_GAP: 36.70\tPPR_GAP: 36.05\t\n",
      "2022-09-20 13:21:27 [INFO ]  Test accuracy: 72.52\tmacro_fscore: 72.48\tmicro_fscore: 72.52\tTPR_GAP: 38.50\tFPR_GAP: 38.50\tPPR_GAP: 37.71\t\n",
      "2022-09-20 13:21:27 [INFO ]  Epoch:   11 [      0/  99998 ( 0%)]\tLoss: 0.3603\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:28 [INFO ]  Epoch:   11 [  51200/  99998 (51%)]\tLoss: 0.3597\t Data Time: 0.54s\tTrain Time: 0.10s\n",
      "2022-09-20 13:21:29 [INFO ]  Epochs since last improvement: 5\n",
      "2022-09-20 13:21:29 [INFO ]  Evaluation at Epoch 11\n",
      "2022-09-20 13:21:29 [INFO ]  Validation accuracy: 72.44\tmacro_fscore: 72.34\tmicro_fscore: 72.44\tTPR_GAP: 37.95\tFPR_GAP: 37.95\tPPR_GAP: 36.72\t\n",
      "2022-09-20 13:21:29 [INFO ]  Test accuracy: 72.44\tmacro_fscore: 72.35\tmicro_fscore: 72.44\tTPR_GAP: 39.50\tFPR_GAP: 39.50\tPPR_GAP: 38.31\t\n",
      "Target class 0, protected group 0: 0.17135\n",
      "Target class 0, protected group 1: 0.6652665266526653\n",
      "Target class 1, protected group 0: 0.5090509050905091\n",
      "Target class 1, protected group 1: 0.13825\n",
      "2022-09-20 13:21:41 [INFO ]  Unexpected args: ['--ip=127.0.0.1', '--stdin=9003', '--control=9001', '--hb=9000', '--Session.signature_scheme=\"hmac-sha256\"', '--Session.key=b\"1c3f633d-61c6-40ca-bf26-fac770577489\"', '--shell=9002', '--transport=\"tcp\"', '--iopub=9004']\n",
      "2022-09-20 13:21:41 [INFO ]  Logging to ./results/dev\\Moji\\knn\\output.log\n",
      "2022-09-20 13:21:41 [WARNING]  Log file already exists, will append\n",
      "2022-09-20 13:21:41 [INFO ]  ======================================== 2022-09-20 13:21:41 ========================================\n",
      "2022-09-20 13:21:41 [INFO ]  Base directory is ./results/dev\\Moji\\knn\n",
      "2022-09-20 13:21:41 [WARNING]  ./results/dev\\Moji\\knn\\opt.yaml already exists, moved to ./results/dev\\Moji\\knn\\old_opts\\opt_2022_09_20__13_21_11.yaml\n",
      "{'Moji': {'emb_size': 2304, 'num_classes': 2, 'num_groups': 2}, 'Bios_both': {'emb_size': 768, 'num_classes': 28, 'num_groups': 4}, 'Bios_intersection': {'emb_size': 768, 'num_classes': 28, 'num_groups': 4}, 'Bios_gender': {'emb_size': 768, 'num_classes': 28, 'num_groups': 2}, 'Bios_economy': {'emb_size': 768, 'num_classes': 28, 'num_groups': 2}, 'Trustpilot_gender': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_age': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_country': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_intersection': {'emb_size': 768, 'num_classes': 5, 'num_groups': 8}, 'Adult_gender': {'emb_size': 101, 'num_classes': 2, 'num_groups': 2}, 'Adult_race': {'emb_size': 101, 'num_classes': 2, 'num_groups': 2}, 'Adult_intersection': {'emb_size': 101, 'num_classes': 2, 'num_groups': 4}, 'COMPAS_gender': {'emb_size': 447, 'num_classes': 2, 'num_groups': 2}, 'COMPAS_race': {'emb_size': 447, 'num_classes': 2, 'num_groups': 2}, 'COMPAS_intersection': {'emb_size': 447, 'num_classes': 2, 'num_groups': 4}, 'imSitu': {'emb_size': 2048, 'num_classes': 211, 'num_groups': 2}, 'MNIST': {'emb_size': 800, 'num_classes': 10, 'num_groups': 2, 'encoder_architecture': 'MNIST'}}\n",
      "Loaded data shapes: (99998, 2304), (99998,), (99998,)\n",
      "Loaded data shapes: (8000, 2304), (8000,), (8000,)\n",
      "Loaded data shapes: (7998, 2304), (7998,), (7998,)\n",
      "2022-09-20 13:21:42 [INFO ]  MLP( \n",
      "2022-09-20 13:21:42 [INFO ]    (output_layer): Linear(in_features=300, out_features=2, bias=True)\n",
      "2022-09-20 13:21:42 [INFO ]    (AF): Tanh()\n",
      "2022-09-20 13:21:42 [INFO ]    (hidden_layers): ModuleList(\n",
      "2022-09-20 13:21:42 [INFO ]      (0): Linear(in_features=2304, out_features=300, bias=True)\n",
      "2022-09-20 13:21:42 [INFO ]      (1): Tanh()\n",
      "2022-09-20 13:21:42 [INFO ]      (2): Linear(in_features=300, out_features=300, bias=True)\n",
      "2022-09-20 13:21:42 [INFO ]      (3): Tanh()\n",
      "2022-09-20 13:21:42 [INFO ]    )\n",
      "2022-09-20 13:21:42 [INFO ]    (criterion): CrossEntropyLoss()\n",
      "2022-09-20 13:21:42 [INFO ]  )\n",
      "2022-09-20 13:21:42 [INFO ]  Total number of parameters: 782402 \n",
      "\n",
      "2022-09-20 13:21:42 [INFO ]  Epoch:    0 [      0/  99998 ( 0%)]\tLoss: 0.6937\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:42 [INFO ]  Epoch:    0 [  51200/  99998 (51%)]\tLoss: 0.3629\t Data Time: 0.55s\tTrain Time: 0.12s\n",
      "2022-09-20 13:21:43 [INFO ]  Evaluation at Epoch 0\n",
      "2022-09-20 13:21:43 [INFO ]  Validation accuracy: 71.99\tmacro_fscore: 71.96\tmicro_fscore: 71.99\tTPR_GAP: 38.85\tFPR_GAP: 38.85\tPPR_GAP: 38.27\t\n",
      "2022-09-20 13:21:43 [INFO ]  Test accuracy: 71.89\tmacro_fscore: 71.87\tmicro_fscore: 71.89\tTPR_GAP: 40.61\tFPR_GAP: 40.61\tPPR_GAP: 40.01\t\n",
      "2022-09-20 13:21:43 [INFO ]  Epoch:    1 [      0/  99998 ( 0%)]\tLoss: 0.3923\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:44 [INFO ]  Epoch:    1 [  51200/  99998 (51%)]\tLoss: 0.4206\t Data Time: 0.51s\tTrain Time: 0.10s\n",
      "2022-09-20 13:21:44 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 13:21:44 [INFO ]  Evaluation at Epoch 1\n",
      "2022-09-20 13:21:45 [INFO ]  Validation accuracy: 72.20\tmacro_fscore: 72.13\tmicro_fscore: 72.20\tTPR_GAP: 39.32\tFPR_GAP: 39.32\tPPR_GAP: 38.40\t\n",
      "2022-09-20 13:21:45 [INFO ]  Test accuracy: 71.74\tmacro_fscore: 71.68\tmicro_fscore: 71.74\tTPR_GAP: 41.33\tFPR_GAP: 41.33\tPPR_GAP: 40.41\t\n",
      "2022-09-20 13:21:45 [INFO ]  Epoch:    2 [      0/  99998 ( 0%)]\tLoss: 0.3843\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:45 [INFO ]  Epoch:    2 [  51200/  99998 (51%)]\tLoss: 0.3848\t Data Time: 0.54s\tTrain Time: 0.11s\n",
      "2022-09-20 13:21:46 [INFO ]  Evaluation at Epoch 2\n",
      "2022-09-20 13:21:46 [INFO ]  Validation accuracy: 72.39\tmacro_fscore: 72.30\tmicro_fscore: 72.39\tTPR_GAP: 38.46\tFPR_GAP: 38.46\tPPR_GAP: 37.37\t\n",
      "2022-09-20 13:21:46 [INFO ]  Test accuracy: 71.94\tmacro_fscore: 71.85\tmicro_fscore: 71.94\tTPR_GAP: 40.71\tFPR_GAP: 40.71\tPPR_GAP: 39.51\t\n",
      "2022-09-20 13:21:46 [INFO ]  Epoch:    3 [      0/  99998 ( 0%)]\tLoss: 0.3509\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:47 [INFO ]  Epoch:    3 [  51200/  99998 (51%)]\tLoss: 0.3883\t Data Time: 0.51s\tTrain Time: 0.09s\n",
      "2022-09-20 13:21:47 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 13:21:47 [INFO ]  Evaluation at Epoch 3\n",
      "2022-09-20 13:21:48 [INFO ]  Validation accuracy: 72.02\tmacro_fscore: 71.80\tmicro_fscore: 72.02\tTPR_GAP: 39.56\tFPR_GAP: 39.56\tPPR_GAP: 37.90\t\n",
      "2022-09-20 13:21:48 [INFO ]  Test accuracy: 72.08\tmacro_fscore: 71.86\tmicro_fscore: 72.08\tTPR_GAP: 41.77\tFPR_GAP: 41.77\tPPR_GAP: 39.94\t\n",
      "2022-09-20 13:21:48 [INFO ]  Epoch:    4 [      0/  99998 ( 0%)]\tLoss: 0.3648\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:48 [INFO ]  Epoch:    4 [  51200/  99998 (51%)]\tLoss: 0.3914\t Data Time: 0.54s\tTrain Time: 0.13s\n",
      "2022-09-20 13:21:49 [INFO ]  Evaluation at Epoch 4\n",
      "2022-09-20 13:21:49 [INFO ]  Validation accuracy: 72.49\tmacro_fscore: 72.29\tmicro_fscore: 72.49\tTPR_GAP: 38.13\tFPR_GAP: 38.13\tPPR_GAP: 36.47\t\n",
      "2022-09-20 13:21:49 [INFO ]  Test accuracy: 72.52\tmacro_fscore: 72.31\tmicro_fscore: 72.52\tTPR_GAP: 40.02\tFPR_GAP: 40.02\tPPR_GAP: 38.11\t\n",
      "2022-09-20 13:21:49 [INFO ]  Epoch:    5 [      0/  99998 ( 0%)]\tLoss: 0.4224\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:50 [INFO ]  Epoch:    5 [  51200/  99998 (51%)]\tLoss: 0.3982\t Data Time: 0.51s\tTrain Time: 0.09s\n",
      "2022-09-20 13:21:50 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 13:21:50 [INFO ]  Evaluation at Epoch 5\n",
      "2022-09-20 13:21:50 [INFO ]  Validation accuracy: 72.11\tmacro_fscore: 72.10\tmicro_fscore: 72.11\tTPR_GAP: 38.48\tFPR_GAP: 38.48\tPPR_GAP: 38.02\t\n",
      "2022-09-20 13:21:50 [INFO ]  Test accuracy: 71.53\tmacro_fscore: 71.52\tmicro_fscore: 71.53\tTPR_GAP: 41.12\tFPR_GAP: 41.12\tPPR_GAP: 40.59\t\n",
      "2022-09-20 13:21:50 [INFO ]  Epoch:    6 [      0/  99998 ( 0%)]\tLoss: 0.3888\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:51 [INFO ]  Epoch:    6 [  51200/  99998 (51%)]\tLoss: 0.3723\t Data Time: 0.63s\tTrain Time: 0.12s\n",
      "2022-09-20 13:21:52 [INFO ]  Epochs since last improvement: 2\n",
      "2022-09-20 13:21:52 [INFO ]  Evaluation at Epoch 6\n",
      "2022-09-20 13:21:52 [INFO ]  Validation accuracy: 71.89\tmacro_fscore: 71.82\tmicro_fscore: 71.89\tTPR_GAP: 40.09\tFPR_GAP: 40.09\tPPR_GAP: 39.32\t\n",
      "2022-09-20 13:21:52 [INFO ]  Test accuracy: 71.48\tmacro_fscore: 71.42\tmicro_fscore: 71.48\tTPR_GAP: 42.15\tFPR_GAP: 42.15\tPPR_GAP: 41.34\t\n",
      "2022-09-20 13:21:52 [INFO ]  Epoch:    7 [      0/  99998 ( 0%)]\tLoss: 0.3796\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:52 [INFO ]  Epoch:    7 [  51200/  99998 (51%)]\tLoss: 0.3281\t Data Time: 0.52s\tTrain Time: 0.09s\n",
      "2022-09-20 13:21:53 [INFO ]  Epochs since last improvement: 3\n",
      "2022-09-20 13:21:53 [INFO ]  Evaluation at Epoch 7\n",
      "2022-09-20 13:21:53 [INFO ]  Validation accuracy: 72.45\tmacro_fscore: 72.39\tmicro_fscore: 72.45\tTPR_GAP: 38.75\tFPR_GAP: 38.75\tPPR_GAP: 37.85\t\n",
      "2022-09-20 13:21:53 [INFO ]  Test accuracy: 71.94\tmacro_fscore: 71.88\tmicro_fscore: 71.94\tTPR_GAP: 41.02\tFPR_GAP: 41.02\tPPR_GAP: 40.11\t\n",
      "2022-09-20 13:21:53 [INFO ]  Epoch:    8 [      0/  99998 ( 0%)]\tLoss: 0.3699\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:54 [INFO ]  Epoch:    8 [  51200/  99998 (51%)]\tLoss: 0.3877\t Data Time: 0.53s\tTrain Time: 0.12s\n",
      "2022-09-20 13:21:55 [INFO ]  Epochs since last improvement: 4\n",
      "2022-09-20 13:21:55 [INFO ]  Evaluation at Epoch 8\n",
      "2022-09-20 13:21:55 [INFO ]  Validation accuracy: 70.95\tmacro_fscore: 70.85\tmicro_fscore: 70.95\tTPR_GAP: 43.17\tFPR_GAP: 43.17\tPPR_GAP: 42.25\t\n",
      "2022-09-20 13:21:55 [INFO ]  Test accuracy: 70.62\tmacro_fscore: 70.53\tmicro_fscore: 70.62\tTPR_GAP: 45.08\tFPR_GAP: 45.08\tPPR_GAP: 44.11\t\n",
      "2022-09-20 13:21:55 [INFO ]  Epoch:    9 [      0/  99998 ( 0%)]\tLoss: 0.3634\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:21:55 [INFO ]  Epoch:    9 [  51200/  99998 (51%)]\tLoss: 0.3513\t Data Time: 0.53s\tTrain Time: 0.10s\n",
      "2022-09-20 13:21:56 [INFO ]  Epochs since last improvement: 5\n",
      "2022-09-20 13:21:56 [INFO ]  Evaluation at Epoch 9\n",
      "2022-09-20 13:21:56 [INFO ]  Validation accuracy: 71.80\tmacro_fscore: 71.72\tmicro_fscore: 71.80\tTPR_GAP: 40.53\tFPR_GAP: 40.53\tPPR_GAP: 39.60\t\n",
      "2022-09-20 13:21:56 [INFO ]  Test accuracy: 71.48\tmacro_fscore: 71.40\tmicro_fscore: 71.48\tTPR_GAP: 43.07\tFPR_GAP: 43.07\tPPR_GAP: 42.09\t\n",
      "Target class 0, protected group 0: 0.1609\n",
      "Target class 0, protected group 1: 0.6863686368636863\n",
      "Target class 1, protected group 0: 0.5582558255825583\n",
      "Target class 1, protected group 1: 0.14475\n",
      "2022-09-20 13:22:09 [INFO ]  Unexpected args: ['--ip=127.0.0.1', '--stdin=9003', '--control=9001', '--hb=9000', '--Session.signature_scheme=\"hmac-sha256\"', '--Session.key=b\"1c3f633d-61c6-40ca-bf26-fac770577489\"', '--shell=9002', '--transport=\"tcp\"', '--iopub=9004']\n",
      "2022-09-20 13:22:09 [INFO ]  Logging to ./results/dev\\Moji\\knn\\output.log\n",
      "2022-09-20 13:22:09 [WARNING]  Log file already exists, will append\n",
      "2022-09-20 13:22:09 [INFO ]  ======================================== 2022-09-20 13:22:09 ========================================\n",
      "2022-09-20 13:22:09 [INFO ]  Base directory is ./results/dev\\Moji\\knn\n",
      "2022-09-20 13:22:09 [WARNING]  ./results/dev\\Moji\\knn\\opt.yaml already exists, moved to ./results/dev\\Moji\\knn\\old_opts\\opt_2022_09_20__13_21_41.yaml\n",
      "{'Moji': {'emb_size': 2304, 'num_classes': 2, 'num_groups': 2}, 'Bios_both': {'emb_size': 768, 'num_classes': 28, 'num_groups': 4}, 'Bios_intersection': {'emb_size': 768, 'num_classes': 28, 'num_groups': 4}, 'Bios_gender': {'emb_size': 768, 'num_classes': 28, 'num_groups': 2}, 'Bios_economy': {'emb_size': 768, 'num_classes': 28, 'num_groups': 2}, 'Trustpilot_gender': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_age': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_country': {'emb_size': 768, 'num_classes': 5, 'num_groups': 2}, 'Trustpilot_intersection': {'emb_size': 768, 'num_classes': 5, 'num_groups': 8}, 'Adult_gender': {'emb_size': 101, 'num_classes': 2, 'num_groups': 2}, 'Adult_race': {'emb_size': 101, 'num_classes': 2, 'num_groups': 2}, 'Adult_intersection': {'emb_size': 101, 'num_classes': 2, 'num_groups': 4}, 'COMPAS_gender': {'emb_size': 447, 'num_classes': 2, 'num_groups': 2}, 'COMPAS_race': {'emb_size': 447, 'num_classes': 2, 'num_groups': 2}, 'COMPAS_intersection': {'emb_size': 447, 'num_classes': 2, 'num_groups': 4}, 'imSitu': {'emb_size': 2048, 'num_classes': 211, 'num_groups': 2}, 'MNIST': {'emb_size': 800, 'num_classes': 10, 'num_groups': 2, 'encoder_architecture': 'MNIST'}}\n",
      "Loaded data shapes: (99998, 2304), (99998,), (99998,)\n",
      "Loaded data shapes: (8000, 2304), (8000,), (8000,)\n",
      "Loaded data shapes: (7998, 2304), (7998,), (7998,)\n",
      "2022-09-20 13:22:09 [INFO ]  MLP( \n",
      "2022-09-20 13:22:09 [INFO ]    (output_layer): Linear(in_features=300, out_features=2, bias=True)\n",
      "2022-09-20 13:22:09 [INFO ]    (AF): Tanh()\n",
      "2022-09-20 13:22:09 [INFO ]    (hidden_layers): ModuleList(\n",
      "2022-09-20 13:22:09 [INFO ]      (0): Linear(in_features=2304, out_features=300, bias=True)\n",
      "2022-09-20 13:22:09 [INFO ]      (1): Tanh()\n",
      "2022-09-20 13:22:09 [INFO ]      (2): Linear(in_features=300, out_features=300, bias=True)\n",
      "2022-09-20 13:22:09 [INFO ]      (3): Tanh()\n",
      "2022-09-20 13:22:09 [INFO ]    )\n",
      "2022-09-20 13:22:09 [INFO ]    (criterion): CrossEntropyLoss()\n",
      "2022-09-20 13:22:09 [INFO ]  )\n",
      "2022-09-20 13:22:09 [INFO ]  Total number of parameters: 782402 \n",
      "\n",
      "2022-09-20 13:22:10 [INFO ]  Epoch:    0 [      0/  99998 ( 0%)]\tLoss: 0.6938\t Data Time: 0.02s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:10 [INFO ]  Epoch:    0 [  51200/  99998 (51%)]\tLoss: 0.3852\t Data Time: 0.59s\tTrain Time: 0.13s\n",
      "2022-09-20 13:22:11 [INFO ]  Evaluation at Epoch 0\n",
      "2022-09-20 13:22:11 [INFO ]  Validation accuracy: 72.22\tmacro_fscore: 72.14\tmicro_fscore: 72.23\tTPR_GAP: 38.85\tFPR_GAP: 38.85\tPPR_GAP: 37.70\t\n",
      "2022-09-20 13:22:11 [INFO ]  Test accuracy: 72.02\tmacro_fscore: 71.94\tmicro_fscore: 72.02\tTPR_GAP: 40.91\tFPR_GAP: 40.91\tPPR_GAP: 39.81\t\n",
      "2022-09-20 13:22:11 [INFO ]  Epoch:    1 [      0/  99998 ( 0%)]\tLoss: 0.3900\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:12 [INFO ]  Epoch:    1 [  51200/  99998 (51%)]\tLoss: 0.3684\t Data Time: 0.54s\tTrain Time: 0.10s\n",
      "2022-09-20 13:22:12 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 13:22:12 [INFO ]  Evaluation at Epoch 1\n",
      "2022-09-20 13:22:13 [INFO ]  Validation accuracy: 71.61\tmacro_fscore: 71.38\tmicro_fscore: 71.61\tTPR_GAP: 41.18\tFPR_GAP: 41.18\tPPR_GAP: 39.47\t\n",
      "2022-09-20 13:22:13 [INFO ]  Test accuracy: 71.61\tmacro_fscore: 71.41\tmicro_fscore: 71.61\tTPR_GAP: 43.11\tFPR_GAP: 43.11\tPPR_GAP: 41.34\t\n",
      "2022-09-20 13:22:13 [INFO ]  Epoch:    2 [      0/  99998 ( 0%)]\tLoss: 0.3491\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:13 [INFO ]  Epoch:    2 [  51200/  99998 (51%)]\tLoss: 0.3802\t Data Time: 0.56s\tTrain Time: 0.09s\n",
      "2022-09-20 13:22:14 [INFO ]  Epochs since last improvement: 2\n",
      "2022-09-20 13:22:14 [INFO ]  Evaluation at Epoch 2\n",
      "2022-09-20 13:22:14 [INFO ]  Validation accuracy: 71.44\tmacro_fscore: 71.28\tmicro_fscore: 71.44\tTPR_GAP: 42.01\tFPR_GAP: 42.01\tPPR_GAP: 40.57\t\n",
      "2022-09-20 13:22:14 [INFO ]  Test accuracy: 71.03\tmacro_fscore: 70.88\tmicro_fscore: 71.03\tTPR_GAP: 43.97\tFPR_GAP: 43.97\tPPR_GAP: 42.59\t\n",
      "2022-09-20 13:22:14 [INFO ]  Epoch:    3 [      0/  99998 ( 0%)]\tLoss: 0.3645\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:15 [INFO ]  Epoch:    3 [  51200/  99998 (51%)]\tLoss: 0.3848\t Data Time: 0.52s\tTrain Time: 0.14s\n",
      "2022-09-20 13:22:15 [INFO ]  Epochs since last improvement: 3\n",
      "2022-09-20 13:22:15 [INFO ]  Evaluation at Epoch 3\n",
      "2022-09-20 13:22:15 [INFO ]  Validation accuracy: 72.36\tmacro_fscore: 72.23\tmicro_fscore: 72.36\tTPR_GAP: 39.39\tFPR_GAP: 39.39\tPPR_GAP: 38.02\t\n",
      "2022-09-20 13:22:15 [INFO ]  Test accuracy: 72.29\tmacro_fscore: 72.18\tmicro_fscore: 72.29\tTPR_GAP: 41.03\tFPR_GAP: 41.03\tPPR_GAP: 39.76\t\n",
      "2022-09-20 13:22:15 [INFO ]  Epoch:    4 [      0/  99998 ( 0%)]\tLoss: 0.3840\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:16 [INFO ]  Epoch:    4 [  51200/  99998 (51%)]\tLoss: 0.3520\t Data Time: 0.52s\tTrain Time: 0.10s\n",
      "2022-09-20 13:22:17 [INFO ]  Evaluation at Epoch 4\n",
      "2022-09-20 13:22:17 [INFO ]  Validation accuracy: 72.50\tmacro_fscore: 72.34\tmicro_fscore: 72.50\tTPR_GAP: 38.92\tFPR_GAP: 38.92\tPPR_GAP: 37.55\t\n",
      "2022-09-20 13:22:17 [INFO ]  Test accuracy: 72.52\tmacro_fscore: 72.37\tmicro_fscore: 72.52\tTPR_GAP: 40.63\tFPR_GAP: 40.63\tPPR_GAP: 39.21\t\n",
      "2022-09-20 13:22:17 [INFO ]  Epoch:    5 [      0/  99998 ( 0%)]\tLoss: 0.3969\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:18 [INFO ]  Epoch:    5 [  51200/  99998 (51%)]\tLoss: 0.3893\t Data Time: 0.62s\tTrain Time: 0.12s\n",
      "2022-09-20 13:22:18 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 13:22:18 [INFO ]  Evaluation at Epoch 5\n",
      "2022-09-20 13:22:18 [INFO ]  Validation accuracy: 71.80\tmacro_fscore: 71.67\tmicro_fscore: 71.80\tTPR_GAP: 40.66\tFPR_GAP: 40.66\tPPR_GAP: 39.45\t\n",
      "2022-09-20 13:22:18 [INFO ]  Test accuracy: 71.98\tmacro_fscore: 71.87\tmicro_fscore: 71.98\tTPR_GAP: 41.73\tFPR_GAP: 41.73\tPPR_GAP: 40.59\t\n",
      "2022-09-20 13:22:18 [INFO ]  Epoch:    6 [      0/  99998 ( 0%)]\tLoss: 0.3511\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:19 [INFO ]  Epoch:    6 [  51200/  99998 (51%)]\tLoss: 0.3767\t Data Time: 0.52s\tTrain Time: 0.10s\n",
      "2022-09-20 13:22:20 [INFO ]  Epochs since last improvement: 2\n",
      "2022-09-20 13:22:20 [INFO ]  Evaluation at Epoch 6\n",
      "2022-09-20 13:22:20 [INFO ]  Validation accuracy: 71.62\tmacro_fscore: 71.36\tmicro_fscore: 71.62\tTPR_GAP: 39.29\tFPR_GAP: 39.29\tPPR_GAP: 37.75\t\n",
      "2022-09-20 13:22:20 [INFO ]  Test accuracy: 72.18\tmacro_fscore: 71.94\tmicro_fscore: 72.18\tTPR_GAP: 41.23\tFPR_GAP: 41.23\tPPR_GAP: 39.54\t\n",
      "2022-09-20 13:22:20 [INFO ]  Epoch:    7 [      0/  99998 ( 0%)]\tLoss: 0.3503\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:20 [INFO ]  Epoch:    7 [  51200/  99998 (51%)]\tLoss: 0.3709\t Data Time: 0.54s\tTrain Time: 0.14s\n",
      "2022-09-20 13:22:21 [INFO ]  Epochs since last improvement: 3\n",
      "2022-09-20 13:22:21 [INFO ]  Evaluation at Epoch 7\n",
      "2022-09-20 13:22:21 [INFO ]  Validation accuracy: 72.32\tmacro_fscore: 72.18\tmicro_fscore: 72.33\tTPR_GAP: 38.96\tFPR_GAP: 38.96\tPPR_GAP: 37.50\t\n",
      "2022-09-20 13:22:21 [INFO ]  Test accuracy: 72.41\tmacro_fscore: 72.26\tmicro_fscore: 72.41\tTPR_GAP: 40.73\tFPR_GAP: 40.73\tPPR_GAP: 39.19\t\n",
      "2022-09-20 13:22:21 [INFO ]  Epoch:    8 [      0/  99998 ( 0%)]\tLoss: 0.3878\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:22 [INFO ]  Epoch:    8 [  51200/  99998 (51%)]\tLoss: 0.3408\t Data Time: 0.51s\tTrain Time: 0.09s\n",
      "2022-09-20 13:22:22 [INFO ]  Evaluation at Epoch 8\n",
      "2022-09-20 13:22:23 [INFO ]  Validation accuracy: 72.31\tmacro_fscore: 72.19\tmicro_fscore: 72.31\tTPR_GAP: 38.24\tFPR_GAP: 38.24\tPPR_GAP: 37.02\t\n",
      "2022-09-20 13:22:23 [INFO ]  Test accuracy: 72.49\tmacro_fscore: 72.37\tmicro_fscore: 72.49\tTPR_GAP: 39.37\tFPR_GAP: 39.37\tPPR_GAP: 38.11\t\n",
      "2022-09-20 13:22:23 [INFO ]  Epoch:    9 [      0/  99998 ( 0%)]\tLoss: 0.3363\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:23 [INFO ]  Epoch:    9 [  51200/  99998 (51%)]\tLoss: 0.3807\t Data Time: 0.63s\tTrain Time: 0.12s\n",
      "2022-09-20 13:22:24 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 13:22:24 [INFO ]  Evaluation at Epoch 9\n",
      "2022-09-20 13:22:24 [INFO ]  Validation accuracy: 71.90\tmacro_fscore: 71.81\tmicro_fscore: 71.90\tTPR_GAP: 39.86\tFPR_GAP: 39.86\tPPR_GAP: 38.80\t\n",
      "2022-09-20 13:22:24 [INFO ]  Test accuracy: 71.81\tmacro_fscore: 71.72\tmicro_fscore: 71.81\tTPR_GAP: 42.19\tFPR_GAP: 42.19\tPPR_GAP: 41.19\t\n",
      "2022-09-20 13:22:24 [INFO ]  Epoch:   10 [      0/  99998 ( 0%)]\tLoss: 0.3570\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:25 [INFO ]  Epoch:   10 [  51200/  99998 (51%)]\tLoss: 0.3816\t Data Time: 0.50s\tTrain Time: 0.09s\n",
      "2022-09-20 13:22:25 [INFO ]  Epochs since last improvement: 2\n",
      "2022-09-20 13:22:25 [INFO ]  Evaluation at Epoch 10\n",
      "2022-09-20 13:22:25 [INFO ]  Validation accuracy: 71.94\tmacro_fscore: 71.86\tmicro_fscore: 71.94\tTPR_GAP: 39.46\tFPR_GAP: 39.46\tPPR_GAP: 38.67\t\n",
      "2022-09-20 13:22:25 [INFO ]  Test accuracy: 71.94\tmacro_fscore: 71.88\tmicro_fscore: 71.94\tTPR_GAP: 41.36\tFPR_GAP: 41.36\tPPR_GAP: 40.56\t\n",
      "2022-09-20 13:22:25 [INFO ]  Epoch:   11 [      0/  99998 ( 0%)]\tLoss: 0.3393\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:26 [INFO ]  Epoch:   11 [  51200/  99998 (51%)]\tLoss: 0.3550\t Data Time: 0.53s\tTrain Time: 0.10s\n",
      "2022-09-20 13:22:27 [INFO ]  Evaluation at Epoch 11\n",
      "2022-09-20 13:22:27 [INFO ]  Validation accuracy: 72.35\tmacro_fscore: 72.21\tmicro_fscore: 72.35\tTPR_GAP: 38.23\tFPR_GAP: 38.23\tPPR_GAP: 36.90\t\n",
      "2022-09-20 13:22:27 [INFO ]  Test accuracy: 72.93\tmacro_fscore: 72.80\tmicro_fscore: 72.93\tTPR_GAP: 39.11\tFPR_GAP: 39.11\tPPR_GAP: 37.59\t\n",
      "2022-09-20 13:22:27 [INFO ]  Epoch:   12 [      0/  99998 ( 0%)]\tLoss: 0.3480\t Data Time: 0.02s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:28 [INFO ]  Epoch:   12 [  51200/  99998 (51%)]\tLoss: 0.3400\t Data Time: 0.51s\tTrain Time: 0.09s\n",
      "2022-09-20 13:22:28 [INFO ]  Evaluation at Epoch 12\n",
      "2022-09-20 13:22:28 [INFO ]  Validation accuracy: 72.02\tmacro_fscore: 71.96\tmicro_fscore: 72.02\tTPR_GAP: 37.35\tFPR_GAP: 37.35\tPPR_GAP: 36.45\t\n",
      "2022-09-20 13:22:28 [INFO ]  Test accuracy: 72.01\tmacro_fscore: 71.94\tmicro_fscore: 72.01\tTPR_GAP: 39.45\tFPR_GAP: 39.45\tPPR_GAP: 38.39\t\n",
      "2022-09-20 13:22:28 [INFO ]  Epoch:   13 [      0/  99998 ( 0%)]\tLoss: 0.3425\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:29 [INFO ]  Epoch:   13 [  51200/  99998 (51%)]\tLoss: 0.3374\t Data Time: 0.54s\tTrain Time: 0.13s\n",
      "2022-09-20 13:22:30 [INFO ]  Epochs since last improvement: 1\n",
      "2022-09-20 13:22:30 [INFO ]  Evaluation at Epoch 13\n",
      "2022-09-20 13:22:30 [INFO ]  Validation accuracy: 71.43\tmacro_fscore: 71.42\tmicro_fscore: 71.42\tTPR_GAP: 39.00\tFPR_GAP: 39.00\tPPR_GAP: 38.85\t\n",
      "2022-09-20 13:22:30 [INFO ]  Test accuracy: 71.14\tmacro_fscore: 71.14\tmicro_fscore: 71.14\tTPR_GAP: 41.58\tFPR_GAP: 41.58\tPPR_GAP: 41.31\t\n",
      "2022-09-20 13:22:30 [INFO ]  Epoch:   14 [      0/  99998 ( 0%)]\tLoss: 0.3572\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:30 [INFO ]  Epoch:   14 [  51200/  99998 (51%)]\tLoss: 0.3259\t Data Time: 0.53s\tTrain Time: 0.09s\n",
      "2022-09-20 13:22:31 [INFO ]  Epochs since last improvement: 2\n",
      "2022-09-20 13:22:31 [INFO ]  Evaluation at Epoch 14\n",
      "2022-09-20 13:22:31 [INFO ]  Validation accuracy: 69.66\tmacro_fscore: 69.45\tmicro_fscore: 69.66\tTPR_GAP: 44.26\tFPR_GAP: 44.26\tPPR_GAP: 42.87\t\n",
      "2022-09-20 13:22:31 [INFO ]  Test accuracy: 69.82\tmacro_fscore: 69.64\tmicro_fscore: 69.82\tTPR_GAP: 46.84\tFPR_GAP: 46.84\tPPR_GAP: 45.52\t\n",
      "2022-09-20 13:22:31 [INFO ]  Epoch:   15 [      0/  99998 ( 0%)]\tLoss: 0.3598\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:32 [INFO ]  Epoch:   15 [  51200/  99998 (51%)]\tLoss: 0.3489\t Data Time: 0.53s\tTrain Time: 0.12s\n",
      "2022-09-20 13:22:33 [INFO ]  Epochs since last improvement: 3\n",
      "2022-09-20 13:22:33 [INFO ]  Evaluation at Epoch 15\n",
      "2022-09-20 13:22:33 [INFO ]  Validation accuracy: 71.08\tmacro_fscore: 71.04\tmicro_fscore: 71.08\tTPR_GAP: 39.77\tFPR_GAP: 39.77\tPPR_GAP: 39.25\t\n",
      "2022-09-20 13:22:33 [INFO ]  Test accuracy: 70.78\tmacro_fscore: 70.76\tmicro_fscore: 70.78\tTPR_GAP: 42.12\tFPR_GAP: 42.12\tPPR_GAP: 41.44\t\n",
      "2022-09-20 13:22:33 [INFO ]  Epoch:   16 [      0/  99998 ( 0%)]\tLoss: 0.3064\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:33 [INFO ]  Epoch:   16 [  51200/  99998 (51%)]\tLoss: 0.3529\t Data Time: 0.52s\tTrain Time: 0.09s\n",
      "2022-09-20 13:22:34 [INFO ]  Epochs since last improvement: 4\n",
      "2022-09-20 13:22:34 [INFO ]  Evaluation at Epoch 16\n",
      "2022-09-20 13:22:34 [INFO ]  Validation accuracy: 71.44\tmacro_fscore: 71.29\tmicro_fscore: 71.44\tTPR_GAP: 39.73\tFPR_GAP: 39.73\tPPR_GAP: 38.57\t\n",
      "2022-09-20 13:22:34 [INFO ]  Test accuracy: 71.73\tmacro_fscore: 71.58\tmicro_fscore: 71.73\tTPR_GAP: 40.76\tFPR_GAP: 40.76\tPPR_GAP: 39.19\t\n",
      "2022-09-20 13:22:34 [INFO ]  Epoch:   17 [      0/  99998 ( 0%)]\tLoss: 0.3346\t Data Time: 0.01s\tTrain Time: 0.00s\n",
      "2022-09-20 13:22:35 [INFO ]  Epoch:   17 [  51200/  99998 (51%)]\tLoss: 0.3468\t Data Time: 0.53s\tTrain Time: 0.12s\n",
      "2022-09-20 13:22:35 [INFO ]  Epochs since last improvement: 5\n",
      "2022-09-20 13:22:35 [INFO ]  Evaluation at Epoch 17\n",
      "2022-09-20 13:22:35 [INFO ]  Validation accuracy: 71.15\tmacro_fscore: 71.05\tmicro_fscore: 71.15\tTPR_GAP: 39.88\tFPR_GAP: 39.88\tPPR_GAP: 39.05\t\n",
      "2022-09-20 13:22:35 [INFO ]  Test accuracy: 70.43\tmacro_fscore: 70.35\tmicro_fscore: 70.43\tTPR_GAP: 42.61\tFPR_GAP: 42.61\tPPR_GAP: 41.44\t\n",
      "Target class 0, protected group 0: 0.172875\n",
      "Target class 0, protected group 1: 0.6868686868686869\n",
      "Target class 1, protected group 0: 0.55995599559956\n",
      "Target class 1, protected group 1: 0.18585\n"
     ]
    }
   ],
   "source": [
    "result_df_list = []\n",
    "\n",
    "for i in range(5):\n",
    "\n",
    "    args = {\n",
    "        # The name of the dataset, corresponding dataloader will be used,\n",
    "        \"dataset\":  \"Moji\",\n",
    "\n",
    "        # Give a name to the exp, which will be used in the path\n",
    "        \"exp_id\":\"knn\",\n",
    "    }\n",
    "\n",
    "    # Init the argument\n",
    "    options = fairlib.BaseOptions()\n",
    "    state = options.get_state(args=args, silence=True)\n",
    "\n",
    "    fairlib.utils.seed_everything(2022+i)\n",
    "\n",
    "    # Init Model\n",
    "    model = fairlib.networks.get_main_model(state)\n",
    "    model.train_self()\n",
    "\n",
    "    k1_y_g_ratio_list, knn_label, class_label, group_label, prediction = mutual_information_analysis(p=2, k=1)\n",
    "\n",
    "    _, confs = gap_eval_scores(\n",
    "        y_pred=prediction,\n",
    "        y_true=class_label, \n",
    "        protected_attribute=group_label,\n",
    "        args = model.args,\n",
    "    )\n",
    "\n",
    "    metrics_group0 = confusion_matrix_based_scores(confs[0])\n",
    "    metrics_group1 = confusion_matrix_based_scores(confs[1])\n",
    "    metrics_results = [metrics_group0, metrics_group1]\n",
    "\n",
    "    merics_y_g = []\n",
    "    for _target_class in [0,1]:\n",
    "        for _group_class in [0,1]:\n",
    "            merics_y_g.append(\n",
    "                {\n",
    "                    \"target\": _target_class,\n",
    "                    \"group\":_group_class,\n",
    "                    \"PPR\": metrics_results[_group_class]['PPR'][_target_class],\n",
    "                    \"TPR\": metrics_results[_group_class]['TPR'][_target_class],\n",
    "                    \"FPR\": metrics_results[_group_class]['FPR'][_target_class],\n",
    "                    \"PPV\": metrics_results[_group_class]['PPV'][_target_class],\n",
    "                    \"NPV\": metrics_results[_group_class]['NPV'][_target_class],\n",
    "                }\n",
    "            )\n",
    "\n",
    "    result_df = k1_y_g_ratio_list.set_index([\"target\",\"group\"]).join(pd.DataFrame(merics_y_g).set_index([\"target\",\"group\"])).reset_index()\n",
    "\n",
    "    result_df_list.append(result_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{llrrrrrrrrrrrrrrrr}\n",
      "\\toprule\n",
      "    &     & \\multicolumn{2}{l}{p} & \\multicolumn{2}{l}{k} & \\multicolumn{2}{l}{ratio} & \\multicolumn{2}{l}{PPR} & \\multicolumn{2}{l}{TPR} & \\multicolumn{2}{l}{FPR} & \\multicolumn{2}{l}{PPV} & \\multicolumn{2}{l}{NPV} \\\\\n",
      "    &     &   mean &  std &   mean &  std &       mean &       std &       mean &       std &       mean &       std &       mean &       std &       mean &       std &       mean &       std \\\\\n",
      "target & group &        &      &        &      &            &           &            &           &            &           &            &           &            &           &            &           \\\\\n",
      "\\midrule\n",
      "0   & 0   &  200.0 &  0.0 &  100.0 &  0.0 &  17.019000 &  1.242669 &  79.934799 &  0.760515 &  91.176000 &  0.688489 &  34.965497 &  3.137330 &  91.255727 &  0.725637 &  64.824876 &  2.239953 \\\\\n",
      "    & 100 &  200.0 &  0.0 &  100.0 &  0.0 &  68.502850 &  1.679611 &  14.269485 &  0.695365 &  45.748575 &  2.627558 &   6.400500 &  0.753194 &  64.157670 &  3.207912 &  87.346220 &  0.563455 \\\\\n",
      "100 & 0   &  200.0 &  0.0 &  100.0 &  0.0 &  55.311531 &  2.972069 &  20.065201 &  0.760515 &  65.034503 &  3.137330 &   8.824000 &  0.688489 &  64.824877 &  2.239953 &  91.255727 &  0.725637 \\\\\n",
      "    & 100 &  200.0 &  0.0 &  100.0 &  0.0 &  15.832500 &  2.285018 &  85.730515 &  0.695365 &  93.599500 &  0.753194 &  54.251425 &  2.627558 &  87.346220 &  0.563455 &  64.157670 &  3.207912 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print((pd.concat(result_df_list)*100).groupby([\"target\",\"group\"]).agg([\"mean\", \"std\"]).to_latex())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.7.12 ('py37')",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.12"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "eb4eca40f7710e7c7146430b0424b585ee7a07b7e7498958627feae1c8ad8261"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
