{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The code is released exclusively for review purposes with the following terms:\n",
    "PROPRIETARY AND CONFIDENTIAL. UNAUTHORIZED USE, COPYING, OR DISTRIBUTION OF THE \n",
    "CODE, VIA ANY MEDIUM, IS STRICTLY PROHIBITED. BY ACCESSING THE CODE, THE \n",
    "REVIEWERS AGREE TO DELETE THEM FROM ALL MEDIA AFTER THE REVIEW PERIOD IS OVER.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\"\"\"Compare explanations for various examples.\"\"\"\n",
    "\n",
    "import numpy as np\n",
    "import sys\n",
    "sys.path.append(\"../utilities/\")\n",
    "import os\n",
    "import pandas as pd\n",
    "from scipy.stats import sem\n",
    "\n",
    "from joblib import Parallel, delayed\n",
    "from sklearn.utils import check_random_state\n",
    "from sklearn.metrics import mean_absolute_error\n",
    "from sklearn.neighbors import kneighbors_graph\n",
    "import yaml\n",
    "import pickle\n",
    "import joblib\n",
    "from itertools import product\n",
    "from scipy.stats import sem\n",
    "import seaborn as sns\n",
    "\n",
    "# fname_lime_exp\n",
    "from utils import (fname_data, fname_model, fname_exp, \n",
    "                   fname_base_perts, fname_env_perts, fname_preds,\n",
    "                   train_perturbation, scale_data,\n",
    "                  compute_weights)\n",
    "from helpers import lrg_lsq_sparse, lrg_lsq\n",
    "pd.options.display.max_rows = 100\n",
    "\n",
    "from IPython.display import display\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Args():\n",
    "    def __init__(self, config_fname=None, dataset_key=None, model_key=None, \n",
    "                 pert_key=None, start_ex=None, end_ex=None):\n",
    "        self.config_fname = config_fname\n",
    "        self.dataset_key = dataset_key\n",
    "        self.model_key = model_key\n",
    "        self.pert_key = pert_key\n",
    "        self.start_ex = start_ex\n",
    "        self.end_ex = end_ex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "agg_mode_str = {\"num_envs\": \"Number of environments\",\n",
    "               \"cnt\": \"Neighborhood size\",\n",
    "               \"kernel_width\": \"Kernel width\"}\n",
    "measure_str = {\n",
    "                \"GI\": \"Generalized infidelity\",\n",
    "                \"INFD\": \"Infidelity\",\n",
    "                \"CAC\": \"Class attribution consistency\",\n",
    "                \"Upsilon\": \"$\\\\mathbf{\\\\Upsilon}$\",\n",
    "                \"CI\": \"Coefficient inconsistency\",\n",
    "                \"CT\": \"Compute time\"\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "measures=[\"INFD\", \"PI\", \"CI\", \"GI\", \"Upsilon\", \"CAC\", \"CT\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# dataset to be used\n",
    "dataset = \"IRIS\"\n",
    "\n",
    "# pert_key = \"\"\n",
    "pert_key = \"Base_Perturbations\"\n",
    "\n",
    "# measures to be plotted\n",
    "agg_mode = \"cnt\"\n",
    "measure = \"Upsilon\"\n",
    "\n",
    "# Methods to be plotted\n",
    "methods = [\n",
    "    \"LIME\",\n",
    "    \"S-LIME\",\n",
    "    \"LINEX/rand\"]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# results_all/iris_rfc_res_expanded.pkl\n",
    "if dataset == \"IRIS\":\n",
    "    res_dfa = pd.read_pickle(\"results_all/iris_rfc_res.pkl\")\n",
    "    res_base_fname = \"figures/iris_rfc_\"\n",
    "    \n",
    "res_dfa = res_dfa.astype(float)\n",
    "res_dfa.columns = measures\n",
    "res_dfa.index = res_dfa.index.rename([\"method\", \"pert_key\", \"cnt\", \"num_envs\", \"kernel_width\", \"k\"])\n",
    "res_dfa = res_dfa.reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "res_dfa"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "res_dfa1 = res_dfa"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "method_keys ={\n",
    "    \"LIME\": (\"LIME\", \"Base_Perturbations\"),\n",
    "    \"S-LIME\": (\"LIME_smooth\", \"Base_Perturbations\"),\n",
    "    \"LINEX/rand\": (\"LINEX\", \"Base_Perturbations\"),\n",
    "    \"MeLime\": (\"LIME\", \"MeLime_Perturbations\"),\n",
    "    \"LINEX/real\": (\"LINEX\", \"MeLime_Perturbations\"),\n",
    "    \"MAPLE\": (\"LIME\", \"MAPLE\"),\n",
    "    \"LINEX/mpl\": (\"LINEX\", \"MAPLE\"),\n",
    "    \"SHAP\": (\"SHAP\", \"Base_Perturbations\")\n",
    "}\n",
    "sns_cp = sns.color_palette(\"bright\", n_colors=8)\n",
    "\n",
    "method_colors = {\n",
    "    \"LIME\": sns_cp[0],\n",
    "    \"S-LIME\": sns_cp[1],\n",
    "    \"LINEX/rand\": sns_cp[2],\n",
    "    \"MeLime\": sns_cp[3],\n",
    "    \"LINEX/real\": sns_cp[4],\n",
    "    \"MAPLE\": sns_cp[5],\n",
    "    \"LINEX/mpl\": sns_cp[6],\n",
    "    \"SHAP\": sns_cp[7]\n",
    "}\n",
    "method_markers = {\n",
    "    \"LIME\": \"o\",\n",
    "    \"S-LIME\": \"v\",\n",
    "    \"LINEX/rand\": \"^\",\n",
    "    \"MeLime\": \"*\",\n",
    "    \"LINEX/real\": \"d\",\n",
    "    \"MAPLE\": \"s\",\n",
    "    \"LINEX/mpl\": \"X\",\n",
    "    \"SHAP\": \"P\"\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Means and SEs\n",
    "grp_mean = res_dfa1.groupby(by=[\"method\", \"pert_key\", agg_mode]).mean()\n",
    "grp_se = res_dfa1.groupby(by=[\"method\", \"pert_key\", agg_mode]).agg(sem)\n",
    "\n",
    "xvals = list(grp_mean.loc[method_keys[\"LIME\"], measure].index)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "methods"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# plt.figure(figsize=(20, 20))\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "for meth in methods:\n",
    "    print(meth)\n",
    "    \n",
    "    meth_mean = grp_mean.loc[method_keys[meth], measure].values\n",
    "    meth_se = grp_se.loc[method_keys[meth], measure].values\n",
    "    \n",
    "    if len(meth_mean) == 1:\n",
    "        meth_mean = np.repeat(meth_mean, len(xvals))\n",
    "    \n",
    "    ax.plot(xvals, meth_mean,\n",
    "            color=method_colors[meth], linewidth=2,\n",
    "            marker=method_markers[meth], markersize=10)\n",
    "    ax.fill_between(xvals,\n",
    "                    (meth_mean-meth_se), \n",
    "                    (meth_mean+meth_se), \n",
    "                    color=method_colors[meth], alpha=.1)\n",
    "\n",
    "plt.xlabel(agg_mode_str[agg_mode], fontsize=14, weight=\"bold\")\n",
    "plt.ylabel(measure_str[measure], fontsize=14, weight=\"bold\")\n",
    "plt.grid()\n",
    "plt.legend(methods, fontsize=14, bbox_to_anchor=(1.04,1), loc=\"upper left\")\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "@webio": {
   "lastCommId": null,
   "lastKernelId": null
  },
  "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.7.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
