{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "03ea5372-1580-4ae4-b770-43b48491cc82",
   "metadata": {},
   "source": [
    "# Triply robust method analysis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "6b97df7a-6cf9-4551-91c1-54f42805dbe1",
   "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 display_plot_utils import read_methods_results, process_methods_df\n",
    "plt.rcParams['text.usetex'] = True\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "9759c82d-6b1a-4061-b311-a4821bf8dac0",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_base_path = '../src/results/old syn data'\n",
    "paper_figures_path = 'figures/paper_figures'\n",
    "seeds = 30"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a08f791e-9e37-496e-9ad1-d0777258722a",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['oracle_qr_triply_robust_oracle_imputation_cqr_calibration_pcp_cqr_bad_oracle_masker',\n",
       "       'oracle_qr_triply_robust_oracle_imputation_cqr_calibration_pcp_cqr_oracle_masker',\n",
       "       'oracle_qr_triply_robust_bad_imputation_cqr_calibration_pcp_cqr_bad_oracle_masker',\n",
       "       'oracle_qr_triply_robust_bad_imputation_cqr_calibration_pcp_cqr_oracle_masker',\n",
       "       'bad_qr_triply_robust_oracle_imputation_cqr_calibration_pcp_cqr_bad_oracle_masker',\n",
       "       'bad_qr_triply_robust_oracle_imputation_cqr_calibration_pcp_cqr_oracle_masker',\n",
       "       'bad_qr_triply_robust_bad_imputation_cqr_calibration_pcp_cqr_bad_oracle_masker',\n",
       "       'bad_qr_triply_robust_bad_imputation_cqr_calibration_pcp_cqr_oracle_masker'],\n",
       "      dtype=object)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset_name = 'missing_y_regression_synthetic_z3'\n",
    "oracle_methods = []\n",
    "for qr_method in ['oracle_qr', 'bad_qr']:\n",
    "    for imputation in ['oracle_imputation', 'bad_imputation', ]:\n",
    "        for weighted in ['pcp_cqr_bad_oracle_masker', 'pcp_cqr_oracle_masker']:\n",
    "            oracle_methods += [f'{qr_method}_triply_robust_{imputation}_cqr_calibration_{weighted}']\n",
    "\n",
    "\n",
    "total_df = pd.DataFrame()\n",
    "dfs = []\n",
    "try:\n",
    "    data_df = read_methods_results(results_base_path, dataset_name, oracle_methods, apply_mean=False, \n",
    "                                   seeds=30, display_errors=True)\n",
    "    data_df = process_methods_df(data_df)\n",
    "    data_df['Dataset'] = dataset_name\n",
    "    dfs.append(data_df)\n",
    "except Exception as e:\n",
    "    print(f\"data: {dataset_name}, error: {e}\")\n",
    "total_df = pd.concat(dfs)\n",
    "display(data_df['Method'].unique())\n",
    "\n",
    "total_df['QR'] = total_df['Method'].apply(lambda x: 'oracle' if 'oracle_qr' in x else 'degenerate')\n",
    "total_df['Imputation'] = total_df['Method'].apply(lambda x: 'oracle' if 'oracle_imputation' in x\\\n",
    "                                                  else 'full+oracle' if 'full_with_oracle_error_sampler' in x\\\n",
    "                                                  else 'degenerate')\n",
    "total_df['PCP'] = total_df['Method'].apply(lambda x: 'oracle' if 'cqr_oracle' in x else 'degenerate')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "2a8a78a4-997f-4b67-adad-cfd3e8bedf97",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 1000x200 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1296.33x318.182 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(10, 2))\n",
    "sns.set(rc={'figure.figsize':(10,2)})\n",
    "sns.set(font_scale=2)\n",
    "g = sns.catplot(data=total_df, x='Imputation', y='full y2 coverage', hue='PCP', col='QR',\n",
    "           kind=\"box\", hue_order=['degenerate', 'oracle'], col_order=['degenerate', 'oracle'], order=['degenerate', 'oracle'],\n",
    "            height = 3.5/1.1, aspect=6.4/1.1/3.5\n",
    ")\n",
    "for axes in g.axes:\n",
    "    for ax in axes:\n",
    "        ax.set_ylabel(\"Coverage\")\n",
    "        ax.axhline(y=90, color='r', linestyle='--')\n",
    "g.set_titles(col_template=\"{col_name} QR\")  # Removes 'QR ='\n",
    "os.makedirs(\"figures/paper_figures/oracles\", exist_ok=True)\n",
    "plt.savefig(\"figures/paper_figures/oracles/oracles_exp.png\", bbox_inches='tight',dpi=300)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be825c89-5410-4ccd-a296-d6748acbdda1",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:oqr]",
   "language": "python",
   "name": "conda-env-oqr-py"
  },
  "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.12.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
