{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "9e5a4040-4988-4b78-a827-880e137b2a00",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "\n",
    "import matplotlib\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import os\n",
    "from typing import List\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "from scipy.interpolate import griddata\n",
    "from matplotlib import cm\n",
    "import matplotlib.colors as mcolors\n",
    "matplotlib.rcParams[\"legend.framealpha\"] = 1\n",
    "matplotlib.rc('font', **{'size': 20})\n",
    "from matplotlib.colors import ListedColormap\n",
    "from display_plot_utils import display_pcp_fail_results, read_methods_results, process_methods_df, methods, method_to_error_type, \\\n",
    "    color_palette\n",
    "\n",
    "plt.rcParams['text.usetex'] = True\n",
    "\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e481ef3c-cba5-4cd7-805d-21181a78a784",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_base_path = '../src/results'\n",
    "paper_figures_path = 'figures/paper_figures'\n",
    "seeds = 30"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f3a6702b-12a6-4f4b-9f10-03aaf92b2f60",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_name = 'missing_y_meps_19' \n",
    "figure_path = paper_figures_path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "07a07aec-9d7d-4c4e-9924-30ddb453c754",
   "metadata": {},
   "outputs": [],
   "source": [
    "original_total_df = read_methods_results(results_base_path, dataset_name, methods, apply_mean=False, seeds=seeds,\n",
    "                                display_errors=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "acb3546a-11a0-4626-8ca4-623b13d63b3b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 550x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "curr_method_name_to_display_name = {\n",
    "    'naive cqr': 'Naive CP',\n",
    "    'weighted oracle masker': 'WCP',\n",
    "    'pcp rf use z=true masker': 'PCP',\n",
    "    # 'full with rfcde errors': 'Ours',\n",
    "        # 'full + linear with linear clustering errors': 'Ours',\n",
    "    'full + linear with linear clustering errors': 'Ours',\n",
    "    \n",
    "}\n",
    "curr_methods_order = list(curr_method_name_to_display_name.values())\n",
    "\n",
    "total_df = process_methods_df(original_total_df.copy())\n",
    "total_df['Error'] = total_df['Method'].apply(method_to_error_type)\n",
    "methods_to_keep = ['naive cqr', 'weighted oracle', 'pcp', 'full']\n",
    "methods_to_exclude = []\n",
    "\n",
    "def keep_method(method_name):\n",
    "    return any([a in method_name for a in methods_to_keep]) and not any(\n",
    "        [a in method_name for a in methods_to_exclude])\n",
    "\n",
    "total_df = total_df[total_df['Method'].apply(keep_method)]\n",
    "total_df = total_df[total_df['Method'].apply(lambda m: m in curr_method_name_to_display_name)]\n",
    "total_df['Method'] = total_df['Method'].apply(lambda x: curr_method_name_to_display_name[x])\n",
    "sns.set(font_scale=2.2)\n",
    "plt.figure(figsize=(5.5, 2))\n",
    "sns.boxplot(data=total_df, x='Method', hue='Method', y='full y2 coverage', order=curr_methods_order,\n",
    "            palette=color_palette, legend=False, showfliers=False)\n",
    "\n",
    "# Find the x position of \"WCP\"\n",
    "wcp_index = curr_methods_order.index(\"WCP\")  # Get index of \"WCP\" in x-axis order\n",
    "\n",
    "# Add text above the \"WCP\" boxplot\n",
    "# plt.text(wcp_index, total_df[total_df['Method'] == 'WCP'][\"full y2 coverage\"].mean()-2.5,  # Adjust y position\n",
    "#          \"Infeasible\", ha='center', va='bottom', fontsize=15, color='black', rotation=45)\n",
    "\n",
    "plt.text(wcp_index, total_df[total_df['Method'] == 'WCP'][\"full y2 coverage\"].mean()-3.5,  # Adjust y position\n",
    "         \"(Infeasible)\", ha='center', va='bottom', fontsize=15, color='black')\n",
    "\n",
    "plt.ylabel(\"Coverage\")\n",
    "plt.xlabel(\"\")\n",
    "plt.axhline(y=90, color='r', linestyle='--')\n",
    "save_dir = os.path.join(figure_path, \"intro_meps\")\n",
    "os.makedirs(save_dir, exist_ok=True)\n",
    "plt.savefig(os.path.join(save_dir, \"coverage.png\"), dpi=300, bbox_inches='tight')\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d0a6ce7d-6023-420a-b96f-c9f1fa1e24c9",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
