{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 155,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from glob import glob\n",
    "import re\n",
    "import os\n",
    "import itertools"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "pip install seaborn --upgrade"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Helper Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "metadata": {},
   "outputs": [],
   "source": [
    "def is_pareto_efficient(costs, return_mask = True):\n",
    "    \"\"\"\n",
    "    Find the pareto-efficient points\n",
    "    :param costs: An (n_points, n_costs) array\n",
    "    :param return_mask: True to return a mask\n",
    "    :return: An array of indices of pareto-efficient points.\n",
    "        If return_mask is True, this will be an (n_points, ) boolean array\n",
    "        Otherwise it will be a (n_efficient_points, ) integer array of indices.\n",
    "    \"\"\"\n",
    "    is_efficient = np.arange(costs.shape[0])\n",
    "    n_points = costs.shape[0]\n",
    "    next_point_index = 0  # Next index in the is_efficient array to search for\n",
    "    while next_point_index<len(costs):\n",
    "        nondominated_point_mask = np.any(costs<costs[next_point_index], axis=1)\n",
    "        nondominated_point_mask[next_point_index] = True\n",
    "        is_efficient = is_efficient[nondominated_point_mask]  # Remove dominated points\n",
    "        costs = costs[nondominated_point_mask]\n",
    "        next_point_index = np.sum(nondominated_point_mask[:next_point_index])+1\n",
    "    if return_mask:\n",
    "        is_efficient_mask = np.zeros(n_points, dtype = bool)\n",
    "        is_efficient_mask[is_efficient] = True\n",
    "        return is_efficient_mask\n",
    "    else:\n",
    "        return is_efficient\n",
    "\n",
    "def get_pf(losses, priv_values, fair_values):\n",
    "    # select points on the PF\n",
    "    pf_indices = is_pareto_efficient(losses)\n",
    "    pf_losses = losses[pf_indices, :]\n",
    "    pf_priv = priv_values[pf_indices]\n",
    "    pf_fair = fair_values[pf_indices]\n",
    "    \n",
    "    return pf_losses, pf_priv, pf_fair, pf_indices"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initialize figure settings\n",
    "SMALL_SIZE = 27\n",
    "MEDIUM_SIZE = SMALL_SIZE + 2\n",
    "BIGGER_SIZE = SMALL_SIZE + 5\n",
    "\n",
    "plt.rc('font', size=SMALL_SIZE)          # controls default text sizes\n",
    "plt.rc('axes', titlesize=SMALL_SIZE)     # fontsize of the axes title\n",
    "plt.rc('axes', labelsize=MEDIUM_SIZE)    # fontsize of the x and y labels\n",
    "plt.rc('xtick', labelsize=SMALL_SIZE)    # fontsize of the tick labels\n",
    "plt.rc('ytick', labelsize=SMALL_SIZE)    # fontsize of the tick labels\n",
    "plt.rc('legend', fontsize=SMALL_SIZE)    # legend fontsize\n",
    "plt.rc('figure', titlesize=BIGGER_SIZE)  # fontsize of the figure title\n",
    "\n",
    "\n",
    "rc_fonts = {\n",
    "    'text.usetex': True,\n",
    "    'font.family': 'Times New Roman',\n",
    "    'text.latex.preamble':\n",
    "        r\"\"\"\n",
    "        \\usepackage{amsmath}\n",
    "        \"\"\",\n",
    "}\n",
    "\n",
    "plt.rcParams.update(rc_fonts)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "metadata": {},
   "outputs": [],
   "source": [
    "def closest_point(target, points):\n",
    "    return  (np.abs(points - target)).argmin()\n",
    "\n",
    "def closest_point_2d(target, points):\n",
    "    dist_2 = np.sum((points - target)**2, axis=1)\n",
    "    return np.argmin(dist_2)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Graphing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 160,
   "metadata": {},
   "outputs": [],
   "source": [
    "from functools import reduce"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_utility_loss_data(dataset, due_to='privacy', use_coverage = False):\n",
    "    # load the losses\n",
    "    loss_dir = f\"../previous_results/loss_functions/{dataset}/fairPATE\"\n",
    "    loss_builder_acc = np.load(loss_dir+'/builder_loss_acc.npy')  \n",
    "    loss_builder_cov = np.load(loss_dir+'/builder_loss_cov.npy')\n",
    "    loss_privacy = np.load(loss_dir+'/privacy_loss.npy')\n",
    "    loss_fairness = np.load(loss_dir+'/fairness_loss.npy')\n",
    "    priv_fair_values = np.load(loss_dir+'/priv_fair_values.npy')\n",
    "\n",
    "    priv_values = priv_fair_values[:,0]\n",
    "    fair_values = priv_fair_values[:,1]\n",
    "    losses = np.squeeze(np.stack((-1 * loss_builder_acc, loss_privacy, loss_fairness, -1 * loss_builder_cov), axis=-1))\n",
    "\n",
    "    # get points on pf\n",
    "    pf_losses, pf_priv, pf_fair, pf_indices = get_pf(losses, priv_values, fair_values)\n",
    "    loss_privacy = pf_losses[:, 1]\n",
    "    loss_fairness = pf_losses[:, 2]\n",
    "    accuracy = pf_losses[:, 0] * -0.01\n",
    "    coverage = pf_losses[:, 3] * -1\n",
    "    if use_coverage:\n",
    "        utility = 0.7 * accuracy + 0.3 * coverage\n",
    "    else:\n",
    "        utility = accuracy\n",
    "\n",
    "    priv_fair = np.stack((loss_privacy, loss_fairness), axis=1)\n",
    "\n",
    "    # starting points\n",
    "    eps = [1, 2, 3, 4, 5, 6, 7, 8, 9]\n",
    "    gamma = [0.01, 0.05, 0.1, 0.15]\n",
    "    all_list = [eps, gamma]\n",
    "    combinations = list(itertools.product(*all_list))\n",
    "\n",
    "    # delta epsilons (uncertainties)\n",
    "    delta_eps = [0.5, 1, 1.5]\n",
    "\n",
    "    # delta gamma (uncertainties)\n",
    "    # delta_gamma = [0.01, 0.05, 0.1, 0.15, 0.2, 0.25, 0.3, 0.35, 0.4]\n",
    "    delta_gamma = [0.01, 0.05, 0.1, 0.15]\n",
    "\n",
    "    if due_to == 'privacy':\n",
    "        # for each starting point, find the points corresponding to each delta epsilon\n",
    "        delta_util_points = []\n",
    "        delta_eps_points = []\n",
    "        for sp in combinations:\n",
    "            og_utility = utility[closest_point_2d(sp, priv_fair)]\n",
    "            for eps in delta_eps:\n",
    "                if sp[0]-eps*2 < 1:\n",
    "                    continue\n",
    "                else:\n",
    "                    new_point = [sp[0]-eps*2, sp[1]]\n",
    "                    new_utility = utility[closest_point_2d(new_point, priv_fair)]\n",
    "                    delta_util =  new_utility - og_utility\n",
    "                    delta_util_points.append(delta_util)\n",
    "                    delta_eps_points.append(eps)\n",
    "        # build this as a df\n",
    "        if use_coverage:\n",
    "            d = {'delta_epsilon': delta_eps_points, 'delta_utility': delta_util_points}\n",
    "        else:\n",
    "            d = {'delta_epsilon': delta_eps_points, 'delta_accuracy': delta_util_points}\n",
    "        df = pd.DataFrame(data=d)\n",
    "    elif due_to == 'fairness':\n",
    "        delta_util_points = []\n",
    "        delta_gamma_points = []\n",
    "        for sp in combinations:\n",
    "            og_utility = utility[closest_point_2d(sp, priv_fair)]\n",
    "            for gamma in delta_gamma:\n",
    "                if sp[1]-gamma*2 < 0.01:\n",
    "                    continue\n",
    "                else:\n",
    "                    new_point = [sp[0], sp[1]-gamma*2]\n",
    "                    new_utility = utility[closest_point_2d(new_point, priv_fair)]\n",
    "                    delta_util =  new_utility - og_utility\n",
    "                    delta_util_points.append(delta_util)\n",
    "                    delta_gamma_points.append(gamma)\n",
    "        # build this as a df\n",
    "        if use_coverage:\n",
    "            d = {'delta_gamma': delta_gamma_points, 'delta_utility': delta_util_points}\n",
    "        else:\n",
    "            d = {'delta_gamma': delta_gamma_points, 'delta_accuracy': delta_util_points}\n",
    "        df = pd.DataFrame(data=d)\n",
    "    else:\n",
    "        raise ValueError('due_to must be either privacy or fairness')\n",
    "    return df"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "metadata": {},
   "outputs": [],
   "source": [
    "fairface_privacy_df = get_utility_loss_data('fairface').assign(dataset='fairface', due_to='privacy').rename(columns={'delta_epsilon': 'delta'})\n",
    "utkface_privacy_df = get_utility_loss_data('utkface').assign(dataset='utkface', due_to='privacy').rename(columns={'delta_epsilon': 'delta'})\n",
    "celeba_privacy_df = get_utility_loss_data('celebasensitive').assign(dataset='celeba', due_to='privacy').rename(columns={'delta_epsilon': 'delta'})\n",
    "\n",
    "fairface_fairness_df = get_utility_loss_data('fairface', due_to='fairness').assign(dataset='fairface', due_to='fairness').rename(columns={'delta_gamma': 'delta'})\n",
    "utkface_fairness_df = get_utility_loss_data('utkface', due_to='fairness').assign(dataset='utkface', due_to='fairness').rename(columns={'delta_gamma': 'delta'})\n",
    "celeba_fairness_df = get_utility_loss_data('celebasensitive', due_to='fairness').assign(dataset='celeba', due_to='fairness').rename(columns={'delta_gamma': 'delta'})\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_df = pd.concat([fairface_privacy_df, utkface_privacy_df, celeba_privacy_df, fairface_fairness_df, utkface_fairness_df, celeba_fairness_df])\n",
    "plot_df = plot_df.assign(utility_loss=lambda x: -100*x[\"delta_accuracy\"])\n",
    "plot_df = plot_df.rename(columns={'dataset': 'Dataset'}).replace({'fairface': 'FairFace', 'utkface': 'UTKFace', 'celeba': 'CelebA'})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_df_priv = plot_df[plot_df['due_to'] == 'privacy']\n",
    "plot_df_fair = plot_df[plot_df['due_to'] == 'fairness']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1500x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(1, 2, figsize = ( 15 , 6 ))\n",
    "sns.barplot(data=plot_df_priv, x='delta', y='utility_loss', hue='Dataset', ax=axes[0])\n",
    "sns.barplot(data=plot_df_fair, x='delta', y='utility_loss', hue='Dataset', ax=axes[1])\n",
    "\n",
    "fig.suptitle(\"\")\n",
    "axes[0].set_ylabel(\"Utility Loss (\\% Accuracy)\")\n",
    "axes[1].set_ylabel(\"\")\n",
    "\n",
    "axes[0].set_xlabel(\"$|\\\\Delta\\\\varepsilon|$\")\n",
    "axes[1].set_xlabel(\"$|\\\\Delta\\\\gamma|$\")\n",
    "axes[1].get_legend().remove()\n",
    "fig.savefig('figures/utility_loss.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Accuracy and Coverage"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "metadata": {},
   "outputs": [],
   "source": [
    "fairface_privacy_df_cov = get_utility_loss_data('fairface', use_coverage=True).assign(dataset='fairface', due_to='privacy').rename(columns={'delta_epsilon': 'delta'})\n",
    "utkface_privacy_df_cov = get_utility_loss_data('utkface', use_coverage=True).assign(dataset='utkface', due_to='privacy').rename(columns={'delta_epsilon': 'delta'})\n",
    "celeba_privacy_df_cov = get_utility_loss_data('celebasensitive', use_coverage=True).assign(dataset='celeba', due_to='privacy').rename(columns={'delta_epsilon': 'delta'})\n",
    "\n",
    "fairface_fairness_df_cov = get_utility_loss_data('fairface', due_to='fairness', use_coverage=True).assign(dataset='fairface', due_to='fairness').rename(columns={'delta_gamma': 'delta'})\n",
    "utkface_fairness_df_cov = get_utility_loss_data('utkface', due_to='fairness', use_coverage=True).assign(dataset='utkface', due_to='fairness').rename(columns={'delta_gamma': 'delta'})\n",
    "celeba_fairness_df_cov = get_utility_loss_data('celebasensitive', due_to='fairness', use_coverage=True).assign(dataset='celeba', due_to='fairness').rename(columns={'delta_gamma': 'delta'})\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_df_cov = pd.concat([fairface_privacy_df_cov, utkface_privacy_df_cov, celeba_privacy_df_cov, fairface_fairness_df_cov, utkface_fairness_df_cov, celeba_fairness_df_cov])\n",
    "plot_df_cov = plot_df_cov.assign(utility_loss=lambda x: -100*x[\"delta_utility\"])\n",
    "plot_df_cov = plot_df_cov.rename(columns={'dataset': 'Dataset'}).replace({'fairface': 'FairFace', 'utkface': 'UTKFace', 'celeba': 'CelebA'})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_df_priv_cov = plot_df_cov[plot_df_cov['due_to'] == 'privacy']\n",
    "plot_df_fair_cov = plot_df_cov[plot_df_cov['due_to'] == 'fairness']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "metadata": {},
   "outputs": [],
   "source": [
    "# g = sns.catplot(data=plot_df, x='delta', y='utility_loss', hue='Dataset', kind='bar', col='due_to', aspect=1.2, height=6, sharey=False, sharex=False, legend_out=False)\n",
    "# g.set_titles(\"\")\n",
    "# g.set_axis_labels(\"\", \"Utility Loss (\\% Accuracy)\")\n",
    "# axes = g.axes.flatten()\n",
    "# axes[0].set_xlabel(\"$|\\\\Delta\\\\varepsilon|$\")\n",
    "# axes[1].set_xlabel(\"$|\\\\Delta\\\\gamma|$\")\n",
    "# g.savefig('figures/utility_loss.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 170,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1500x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(1, 2, figsize = ( 15 , 6 ))\n",
    "sns.barplot(data=plot_df_priv_cov, x='delta', y='utility_loss', hue='Dataset', ax=axes[0])\n",
    "sns.barplot(data=plot_df_fair_cov, x='delta', y='utility_loss', hue='Dataset', ax=axes[1])\n",
    "\n",
    "fig.suptitle(\"\")\n",
    "axes[0].set_ylabel(\"Utility Loss\")\n",
    "axes[1].set_ylabel(\"\")\n",
    "\n",
    "axes[0].set_xlabel(\"$|\\\\Delta\\\\varepsilon|$\")\n",
    "axes[1].set_xlabel(\"$|\\\\Delta\\\\gamma|$\")\n",
    "axes[1].get_legend().remove()\n",
    "fig.savefig('figures/utility_loss_cov.pdf', bbox_inches='tight')"
   ]
  }
 ],
 "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.9.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
