{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "cd5c007f-3459-4340-a6db-ff556dbfce75",
   "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": 7,
   "id": "820975a3-83cf-4398-8878-bd0fe31f5b6b",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_base_path = '../src/results'\n",
    "paper_figures_path = 'figures/paper_figures'\n",
    "figure_path = paper_figures_path\n",
    "seeds = 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cca53423-949e-42f6-8af0-967544c172cc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c482f1cd-196b-4a5c-b1bd-3ac3c86026d3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f9bac89f-158f-4f19-9e2c-95415f24d6dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "original_dataset_names = ['facebook_1', 'facebook_2', 'bio', 'house', 'meps_19']\n",
    "original_data = 'facebook_1'\n",
    "corruption_type = 'missing_y'\n",
    "dataset_name = f'{corruption_type}_{original_data}'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "38ac5207-4370-4d8b-9c3a-7e7dc2e98af1",
   "metadata": {},
   "outputs": [],
   "source": [
    "methods = ['qr_full_with_linear_with_linear_clustering_error_sampler_imputation_cqr_calibration']\n",
    "data_df = read_methods_results(results_base_path, dataset_name, methods, apply_mean=False, seeds=seeds,\n",
    "                              display_errors=True)\n",
    "data_df = process_methods_df(data_df)\n",
    "data_df['Dataset'] = dataset_name.replace(f\"{corruption_type}_\", \"\").replace(\"meps_19\", \"meps19\")\\\n",
    "                                    .replace(\"facebook_1\", \"facebook1\").replace(\"facebook_2\", \"facebook2\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "6f3cfbbd-7da0-442a-a556-f30ddced6d1f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mse:  1.842\n",
      "rmse:  1.339\n",
      "rrmse:  6.589\n",
      "mape:  1947.0049999999999\n",
      "smape:  72.14500000000001\n",
      "nrmse:  0.8009999999999999\n",
      "relative_error:  -0.10000000000000002\n",
      "abs_relative_error:  0.7529999999999999\n",
      "r2:  -inf\n",
      "model_pred_partial_correlation:  -0.073\n",
      "model_pred_clustering_correlation:  -0.6769999999999999\n",
      "model_pred_mean_clustering_correlation:  0.31899999999999995\n",
      "model_pred_cmi_knn:  4.765000000000001\n",
      "model_pred_kci_pval:  0.857\n",
      "int1_partial_correlation:  -0.016999999999999998\n",
      "int1_clustering_correlation:  -0.625\n",
      "int1_mean_clustering_correlation:  0.279\n",
      "int1_cmi_knn:  3.0749999999999997\n",
      "int1_kci_pval:  0.8940000000000001\n",
      "int2_partial_correlation:  -0.033\n",
      "int2_clustering_correlation:  -0.473\n",
      "int2_mean_clustering_correlation:  0.292\n",
      "int2_cmi_knn:  2.776\n",
      "int2_kci_pval:  0.8290000000000001\n"
     ]
    }
   ],
   "source": [
    "metrics = [\"mse\",\n",
    "\"rmse\",\n",
    "\"rrmse\",\n",
    "\"mape\",\n",
    "\"smape\",\n",
    "\"nrmse\",\n",
    "\"relative_error\",\n",
    "\"abs_relative_error\",\n",
    "\"r2\",\n",
    "          'model_pred_partial_correlation',\n",
    "          'model_pred_clustering_correlation',\n",
    "          'model_pred_mean_clustering_correlation',\n",
    "          'model_pred_cmi_knn',\n",
    "          'model_pred_kci_pval',\n",
    "\n",
    "           \n",
    "          'int1_partial_correlation',\n",
    "          'int1_clustering_correlation',\n",
    "          'int1_mean_clustering_correlation',\n",
    "          'int1_cmi_knn',\n",
    "          'int1_kci_pval',\n",
    "\n",
    "           \n",
    "          'int2_partial_correlation',\n",
    "          'int2_clustering_correlation',\n",
    "          'int2_mean_clustering_correlation',\n",
    "          'int2_cmi_knn',\n",
    "          'int2_kci_pval',\n",
    "          ]\n",
    "for metric in metrics:\n",
    "    print(f\"{metric}: \", data_df[metric].mean().item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "c0d40bff-1d78-4f38-883f-75a6210197ec",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "original_dataset_names = ['facebook_1', 'bio', 'house']\n",
    "corruption_type = 'missing_y'\n",
    "dataset_names = [f'{corruption_type}_{d}' for d in original_dataset_names]\n",
    "methods = ['qr_full_with_linear_with_linear_clustering_error_sampler_imputation_cqr_calibration']\n",
    "dfs = []\n",
    "for dataset_name in dataset_names:\n",
    "    data_df = read_methods_results(results_base_path, dataset_name, methods, apply_mean=False, seeds=seeds,\n",
    "                                  display_errors=False)\n",
    "    data_df = process_methods_df(data_df)\n",
    "    data_df['Dataset'] = dataset_name.replace(f\"{corruption_type}_\", \"\").replace(\"meps_19\", \"meps19\")\\\n",
    "                                        .replace(\"facebook_1\", \"facebook1\").replace(\"facebook_2\", \"facebook2\")\n",
    "    # data_df['mse'] = data_df['mse'] * (data_df['y_scale'] ** 2)\n",
    "    # data_df['mae'] *= data_df['y_scale']\n",
    "    # data_df['rmse'] *= data_df['y_scale']\n",
    "\n",
    "    dfs.append(data_df)\n",
    "total_df = pd.concat(dfs) \n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "cdfb679c-ad31-4487-9f18-d112641a0129",
   "metadata": {},
   "outputs": [],
   "source": [
    "metrics = ['Dataset','full y2 coverage','y2 length', 'mse', 'model_pred_partial_correlation', 'int1_partial_correlation', 'int2_partial_correlation',\n",
    "          ]\n",
    "# total_df = total_df[metrics]\n",
    "# total_df = total_df.groupby('Dataset').agg('mean').apply(lambda x: np.round(x,2)).reset_index()\n",
    "# print(total_df.to_markdown(index=False))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "8b672f9c-a9a1-4b88-9e36-32403c838eb0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{llllll}\n",
      "\\toprule\n",
      "\\textbf{Dataset} & \\textbf{Coverage rate} & \\textbf{$\\hat{g}$ MSE} & \\textbf{$\\hat{g}$ PC} & \\textbf{$C^0$ PC} & \\textbf{$C^1$ PC} \\\\\n",
      "\\midrule\n",
      "bio & $90.72 \\pm 0.49$ & $0.56 \\pm 0.00$ & $-0.02 \\pm 0.00$ & $0.03 \\pm 0.00$ & $-0.02 \\pm 0.00$ \\\\\n",
      "facebook1 & $90.96 \\pm 0.36$ & $1.84 \\pm 0.21$ & $-0.07 \\pm 0.05$ & $-0.02 \\pm 0.04$ & $-0.03 \\pm 0.05$ \\\\\n",
      "house & $91.23 \\pm 0.36$ & $0.71 \\pm 0.03$ & $0.15 \\pm 0.01$ & $0.18 \\pm 0.01$ & $0.19 \\pm 0.01$ \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "metrics = [\n",
    "    'Dataset',\n",
    "    'full y2 coverage',\n",
    "    # 'y2 length',\n",
    "    'mse',\n",
    "    'model_pred_partial_correlation',\n",
    "    'int1_partial_correlation',\n",
    "    'int2_partial_correlation',\n",
    "]\n",
    "\n",
    "# Mapping of old metric names to LaTeX-friendly names\n",
    "rename_dict = {\n",
    "    'full y2 coverage': 'Coverage rate',\n",
    "    # 'y2 length': 'Interval length',\n",
    "    'mse': r'$\\hat{g}$ MSE',\n",
    "    'model_pred_partial_correlation': r'$\\hat{g}$ PC',\n",
    "    'int1_partial_correlation': r'$C^0$ PC',\n",
    "    'int2_partial_correlation': r'$C^1$ PC',\n",
    "}\n",
    "\n",
    "# Keep only the relevant columns\n",
    "df = total_df[metrics].copy()\n",
    "\n",
    "# Function to format mean ± SE with LaTeX\n",
    "def mean_se(x):\n",
    "    mean = np.mean(x)\n",
    "    se = np.std(x, ddof=1) / np.sqrt(len(x))  # standard error\n",
    "    return f\"${mean:.2f} \\\\pm {se:.2f}$\"\n",
    "\n",
    "# Group by dataset and aggregate with mean ± SE\n",
    "summary_df = df.groupby('Dataset').agg(lambda col: mean_se(col) if col.dtype != 'O' else col.iloc[0])\n",
    "\n",
    "# Rename the columns\n",
    "summary_df = summary_df.rename(columns=rename_dict).reset_index()\n",
    "\n",
    "bold_cols = {col: f\"\\\\textbf{{{col}}}\" for col in summary_df.columns}\n",
    "summary_df = summary_df.rename(columns=bold_cols)\n",
    "\n",
    "\n",
    "# Output LaTeX table\n",
    "print(summary_df.to_latex(index=False, escape=False))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "44caa859-f20f-49db-867f-4c0af4a69921",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2717a8dc-9a78-49ff-895c-076f8381d485",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d33747ab-45aa-43a4-85e9-373b13fa71ea",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "119c4fcb-3291-4263-8d94-e6124732262f",
   "metadata": {},
   "outputs": [],
   "source": [
    "original_dataset_names = ['facebook_1', 'bio', 'house',]\n",
    "original_data = 'house'\n",
    "corruption_type = 'missing_y'\n",
    "es = [1, 25, 50, 100, 500, 1000, 5000, 10000, 50000]\n",
    "dataset_names = [f'e_{e}_{corruption_type}_{original_data}' for e in es]\n",
    "methods = ['qr_full_with_linear_with_linear_clustering_error_sampler_imputation_cqr_calibration']\n",
    "dfs = []\n",
    "for dataset_name in dataset_names:\n",
    "    try:\n",
    "        data_df = read_methods_results(results_base_path, dataset_name, methods, apply_mean=False, seeds=seeds,\n",
    "                                      display_errors=False)\n",
    "        data_df = process_methods_df(data_df)\n",
    "        data_df['Dataset'] = dataset_name.replace(f\"{corruption_type}_\", \"\").replace(\"meps_19\", \"meps19\")\\\n",
    "                                            .replace(\"facebook_1\", \"facebook1\").replace(\"facebook_2\", \"facebook2\")\n",
    "        data_df['e'] = int(dataset_name.replace(f\"{corruption_type}_\", \"\").replace(f\"_{original_data}\", \"\").replace(\"e_\", \"\"))\n",
    "        data_df['mse'] = data_df['mse'] * (data_df['y_scale'] ** 2)\n",
    "        data_df['mae'] *= data_df['y_scale']\n",
    "        data_df['rmse'] *= data_df['y_scale']\n",
    "        data_df['y2 length'] *= data_df['y_scale']\n",
    "        dfs.append(data_df)\n",
    "    except:\n",
    "        continue\n",
    "total_df = pd.concat(dfs) \n",
    "total_df['Noise s.t.d'] = total_df['e'] / 10\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4bd59480-d5b0-4c80-98e3-65630b1d6fb6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "c5e70c63-7c58-445d-ad82-0f734b485b05",
   "metadata": {},
   "outputs": [],
   "source": [
    "# metrics = ['Noise s.t.d', 'full y2 coverage', 'rmse', 'y2 length']\n",
    "# import copy\n",
    "# summary = copy.deepcopy(total_df)\n",
    "# summary = summary[metrics]\n",
    "# # summary.reset_index(inplace=True)\n",
    "# print(summary.to_markdown(index=False))\n",
    "# # print(summary.to_latex(index=False, float_format=\"%.2f\"))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "f6d46235-58d3-48b3-9e1f-b8c7ef5ba00d",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Shai1\\AppData\\Local\\Temp\\ipykernel_300492\\1909045331.py:21: UserWarning: set_ticklabels() should only be used with a fixed number of ticks, i.e. after set_ticks() or using a FixedLocator.\n",
      "  ax.set_xticklabels([f\"{v:g}\" for v in sorted_vals], rotation=30, ha='right')\n"
     ]
    },
    {
     "data": {
      "image/png": "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v/0AlahUKgwbNgzXXHMNAODkyZMYMmQIAgICOm15CJVKhfr6epSWlgIAYmNjHcaWSGOChg4dirvuugtXXnkl6urq8Morr+DAgQM+aXNLpCAFNI1tCggIQHV1Nerq6uTxW/aPA0CfPn1w++234+abbwYAvPbaa/juu++812g3qFQqHDlyBF999RWAphM58OcJXjpWI0eOxN13343w8HAcPHgQGzduRFVVlU/a7Ipu3brh9OnT+P333/H777+jtrYWwJ8BWTqhDxo0CAaDAaNHj8bp06exceNG/PLLLz5rd1t27NiBX375Beeccw5uuOEGAH8eK+n/0dHRuOeeexAcHIzvvvsOb7zxRrP3qr+QjsfJkydx6tQpWK1WnDp1ymEZqVPg0ksvxf/93/9h8ODBOHLkCF599VUcPXrU621WCkNXFxQQEIDrr78eY8eOxQsvvID4+Hj06NFDHpPx5ZdfYtu2bfKHpz8HFOkPb/To0Rg7dixCQkJQWlqKt99+G0DTybGhoQEBAQFQqVSwWq2d5iaBa665Btdddx169+6NPXv24NVXXwXQvAflTP4ayhobG1FfXy8PTP7+++8BOC93MXToUCQnJwNo+gb/xhtvyAOcfcW+RIcUpCS//vorzj33XISGhuLYsWMAnN/Kft555yElJQVqtRo//PADCgsLfR5SWvv7vuiiixAYGIiKigoAzfdJpVJh5MiRmDFjBoCmLzzvvvuu37wHne3b8ePH0a9fPwwYMACHDx8G4PxYXXjhhZgzZw6ApjuhX3/99WYnfn/RvXt39OvXD0FBQTCbzQD+3Cfp/927d8d1112Hu+++GwDwxhtv4KOPPvJNg52wP1ZSm2tqahAcHIx+/frh119/bfG5ERER+Pvf/w4AMBqNeOutt/y+F7klDF1d1NChQ5GXlyd3Nzc0NOCvf/0rxo0bByEEPvnkE3z55ZcA/L8OihACgYGBiImJwVVXXQUAWL16NWpqahAUFIRu3brh5MmT+Pe//43/+7//Q3JyMmbOnIm1a9fKZRf81Y033oiRI0cCAF5++WUcP34c3bp1Q0NDg3zi37x5M95//318+OGHOHbsmBxO/C0sS7100onrxIkTAJy3MyAgADExMfLluPfffx//+9//vNdYO/v27cMtt9yC++67Dx9//DF2797dbJmLL74Y3bp1g81mw759+wCgxQ99+0C5detWfP75555rvAta+vtubGzEiRMnIIRo9VgFBgZi0qRJiI6ORn19Pd577z3s2bPHo21uSUu10exD4KWXXorTp0/j4MGDcuhq6Vjp9Xr5PVhSUuK3l0/r6+vxxx9/QAgh994507NnT9xzzz24+OKLcezYMbz99ts4dOiQF1v6p5Zqo9lfibjkkktw8uRJlJeXo7q6GkDLXypvvvlmjB07Fg0NDSgpKcH+/fu9sBfKY+jq4qQPG6m34cEHHwTQ1AuxdetWVFZWAvC/E7g96Y916NChuPHGG9G/f3/88MMPWLNmDYCmD8uEhASsWbMGe/bsgclkQmlpKZ555hncf//9eO+993D69Glf7kKLLrnkEsTExGDQoEGorKxEbm4ugKbLIGVlZYiPj8dDDz2E+fPn47777sMdd9yB++67DwcOHPDqMautrcX777+P3377DYDz90tjYyN69eolh8jNmzcDaD3U33PPPVCr1di/fz9MJlOLvXueUFNTg0cffRSxsbH48ccfMXLkSDz//PO4/PLLHZaT/oakS3AbNmxAY2Ojw+XtM91xxx247LLLUF1dLY+h9Jbjx48jKysLGRkZePzxx1FSUiKHD+mEJoTABRdcAJ1Oh4aGBnzwwQetrrNHjx6YNWsWAGDnzp343//+59X339GjRzFnzhzExcVh4sSJMBgMmDt3rlyryn7MVu/evXHjjTcCAF555RUAf15WdCYpKQlhYWGwWCwwmUxe7cWzWCx46qmnkJGRgaeeegplZWU4fvw4AMfwERkZiSFDhsjvJ6DlINmnTx+5x9ZkMuHrr7/28F44+uWXXzB16lRMmDABt99+O+6880489thj2LRpE4CmzwOVSgUhBC677DL5zlLprvSWPi+6d+8u93bt2LFD7jTobBi6ujjpw0Z6k19yySVISUkB0HRZp6ysTH7cn0kf8Ndff708Dio/Px+7d+9GUVERDh06hL/+9a9Ys2YNli1bhokTJ6Jv377Yu3cvnn76aaxdu9aHrW/dX/7yF0RFRUGlUqGgoAC7d+/Gl19+iaSkJPzyyy+4+OKLMW7cOJx//vk4fvw4SktLMXfuXPmE4g15eXl47rnn8O233wJw/n6RTnxXXXUVQkJCYDab5ZN5SyeISy65RO4Veu+99/DTTz95oPWOGhoa8Oqrr2LUqFF45513cN5552HhwoVYuXIlxo8f3+xyqPQ3dNFFF+H888/HkSNHsH79egAtf1mxP/G99dZbXuntOn36NLKzs6HX65GXl4dXX30V+fn5uP/++3HHHXegrKxM7oWUwm1UVBQAoLi4GOXl5VCpVC0eq2uvvRYGgwEA8O6778pBzpOEEHj33Xdx3XXXYevWrTj33HNxwQUXAAA++OADLF68GM888wx27twpP6ehoQFarRbnnHMOvv32W5SUlMi/d2bIkCHyezA/P1++1OpJJ06cwCOPPIJx48Zhw4YNePXVV7FhwwakpKRg2rRp2L17t3yMTp8+DSEErrvuOgDAxo0b5R7xlgJifHy83Cv03nvvoaamxuP7VF9fj5ycHMTHx+Pbb79F3759ccEFF+DkyZN4++23MW/ePKxYsUKuNC/1io8YMQIqlQqbNm1CRUVFq+/BUaNGYerUqQCaXgd/GwvqCoaus4h0okxJScF5552Hw4cPY+vWrfLllM7Q2zVgwACMGzcOl1xyCY4dO4Z7770XH330ESZOnIhVq1YhKioK8fHxePrpp7F48WIATd/8ly5d6pUTentIlZeHDh2KEydOYNmyZdiwYQMCAwPx4IMPYtOmTXj++eexfv16PPTQQwCAiooKrFixwiuXQ77++mt5sPuWLVvku6Jaer8MHDgQERERAJouAwshWu0VmjBhAi6++GL89ttv8rg2TykrK8Po0aORkZEBlUqFe+65B6+99hruuuuuFu+Gldqt0+lw8cUXA2jq7frtt99avfFBr9fjmmuuQWNjo8f3q7GxEU888QReeuklhISEICUlBQ899BAmT56MoUOH4ujRo1i4cCGeffZZAJDr2l100UXybAc5OTkAWu8VuvPOOxEWFoby8nJ5XKUn/fLLL3jppZcQHByMBQsW4LXXXsP69euxevVqOSht2LAB8+fPR21tLbp164Zu3bph+PDhGDx4MICmLwxt9UyOHz8eF110EY4dO4a33nrLo/sk1UZ79913MXDgQNx///1ITU3FrbfeikGDBmHfvn1IS0vDypUrATQdK5VKhcsvvxwDBw7EiRMnkJeXB6D1XqGkpCQATXeofvjhhx7dJwDYvn071q1bh379+uHZZ5/F+vXrsXHjRuTk5Mh3iq5YsQL//Oc/ATS9z3r27IkrrrgC4eHhaGhokIspt/YenDBhAtRqNXbv3u2V/VIaQ1cnoGQYamxs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5lxXrI3WVbDrwA9de+21mDNnDnr06IGvv/4a//znP7Fx40ZUVVWhtrYWtbW1eOWVV7Bv3z5cc801SExM9HWT3bZ161YMHDgQ4eHhqK+vR0VFBZYuXYr58+ejrKwM3bt3x/r161FcXIyePXv6urnUgnXr1uGbb77B9ddf7+umKEb46S3rUrtYG+1PrI3mXFerjdaV8BXwQwEBARg3bhwWLlwod0U/+eSTiImJwezZsxEXF4d169ahW7duuP/++6FWq33dZLdUVVVh+/btGDFiBI4dO4aXX34Zf//73/H222+jsbERCxYswDfffOPRW/NJGeeee26Hp43yN/56yzproymPtdE6R220roShy49NnjwZK1asQGxsLAYMGICamhrs3LkTv/76K2655RaUlZV1ymBy6NAh1NbWoqGhAQ8//DCee+45HDlyBDfffDO2b9+Oe+65x+ffxon8GWujKYe10XxbG+1sw4H0fm7o0KHIzs7GH3/8IQ8qvfjii9G/f38ft6z9du7cCQBybZvBgwdj5cqV8oBPInLuzNpoS5YskWujff3116iurkb37t07fW206upqv6iNtmnTJrk2WkREBC666CKHmxbOrI1mtVrxxhtvYPXq1fj9998xa9Ys+bM6ICAApaWlXq+NZjabUVFRgWXLliE4OBiBgYG4//775fpae/fuxbZt2/DMM8+goqIClZWVGDVqlNy7KN3AkJ6eji1btmDPnj2YP38+Ro0ahZCQEPzxxx8dqo12tlEJfx3AQDJpdveu4ssvv8S9996LEydO4IUXXsANN9zg6yYRdQr2vSYAMG7cOFRWVso9DgsWLMBdd93VaXqKP/74Y3z00Ue4+eab0b17d5w4cQLff/891q9fj4MHD2LgwIHIycnBpZde6tV2SXfxrVq1CsuWLUOfPn1w7733Ytq0aa2+ttXV1XjooYdgMpkANBVQve6663DJJZfg4MGDePHFF1FTU4MZM2bgkUce8fh+nDp1Ci+++CJeeeUVuVp8REQENmzYgF69ejkEyAULFsjjtkaMGIGCggKHdWVnZ6OoqAiHDx9Gz549ERgYiBEjRuC7775DTU0NzjvvPKxduxaXXHKJx/erM2PoIq+rq6vDV199hZEjR3q0e52oq/rxxx+xfPlylJSUAADi4+ORkZGB0NBQH7fMPcuXL8fKlSvlfwcHB8vh4JZb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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "sns.set(font_scale=2.2)\n",
    "\n",
    "# ensure the column is numeric (important if values were strings)\n",
    "total_df['Noise s.t.d'] = total_df['Noise s.t.d'].astype(float)\n",
    "\n",
    "# sort unique values numerically and use them as the order\n",
    "sorted_vals = sorted(total_df['Noise s.t.d'].unique())\n",
    "\n",
    "ax = sns.boxplot(\n",
    "    data=total_df,\n",
    "    x='Noise s.t.d',\n",
    "    y='full y2 coverage',\n",
    "    showfliers=False,\n",
    "    order=sorted_vals  # enforce numeric order for the categorical plot\n",
    ")\n",
    "\n",
    "# set readable labels: {:g} removes trailing .0 (10.0 -> 10), keeps decimals (0.1 -> 0.1)\n",
    "ax.set_xticklabels([f\"{v:g}\" for v in sorted_vals], rotation=30, ha='right')\n",
    "\n",
    "plt.ylabel(\"Coverage\")\n",
    "plt.title(f\"{original_data} dataset\")\n",
    "plt.tight_layout()\n",
    "save_dir = os.path.join(paper_figures_path, \"noise_exp\")\n",
    "os.makedirs(save_dir, exist_ok=True)\n",
    "plt.savefig(os.path.join(save_dir, f\"{original_data}_coverage.png\"), dpi=300, bbox_inches='tight')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "41d83f90-baf5-444d-a646-ec18e3f92e12",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dcfa7037-e10f-42cf-8d36-e1a569615bbf",
   "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.12.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
