{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "351f5546-572a-48d2-88bb-cd8ca41db6ca",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.insert(0, '../Results')\n",
    "sys.path.insert(0, '../../src')\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pickle\n",
    "import os\n",
    "from utils.visualization_utils import perc, SetPlotRC, ApplyFont\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "11014395-789a-4ae5-afb7-67d962dc187f",
   "metadata": {},
   "outputs": [],
   "source": [
    "if not os.path.exists(\"Figures\"):\n",
    "    os.mkdir(\"Figures\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b77e1893-1098-4efe-905c-52702e9dc84d",
   "metadata": {},
   "source": [
    "# RBF Kernel Length Scale Ablation Study"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "65cadd09-4612-41ab-839f-6d2bf908f626",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(900, 6)\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Algorithm</th>\n",
       "      <th>l_quantile</th>\n",
       "      <th>MSE</th>\n",
       "      <th>MSE_std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.055435</td>\n",
       "      <td>0.035464</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.028723</td>\n",
       "      <td>0.016901</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.026604</td>\n",
       "      <td>0.015881</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.027372</td>\n",
       "      <td>0.018847</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.034501</td>\n",
       "      <td>0.019472</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0.90</td>\n",
       "      <td>0.222739</td>\n",
       "      <td>0.096864</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.026455</td>\n",
       "      <td>0.011333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.020057</td>\n",
       "      <td>0.011644</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.019619</td>\n",
       "      <td>0.012992</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.024065</td>\n",
       "      <td>0.018688</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.034029</td>\n",
       "      <td>0.033190</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0.90</td>\n",
       "      <td>0.225297</td>\n",
       "      <td>0.130187</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.220788</td>\n",
       "      <td>0.058264</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.088199</td>\n",
       "      <td>0.053170</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.072904</td>\n",
       "      <td>0.070558</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.068177</td>\n",
       "      <td>0.071517</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.076283</td>\n",
       "      <td>0.071089</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0.90</td>\n",
       "      <td>0.323913</td>\n",
       "      <td>0.166720</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.221342</td>\n",
       "      <td>0.117814</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.056341</td>\n",
       "      <td>0.026099</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.039763</td>\n",
       "      <td>0.019668</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.034562</td>\n",
       "      <td>0.021965</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.036207</td>\n",
       "      <td>0.029600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0.90</td>\n",
       "      <td>0.082134</td>\n",
       "      <td>0.051155</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.030609</td>\n",
       "      <td>0.013305</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.021929</td>\n",
       "      <td>0.009438</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.019066</td>\n",
       "      <td>0.009375</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.026696</td>\n",
       "      <td>0.011843</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.035102</td>\n",
       "      <td>0.020881</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0.90</td>\n",
       "      <td>0.249675</td>\n",
       "      <td>0.115741</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Algorithm  l_quantile       MSE   MSE_std\n",
       "0      DRKPV        0.25  0.055435  0.035464\n",
       "1      DRKPV        0.40  0.028723  0.016901\n",
       "2      DRKPV        0.50  0.026604  0.015881\n",
       "3      DRKPV        0.60  0.027372  0.018847\n",
       "4      DRKPV        0.75  0.034501  0.019472\n",
       "5      DRKPV        0.90  0.222739  0.096864\n",
       "6     DRPMMR        0.25  0.026455  0.011333\n",
       "7     DRPMMR        0.40  0.020057  0.011644\n",
       "8     DRPMMR        0.50  0.019619  0.012992\n",
       "9     DRPMMR        0.60  0.024065  0.018688\n",
       "10    DRPMMR        0.75  0.034029  0.033190\n",
       "11    DRPMMR        0.90  0.225297  0.130187\n",
       "12       KAP        0.25  0.220788  0.058264\n",
       "13       KAP        0.40  0.088199  0.053170\n",
       "14       KAP        0.50  0.072904  0.070558\n",
       "15       KAP        0.60  0.068177  0.071517\n",
       "16       KAP        0.75  0.076283  0.071089\n",
       "17       KAP        0.90  0.323913  0.166720\n",
       "18       KPV        0.25  0.221342  0.117814\n",
       "19       KPV        0.40  0.056341  0.026099\n",
       "20       KPV        0.50  0.039763  0.019668\n",
       "21       KPV        0.60  0.034562  0.021965\n",
       "22       KPV        0.75  0.036207  0.029600\n",
       "23       KPV        0.90  0.082134  0.051155\n",
       "24      PMMR        0.25  0.030609  0.013305\n",
       "25      PMMR        0.40  0.021929  0.009438\n",
       "26      PMMR        0.50  0.019066  0.009375\n",
       "27      PMMR        0.60  0.026696  0.011843\n",
       "28      PMMR        0.75  0.035102  0.020881\n",
       "29      PMMR        0.90  0.249675  0.115741"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_doubly_robustKPV_SyntheticLowDim = pd.read_pickle(r\"../Results/DoublyRobustKPV_RBF_LengthScale_Ablation_SyntheticLowDim_Experiment.pkl\")\n",
    "df_doubly_robustPMMR_SyntheticLowDim = pd.read_pickle(r\"../Results/DoublyRobustPMMR_RBF_LengthScale_Ablation_SyntheticLowDim_Experiment.pkl\")\n",
    "df_RBF_length_scale_SyntheticData = pd.concat([df_doubly_robustKPV_SyntheticLowDim, df_doubly_robustPMMR_SyntheticLowDim])\n",
    "print(df_RBF_length_scale_SyntheticData.shape)\n",
    "\n",
    "df_results_aggregated = df_RBF_length_scale_SyntheticData.groupby(['Algorithm', 'l_quantile']).agg({ \"Causal_MSE\" : [\"mean\", \"std\"]}).set_axis([\"MSE\", \"MSE_std\"], axis=1).reset_index()\n",
    "df_results_aggregated"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "0ca72bf3-3bce-4656-88e4-f37923f894a0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(900, 6)\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Algorithm</th>\n",
       "      <th>l_quantile</th>\n",
       "      <th>MSE</th>\n",
       "      <th>MSE_std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.024830</td>\n",
       "      <td>0.007798</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.020368</td>\n",
       "      <td>0.014919</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.018547</td>\n",
       "      <td>0.010231</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.019734</td>\n",
       "      <td>0.012334</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.023987</td>\n",
       "      <td>0.016977</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0.90</td>\n",
       "      <td>0.021048</td>\n",
       "      <td>0.018496</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.016937</td>\n",
       "      <td>0.005547</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.015646</td>\n",
       "      <td>0.008659</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.016415</td>\n",
       "      <td>0.009294</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.018386</td>\n",
       "      <td>0.009437</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.025628</td>\n",
       "      <td>0.013936</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0.90</td>\n",
       "      <td>0.022653</td>\n",
       "      <td>0.015066</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.022234</td>\n",
       "      <td>0.006186</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.019409</td>\n",
       "      <td>0.011881</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.027124</td>\n",
       "      <td>0.019455</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.037846</td>\n",
       "      <td>0.026202</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.054879</td>\n",
       "      <td>0.036611</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0.90</td>\n",
       "      <td>0.033689</td>\n",
       "      <td>0.020920</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.032171</td>\n",
       "      <td>0.015349</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.026979</td>\n",
       "      <td>0.018373</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.021337</td>\n",
       "      <td>0.012578</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.017667</td>\n",
       "      <td>0.013173</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.014595</td>\n",
       "      <td>0.012779</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0.90</td>\n",
       "      <td>0.014111</td>\n",
       "      <td>0.012040</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.014362</td>\n",
       "      <td>0.005472</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.013993</td>\n",
       "      <td>0.008152</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.014622</td>\n",
       "      <td>0.008629</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.015109</td>\n",
       "      <td>0.008832</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.014244</td>\n",
       "      <td>0.007628</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0.90</td>\n",
       "      <td>0.013324</td>\n",
       "      <td>0.009472</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Algorithm  l_quantile       MSE   MSE_std\n",
       "0      DRKPV        0.25  0.024830  0.007798\n",
       "1      DRKPV        0.40  0.020368  0.014919\n",
       "2      DRKPV        0.50  0.018547  0.010231\n",
       "3      DRKPV        0.60  0.019734  0.012334\n",
       "4      DRKPV        0.75  0.023987  0.016977\n",
       "5      DRKPV        0.90  0.021048  0.018496\n",
       "6     DRPMMR        0.25  0.016937  0.005547\n",
       "7     DRPMMR        0.40  0.015646  0.008659\n",
       "8     DRPMMR        0.50  0.016415  0.009294\n",
       "9     DRPMMR        0.60  0.018386  0.009437\n",
       "10    DRPMMR        0.75  0.025628  0.013936\n",
       "11    DRPMMR        0.90  0.022653  0.015066\n",
       "12       KAP        0.25  0.022234  0.006186\n",
       "13       KAP        0.40  0.019409  0.011881\n",
       "14       KAP        0.50  0.027124  0.019455\n",
       "15       KAP        0.60  0.037846  0.026202\n",
       "16       KAP        0.75  0.054879  0.036611\n",
       "17       KAP        0.90  0.033689  0.020920\n",
       "18       KPV        0.25  0.032171  0.015349\n",
       "19       KPV        0.40  0.026979  0.018373\n",
       "20       KPV        0.50  0.021337  0.012578\n",
       "21       KPV        0.60  0.017667  0.013173\n",
       "22       KPV        0.75  0.014595  0.012779\n",
       "23       KPV        0.90  0.014111  0.012040\n",
       "24      PMMR        0.25  0.014362  0.005472\n",
       "25      PMMR        0.40  0.013993  0.008152\n",
       "26      PMMR        0.50  0.014622  0.008629\n",
       "27      PMMR        0.60  0.015109  0.008832\n",
       "28      PMMR        0.75  0.014244  0.007628\n",
       "29      PMMR        0.90  0.013324  0.009472"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_doubly_robustKPV_AbortionData = pd.read_pickle(r\"../Results/DoublyRobustKPV_RBF_LengthScale_Ablation_Abortion_Experiment.pkl\")\n",
    "df_doubly_robustPMMR_AbortionData = pd.read_pickle(r\"../Results/DoublyRobustPMMR_RBF_LengthScale_Ablation_Abortion_Experiment.pkl\")\n",
    "df_RBF_length_scale_AbortionData = pd.concat([df_doubly_robustKPV_AbortionData, df_doubly_robustPMMR_AbortionData])\n",
    "print(df_RBF_length_scale_AbortionData.shape)\n",
    "\n",
    "df_results_aggregated = df_RBF_length_scale_AbortionData.groupby(['Algorithm', 'l_quantile']).agg({ \"Causal_MSE\" : [\"mean\", \"std\"]}).set_axis([\"MSE\", \"MSE_std\"], axis=1).reset_index()\n",
    "df_results_aggregated"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9a9d1f52-c0fd-4e4e-bc34-8875ac0c8a7a",
   "metadata": {},
   "source": [
    "# Matern kernel - Different p values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "5a893154-f7ff-4a5e-bf3d-a1165eb4d68c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(750, 6)\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Algorithm</th>\n",
       "      <th>matern_p</th>\n",
       "      <th>MSE</th>\n",
       "      <th>MSE_std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0</td>\n",
       "      <td>0.032365</td>\n",
       "      <td>0.016323</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>1</td>\n",
       "      <td>0.022505</td>\n",
       "      <td>0.013305</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>2</td>\n",
       "      <td>0.022969</td>\n",
       "      <td>0.013257</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>3</td>\n",
       "      <td>0.022516</td>\n",
       "      <td>0.013466</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>10</td>\n",
       "      <td>0.024488</td>\n",
       "      <td>0.015674</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0</td>\n",
       "      <td>0.029465</td>\n",
       "      <td>0.011259</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>1</td>\n",
       "      <td>0.019434</td>\n",
       "      <td>0.013111</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>2</td>\n",
       "      <td>0.019263</td>\n",
       "      <td>0.013512</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>3</td>\n",
       "      <td>0.01893</td>\n",
       "      <td>0.013316</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>10</td>\n",
       "      <td>0.022063</td>\n",
       "      <td>0.016517</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0</td>\n",
       "      <td>0.055623</td>\n",
       "      <td>0.021940</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>KAP</td>\n",
       "      <td>1</td>\n",
       "      <td>0.068378</td>\n",
       "      <td>0.054527</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>KAP</td>\n",
       "      <td>2</td>\n",
       "      <td>0.063125</td>\n",
       "      <td>0.063403</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>KAP</td>\n",
       "      <td>3</td>\n",
       "      <td>0.061338</td>\n",
       "      <td>0.062371</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>KAP</td>\n",
       "      <td>10</td>\n",
       "      <td>0.063511</td>\n",
       "      <td>0.067248</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0</td>\n",
       "      <td>0.071152</td>\n",
       "      <td>0.025301</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>KPV</td>\n",
       "      <td>1</td>\n",
       "      <td>0.042552</td>\n",
       "      <td>0.021716</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>KPV</td>\n",
       "      <td>2</td>\n",
       "      <td>0.040212</td>\n",
       "      <td>0.021733</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>KPV</td>\n",
       "      <td>3</td>\n",
       "      <td>0.03841</td>\n",
       "      <td>0.021933</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>KPV</td>\n",
       "      <td>10</td>\n",
       "      <td>0.03463</td>\n",
       "      <td>0.023474</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0</td>\n",
       "      <td>0.060702</td>\n",
       "      <td>0.018751</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>1</td>\n",
       "      <td>0.02338</td>\n",
       "      <td>0.009230</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>2</td>\n",
       "      <td>0.02142</td>\n",
       "      <td>0.008957</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>3</td>\n",
       "      <td>0.021901</td>\n",
       "      <td>0.009928</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>10</td>\n",
       "      <td>0.029576</td>\n",
       "      <td>0.013103</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Algorithm  matern_p       MSE   MSE_std\n",
       "0      DRKPV         0  0.032365  0.016323\n",
       "1      DRKPV         1  0.022505  0.013305\n",
       "2      DRKPV         2  0.022969  0.013257\n",
       "3      DRKPV         3  0.022516  0.013466\n",
       "4      DRKPV        10  0.024488  0.015674\n",
       "5     DRPMMR         0  0.029465  0.011259\n",
       "6     DRPMMR         1  0.019434  0.013111\n",
       "7     DRPMMR         2  0.019263  0.013512\n",
       "8     DRPMMR         3   0.01893  0.013316\n",
       "9     DRPMMR        10  0.022063  0.016517\n",
       "10       KAP         0  0.055623  0.021940\n",
       "11       KAP         1  0.068378  0.054527\n",
       "12       KAP         2  0.063125  0.063403\n",
       "13       KAP         3  0.061338  0.062371\n",
       "14       KAP        10  0.063511  0.067248\n",
       "15       KPV         0  0.071152  0.025301\n",
       "16       KPV         1  0.042552  0.021716\n",
       "17       KPV         2  0.040212  0.021733\n",
       "18       KPV         3   0.03841  0.021933\n",
       "19       KPV        10   0.03463  0.023474\n",
       "20      PMMR         0  0.060702  0.018751\n",
       "21      PMMR         1   0.02338  0.009230\n",
       "22      PMMR         2   0.02142  0.008957\n",
       "23      PMMR         3  0.021901  0.009928\n",
       "24      PMMR        10  0.029576  0.013103"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_doubly_robustKPV_SyntheticLowDim = pd.read_pickle(r\"../Results/DoublyRobustKPV_Matern_Ablation_SyntheticLowDim_Experiment.pkl\")\n",
    "df_doubly_robustPMMR_SyntheticLowDim = pd.read_pickle(r\"../Results/DoublyRobustPMMR_Matern_Ablation_SyntheticLowDim_Experiment.pkl\")\n",
    "df_Matern_SyntheticData = pd.concat([df_doubly_robustKPV_SyntheticLowDim, df_doubly_robustPMMR_SyntheticLowDim])\n",
    "print(df_Matern_SyntheticData.shape)\n",
    "\n",
    "df_results_aggregated = df_Matern_SyntheticData.groupby(['Algorithm', 'matern_p']).agg({ \"Causal_MSE\" : [\"mean\", \"std\"]}).set_axis([\"MSE\", \"MSE_std\"], axis=1).reset_index()\n",
    "df_results_aggregated"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d9e00945-5f9e-4e83-ab5e-8e065f5dea8c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(750, 6)\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Algorithm</th>\n",
       "      <th>matern_p</th>\n",
       "      <th>MSE</th>\n",
       "      <th>MSE_std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>0</td>\n",
       "      <td>0.019877</td>\n",
       "      <td>0.007196</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>1</td>\n",
       "      <td>0.022692</td>\n",
       "      <td>0.015652</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>2</td>\n",
       "      <td>0.020840</td>\n",
       "      <td>0.012324</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>3</td>\n",
       "      <td>0.023947</td>\n",
       "      <td>0.017990</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>DRKPV</td>\n",
       "      <td>10</td>\n",
       "      <td>0.023658</td>\n",
       "      <td>0.014879</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>0</td>\n",
       "      <td>0.016418</td>\n",
       "      <td>0.003778</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>1</td>\n",
       "      <td>0.019416</td>\n",
       "      <td>0.009847</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>2</td>\n",
       "      <td>0.018507</td>\n",
       "      <td>0.010077</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>3</td>\n",
       "      <td>0.018949</td>\n",
       "      <td>0.010180</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>DRPMMR</td>\n",
       "      <td>10</td>\n",
       "      <td>0.021217</td>\n",
       "      <td>0.011602</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>KAP</td>\n",
       "      <td>0</td>\n",
       "      <td>0.019593</td>\n",
       "      <td>0.006518</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>KAP</td>\n",
       "      <td>1</td>\n",
       "      <td>0.025342</td>\n",
       "      <td>0.017011</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>KAP</td>\n",
       "      <td>2</td>\n",
       "      <td>0.032350</td>\n",
       "      <td>0.024053</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>KAP</td>\n",
       "      <td>3</td>\n",
       "      <td>0.036167</td>\n",
       "      <td>0.026568</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>KAP</td>\n",
       "      <td>10</td>\n",
       "      <td>0.044859</td>\n",
       "      <td>0.032305</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>KPV</td>\n",
       "      <td>0</td>\n",
       "      <td>0.026626</td>\n",
       "      <td>0.011258</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>KPV</td>\n",
       "      <td>1</td>\n",
       "      <td>0.022505</td>\n",
       "      <td>0.014054</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>KPV</td>\n",
       "      <td>2</td>\n",
       "      <td>0.019629</td>\n",
       "      <td>0.011604</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>KPV</td>\n",
       "      <td>3</td>\n",
       "      <td>0.021425</td>\n",
       "      <td>0.015225</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>KPV</td>\n",
       "      <td>10</td>\n",
       "      <td>0.018700</td>\n",
       "      <td>0.013802</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>0</td>\n",
       "      <td>0.015090</td>\n",
       "      <td>0.004597</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>1</td>\n",
       "      <td>0.014899</td>\n",
       "      <td>0.008147</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>2</td>\n",
       "      <td>0.015588</td>\n",
       "      <td>0.008556</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>3</td>\n",
       "      <td>0.015983</td>\n",
       "      <td>0.008794</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>PMMR</td>\n",
       "      <td>10</td>\n",
       "      <td>0.016654</td>\n",
       "      <td>0.008925</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Algorithm  matern_p       MSE   MSE_std\n",
       "0      DRKPV         0  0.019877  0.007196\n",
       "1      DRKPV         1  0.022692  0.015652\n",
       "2      DRKPV         2  0.020840  0.012324\n",
       "3      DRKPV         3  0.023947  0.017990\n",
       "4      DRKPV        10  0.023658  0.014879\n",
       "5     DRPMMR         0  0.016418  0.003778\n",
       "6     DRPMMR         1  0.019416  0.009847\n",
       "7     DRPMMR         2  0.018507  0.010077\n",
       "8     DRPMMR         3  0.018949  0.010180\n",
       "9     DRPMMR        10  0.021217  0.011602\n",
       "10       KAP         0  0.019593  0.006518\n",
       "11       KAP         1  0.025342  0.017011\n",
       "12       KAP         2  0.032350  0.024053\n",
       "13       KAP         3  0.036167  0.026568\n",
       "14       KAP        10  0.044859  0.032305\n",
       "15       KPV         0  0.026626  0.011258\n",
       "16       KPV         1  0.022505  0.014054\n",
       "17       KPV         2  0.019629  0.011604\n",
       "18       KPV         3  0.021425  0.015225\n",
       "19       KPV        10  0.018700  0.013802\n",
       "20      PMMR         0  0.015090  0.004597\n",
       "21      PMMR         1  0.014899  0.008147\n",
       "22      PMMR         2  0.015588  0.008556\n",
       "23      PMMR         3  0.015983  0.008794\n",
       "24      PMMR        10  0.016654  0.008925"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_doubly_robustKPV_AbortionData = pd.read_pickle(r\"../Results/DoublyRobustKPV_Matern_Ablation_Abortion_Experiment.pkl\")\n",
    "df_doubly_robustPMMR_AbortionData = pd.read_pickle(r\"../Results/DoublyRobustPMMR_Matern_Ablation_Abortion_Experiment.pkl\")\n",
    "df_Matern_AbortionData = pd.concat([df_doubly_robustKPV_AbortionData, df_doubly_robustPMMR_AbortionData])\n",
    "print(df_Matern_AbortionData.shape)\n",
    "\n",
    "df_results_aggregated = df_Matern_AbortionData.groupby(['Algorithm', 'matern_p']).agg({ \"Causal_MSE\" : [\"mean\", \"std\"]}).set_axis([\"MSE\", \"MSE_std\"], axis=1).reset_index()\n",
    "df_results_aggregated"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1bc0be4f-1cca-4e40-b1e4-53d6b3ea8406",
   "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.8.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
