{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/root202/Software/anaconda3/envs/posthoc-eval/lib/python3.8/site-packages/outdated/utils.py:14: OutdatedPackageWarning: The package outdated is out of date. Your version is 0.2.1, the latest is 0.2.2.\n",
      "Set the environment variable OUTDATED_IGNORE=1 to disable these warnings.\n",
      "  return warn(\n",
      "/Users/root202/Software/anaconda3/envs/posthoc-eval/lib/python3.8/site-packages/outdated/utils.py:14: OutdatedPackageWarning: The package pingouin is out of date. Your version is 0.5.1, the latest is 0.5.3.\n",
      "Set the environment variable OUTDATED_IGNORE=1 to disable these warnings.\n",
      "  return warn(\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import pingouin as pg\n",
    "import matplotlib.pyplot as plt\n",
    "dataset = pd.read_csv('../data/doctor_result_data.csv')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Testing the hypothesis: the degree of plausibility is associated with whether doctor will take or reject AI decisions\n",
    "\n",
    "- doctor_result_data.csv data is the study result dataset\n",
    "- Outcome variable Y: doctor final prediction after checking explanation drXAI is agreeable with AI prediction\n",
    "    - `dataset['Agreement_xai'] = dataset.apply(lambda row: \"Agree\" if row['AIpred'] == row['drXAI'] else \"Disagree\", axis = 1)`\n",
    "- Treatment variable X: plausibility, xai_qual\n",
    "- controlled variable Z: MRI_easiness = dr_acc. The raw data column 'MRI Difficulty' is just renamed from dr_acc, so should be called easiness.\n",
    "- Causal diagram: MRI_easiness -> dr_agreement, MRI_easiness -> plausibility -> dr_agreement\n",
    "\n",
    "```\n",
    "dag {\n",
    "\"Dr agreement\" [outcome,pos=\"-0.232,-0.809\"]\n",
    "\"MRI easiness\" [pos=\"-0.965,-0.798\"]\n",
    "Plausibility [exposure,pos=\"-0.618,-0.351\"]\n",
    "\"MRI easiness\" -> \"Dr agreement\"\n",
    "\"MRI easiness\" -> Plausibility\n",
    "Plausibility -> \"Dr agreement\"\n",
    "}\n",
    "```\n",
    "Visualize the causal diagram at: https://www.dagitty.net/dags.html"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 1. data processing and stat. summary"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "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>Agreement_xai</th>\n",
       "      <th>Plausibility</th>\n",
       "      <th>MRI_easiness</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Agree</td>\n",
       "      <td>9.0</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Agree</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Agree</td>\n",
       "      <td>8.0</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Agree</td>\n",
       "      <td>7.0</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Agree</td>\n",
       "      <td>9.0</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>754</th>\n",
       "      <td>Agree</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.870968</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>755</th>\n",
       "      <td>Agree</td>\n",
       "      <td>8.0</td>\n",
       "      <td>0.870968</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>756</th>\n",
       "      <td>Agree</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.870968</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>757</th>\n",
       "      <td>Agree</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.870968</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>758</th>\n",
       "      <td>Agree</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.870968</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>744 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    Agreement_xai  Plausibility  MRI_easiness\n",
       "0           Agree           9.0      1.000000\n",
       "1           Agree          10.0      1.000000\n",
       "2           Agree           8.0      1.000000\n",
       "3           Agree           7.0      1.000000\n",
       "4           Agree           9.0      1.000000\n",
       "..            ...           ...           ...\n",
       "754         Agree           0.0      0.870968\n",
       "755         Agree           8.0      0.870968\n",
       "756         Agree           3.0      0.870968\n",
       "757         Agree           2.0      0.870968\n",
       "758         Agree          10.0      0.870968\n",
       "\n",
       "[744 rows x 3 columns]"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Get X, Y, Z data column from raw data\n",
    "data = dataset[['Agreement_xai', 'xai_qual', 'MRI Difficulty']]\n",
    "data = data.rename(columns={'xai_qual': 'Plausibility', 'MRI Difficulty': 'MRI_easiness'})\n",
    "data = data.dropna()\n",
    "data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "count    649.000000\n",
       "mean       6.453005\n",
       "std        2.816622\n",
       "min        0.000000\n",
       "25%        5.000000\n",
       "50%        7.000000\n",
       "75%        9.000000\n",
       "max       10.000000\n",
       "Name: Plausibility, dtype: float64"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# stat. summary of plausibility for group when doctor agree with AI\n",
    "data[data['Agreement_xai']==\"Agree\"]['Plausibility'].describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "count    95.000000\n",
       "mean      3.821053\n",
       "std       2.559833\n",
       "min       0.000000\n",
       "25%       2.000000\n",
       "50%       4.000000\n",
       "75%       5.500000\n",
       "max      10.000000\n",
       "Name: Plausibility, dtype: float64"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/root202/Software/anaconda3/envs/posthoc-eval/lib/python3.8/site-packages/outdated/utils.py:14: OutdatedPackageWarning: The package outdated is out of date. Your version is 0.2.1, the latest is 0.2.2.\n",
      "Set the environment variable OUTDATED_IGNORE=1 to disable these warnings.\n",
      "  return warn(\n",
      "/Users/root202/Software/anaconda3/envs/posthoc-eval/lib/python3.8/site-packages/outdated/utils.py:14: OutdatedPackageWarning: The package pingouin is out of date. Your version is 0.5.1, the latest is 0.5.3.\n",
      "Set the environment variable OUTDATED_IGNORE=1 to disable these warnings.\n",
      "  return warn(\n"
     ]
    }
   ],
   "source": [
    "# stat. summary of plausibility for group when doctor disagreeagree with AI\n",
    "data[data['Agreement_xai']==\"Disagree\"]['Plausibility'].describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA2kAAAH4CAYAAADQLaVpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAAsTAAALEwEAmpwYAABtf0lEQVR4nO3deVxV1d7H8e9hFgERcxZFRTE1TDSHyjG1a+VEhQOZUFFpUrdJs+xampo2q5nPFZtMUzMzNZscciwqpXBEQRDTHEFEpgOc8/zhi3MjQI7IsJPP+/Xq9VzXWmet3z6PFl/X3mubrFarVQAAAAAAQ3Co6gIAAAAAAP9DSAMAAAAAAyGkAQAAAICBENIAAAAAwEAIaQAAAABgIIQ0AAAAADAQp6ou4FoUEBBQ1SUAAAAAMLi4uLhi2wlpFaSkLxwAAAAALrexw+2OAAAAAGAghDQAAAAAMBBCGgAAAAAYCCENAAAAAAyEkAYAAAAABkJIAwAAAAADIaQBAAAAgIEQ0gAAAADAQAhpAAAAAGAgTlVdACSr1aoLFy4oIyNDOTk5VV0OqjGTyaSaNWuqdu3acnLiXw8AAABVgZ/CqpjFYtGJEyfk5OQkHx8fubq6ymQyVXVZqKYsFovS09N17Ngx+fr6EtQAAACqAD+BVbHz58/L1dVVdevWrepSADk4OKhWrVqSpNTUVH5fAgAAVAGeSatiFy5ckI+PT1WXARTi6empjIyMqi4DAACgWiKkVTGr1SpHR8eqLgMoxMHBQVartarLAAAAqJYIaQAAAABgIIQ0AAAAADAQQhoAAAAAGAghDQAAAAAMhCP4/wHSs3OVm//POcTB2dEkTzfnCpv/0KFDGjRokCTp6aef1sMPP1xhawEAUN1U1s8dFf3zAvBPZtiQtnPnTi1YsEBxcXHKzc1Vu3btFBERoZ49e5ZpviNHjmjo0KF69NFHNW7cuGLHWK1WrVq1SitWrNChQ4dksVjUpk0bjRkzRnfcccfVXM5Vyc23atySXVW2/pWaH9qpQudftWqVJMnV1VWfffaZIiIieAE4AADlpLJ+7qjonxeAfzJD3u64atUqhYeHKyYmRoGBgerYsaNiYmIUERGh5cuXX/F8KSkpGj9+vHJyckocY7VaNWHCBD3//PM6dOiQunbtqsDAQO3Zs0dPPvmkFi9efDWXhHKSl5enNWvWqEGDBhowYICSk5O1c+fOqi4LAAAAKDeGC2mnTp3SlClT5Onpqc8//1wLFy7UokWLtHTpUnl4eGj69Ok6deqU3fMdOnRII0eOVEJCwmXHrVq1SmvWrFHr1q317bffasGCBVq8eLE+/vhjubi46NVXX9W5c+eu9vJwlX744QedO3dON998swYOHChJZQruAAAAgFEZLqQtWbJEZrNZYWFhat26ta09MDBQERERysnJseuH8qysLM2bN08hISFKSkpSkyZNLjt+wYIFcnJy0ttvv6169erZ2jt37qzhw4erfv362rt3b9kvDOXiiy++kCTdfvvt6tmzp7y9vbVx40adOXOm2PHHjx/XCy+8oN69eyswMFDDhg3TunXr9OWXXyogIMB266QkjR49WgEBATp8+LBCQ0PVvn179ezZU9u2bbON+f333/XYY4+pW7duuuGGG3T77bfrrbfe0sWLF4tdPyEhQc8++6xuvfVWtW/fXn379tUrr7xC4AcAAECJDBfSCn4g7tevX5G+gratW7eWOs/XX3+tuXPnysPDQ/PmzdPQoUNLHHvgwAElJyerR48eatmyZZH+yZMna9OmTerVq5edV4GKkJKSoi1btqhOnTq69dZb5ezsrDvvvFN5eXn6/PPPi4xPSEhQSEiIVq5cKXd3d/Xu3VsXL17U008/rSVLlpS4zvjx43Xs2DH17t1bDg4Oatu2raRLu60jR47Upk2b5Ovrqz59+ignJ0cLFizQyJEjdf78+ULzbN++XXfffbfWrFmjOnXqqG/fvnJxcdHixYt1991369ixY+X6/QAAAODaYKiDQ6xWq+Lj4+Xg4KAWLVoU6ffz85ODg4Pi4+NltVove1iEt7e3IiMjFR4erpo1a+rgwYMljt23b5+kS7t1FotFmzdv1k8//aScnBxdf/31GjJkiNzd3a/+AnFV1qxZo9zcXA0ePFhOTpd+6959991asmSJVqxYoYcfflgODv/7e4f//Oc/Onv2rMaOHasnnnhCJpNJ+fn5mjlz5mWfMczLy9NXX30lT09PWSwWOTg4KCEhQf/5z3/k7u6u//u//1OnTpceds7NzdW0adO0fPlyTZs2TW+88YakS4HyqaeeUm5urubNm6f+/ftLuvR7fMGCBXr77bf17LPPatmyZRX1dQEAAOAfylA7aWlpaTKbzfL29paLi0uRficnJ9WuXVtZWVnKyMi47Fx9+/bV+PHjVbNmzVLXTU5OliS5u7trzJgxGjdunD7++GMtX75cL730ku66665Sn2lDxSu4NTE4ONjW1q5dO7Vp00bHjx/X9u3bbe379+/Xr7/+qrZt29oCmiQ5Ojpq0qRJat68eYnrDBs2TJ6enpJkC30fffSRcnNz9fjjj9sCmiQ5Oztr8uTJql+/vtavX297XnLlypVKS0vTfffdZwtokmQymTR27Fi1b99eMTExiomJudqvBQAAANcYQ4W0rKwsSVKNGjVKHOPm5iZJpYa0K5Geni5Jevfdd5WQkKC3335bv/zyi77++msNHDhQx48f1yOPPKLs7OxyWxNXZt++fYqLi1O7du0KPasoXdpNkwofIFJw4uNtt91WZMfV0dGxUHD6uzZt2hRpi46OliR17dq1SJ+Li4u6dOkii8WiX3/9tdTxknTrrbdKkn755ZcS6wAAAED1ZKjbHf96q1pprNbye8mi2WyWdCmsLV26VEFBQZIkLy8vvfXWWzp+/LhiY2O1Zs0ahYSElNu6sF/BLtrZs2c1evToQn0Fgf2HH37QqVOnVL9+ff3555+SpIYNGxY7X+PGjUtcq1atWkXaTp48KUkaPHjwZessWLfg/44dO9au8QAAAEABQ4W0gue+Lvc+s4LdrPJ8Rqxg565Nmza2gFbAZDIpJCREsbGxio6OJqRVAbPZrHXr1km69IqGkl7BkJeXp5UrV+qxxx5Tbm6uJMlisRQ79nIhv7hnHfPz8yVJd91112WfhWzWrFmh8bfddttlf68Wt2sHAACA6s1QIc3Dw0Pu7u5KTU1VXl6e7XCIAnl5eUpNTZWrq6u8vLzKbd3atWtLKnl3pVGjRpKk1NTUclsT9tu4caPOnz+v7t2768MPPyx2zPfff6/x48dr5cqVGjt2rBo0aCCp5J2qgp0xe9WrV0/Hjx/Xs88+a5u7tPFJSUl64IEH1Llz5ytaCwAAANWboZ5JM5lM8vf3V35+vpKSkor0JyYmymKxFHkm6WoFBARIkk6fPl1sf8E7uHx8fMp1Xdin4N1od955Z4ljevXqJW9vb504cUJbt261PQv2ww8/FBlrtVq1efPmK6qhIGht2bKl2P4HH3xQw4cPV2xsbKHxJb0uYtKkSbr77ru1cePGK6oDAAAA1z5DhTRJ6tGjhyRpw4YNRfoK2sr7fWVdu3aVi4uL9u7dW+y7qwre3caOSOU7ffq0tm/fLmdnZw0YMKDEcS4uLho4cKAkadmyZerUqZPatWunffv2af78+bZxVqtVc+fOVVxcnKTib20szujRo+Xg4KA333zTdjhIwXzz5s3T9u3b9ccff9huXxw+fLhq1Kih999/X99//32huVatWqUvvvhChw4dUocOHez7IgAAAFBtGC6kBQcHy9XVVQsXLtTevXtt7Xv27FFUVJTc3Nw0atQoW3tycrISEhJsJzSWhaenp+69915ZLBY9++yzhV5KvH79en311Vfy8fHRHXfcUeY1UDarV69Wfn6+brnllmIP9PirIUOGSLq0e3Xy5EnNnDlTXl5eeuedd3TXXXfpiSee0J133ql3331Xvr6+klTkltqS3HDDDZo4caLtWP3g4GBFRkbqX//6l+bOnSs3Nze98847tldHNGjQQDNnzpR06eXYgwYNUmRkpAYPHqxJkybJZDJp9uzZuu6668r61QAAAOAaZahn0iSpSZMmmjhxoqZOnaoRI0bYbluLjo5WXl6eZs2apTp16tjGh4WF6fjx45o5c2ah92ddqaeffloHDhzQ7t271a9fP9100006c+aM9uzZI1dXV7366qvl+hzclXB2NGl+aKfSBxqEs6N9u1P2KLjV0Z6A3LFjR/n5+SkpKUmfffaZIiMjtXLlSr3zzjvauXOnjh49qlatWmnu3LnatWuXPvzwQ9v70OwRFhamtm3b6oMPPlBMTIwOHz6sBg0aaNiwYXrkkUeKvHtt4MCB8vPzU1RUlKKjo5WYmKi6devq9ttv18MPP6z27dtf2ZcBAACAasFwIU2SQkND1ahRI0VFRWn37t1ycXFRUFCQxo4dq+7du1fImjVr1tRHH32kjz/+WF9++aV27NihmjVrqn///ho7dqzatWtXIevaw9PNucrWrmpff/31FY3/9ttvJUkXLlxQXFycGjdurDfffLPIuILwV7CjJkmLFy8udf4uXbqoS5cudtdz/fXX64033rB7PAAAAGCylucLxyDp0kEkBc88lSYxMbHIDgyuXkJCgu644w75+flp5cqVhXbMtm7dqkcffVR+fn5av359FVZpbPzeBIDqKSXDrHFLdlX4OvNDO8mnpkuFrwMY1eUygyF30oCr1bJlS/Xp00ebN29W7969FRQUpBo1auiPP/7Qvn375OHhYXtm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duyYRo4cqTNnzqh169Zq3ry5du/erTNnzqhnz55677335ORkqHNWAAAAAFyDDBnSpEu3HkZFRWn//v1ycXFRQECAxo4dq+7duxcaV1JIky49YzZnzhxFR0fLbDarWbNmGjFihO69917bsft/9eeff2rOnDnaunWr0tPT5evrqyFDhmjMmDFydXWt0OsFAAAAAMnAIQ3/HDt37tSCBQsUFxen3NxctWvXThEREerZs2dVl4ZKlJ+fr08//VRffPGFjhw5ovz8fPn6+uqOO+7QQw89xF90VGPnz5/XoEGDdPr0aV5RUk0dP35c7777rrZv366UlBTVrl1bvXv31uOPP247aRnVx5dffqklS5bo0KFDslgsat68uYKDg3XfffcV+5fouLasWrVKkyZN0pIlS9S5c+ci/YmJiZo7d6527dql8+fPq2nTpgoJCVFoaOgVvVP5n46QhqtS8AfNxcVF3bp1k8ViUXR0tHJzczV16lQNHz68qktEJcjPz9e4ceP0ww8/yN3dXR06dJCTk5N+//13XbhwQR06dNBHH31keychqpcnn3xS69evl8R7JKujPXv2KDw8XOnp6WrdurWaNm2qvXv36uTJk2ratKlWrlypWrVqVXWZqCSzZ8/WokWL5OLioptuukmOjo769ddflZmZqX79+mnevHkymUxVXSYqSExMjB544AFlZmYWG9IOHjyo0NBQXbx4UUFBQapTp46io6N14cIFDRo0SK+//noVVV4FrEAZnTx50tq+fXtrp06drHFxcbb233//3RoUFGS94YYbrCdPnqzCClFZPv30U2vr1q2tgwYNKvT/83PnzlmHDx9ubd26tfX111+vwgpRVdauXWtt3bq17R9ULzk5OdYBAwZYW7dubf34449t7dnZ2dbIyEhr69atrdOmTavCClGZDhw4YA0ICLB269bNeuTIEVv7yZMnrX369LG2bt3a+s0331RhhahI33zzjbVjx462/x788ssvhfotFot10KBB1tatW1tXr15taz937pytvTr9/qg+e4Yod0uWLJHZbFZYWFihd8gFBgYqIiJCOTk5Wr58eRVWiMryxRdfSJKef/551a9f39bu4+Ojl156SZL01VdfVUVpqEKnTp3S1KlT1bFjR25hqqbWr1+vpKQkDRo0SKNHj7a1u7q6atKkSbruuuuUmJhYhRWiMv3444+yWq0aPHiwmjdvbmuvX7++7eTuX375parKQwU5efKkJkyYoMcff1wWi0XXXXddseN27NihuLg4denSpdAhgX/9WWLx4sWVUbIhENJQZtu2bZMk9evXr0hfQdvWrVsrtSZUjdq1a6tFixYKDAws0ufn5ydJOn36dCVXhar2wgsvyGw2a9asWVVdCqrId999J0nFvsamYcOG2rFjhxYtWlTZZaGKFNzGeOrUqSJ9qampkiRvb+/KLAmV4O2339aXX36p9u3ba/ny5WrRokWx4y73c2XBrY+7du3SxYsXK7Reo+BMeZSJ1WpVfHy8HBwciv3D5ufnJwcHB8XHx8tqtXJ/+TVuwYIFJfbt2bNHktSgQYPKKgcGsHTpUm3btk0vvviimjVrVtXloIrs379fzs7OatOmjf7880+tXbtWycnJ8vb21oABA4r9ix1cu3r06KFXX31V33zzjf773//qnnvukZOTk7777jt9/PHHqlWrlu6+++6qLhPlrEWLFpo1a5YGDx582YM/4uPjJanQ3Vl/1bx5c507d04JCQnq0KFDhdRqJIQ0lElaWprMZrN8fHzk4uJSpN/JyUm1a9fWuXPnlJGRIQ8PjyqoElXNarXaXhA/YMCAKq4GleXo0aN67bXX1L17d4WGhlZ1OagiZrNZf/75pxo0aKBvvvlGL7zwgrKysmz9Cxcu1IMPPqgJEyZUYZWoTC1bttS0adM0ffp0vfHGG3rjjTdsfR07dtTMmTPVsGHDKqwQFeHhhx+2a1zBHTclnfha0H727NnyKczguN0RZVLwH9rLndbn5uYmScrIyKiUmmA8b775pn755Rddd911euihh6q6HFSC/Px8TZw4UQ4ODpoxYwa76NVYwS1JaWlpmjhxovr166dvvvlGv/zyi9566y15e3tr0aJFPLtczQQFBal79+5yd3dXt27ddPPNN6tmzZras2ePli5dKiuHjldbBT9bFvz8+HcF7ZmZmZVWU1ViJw1lciXvqeBfuNXTO++8o//+979ycXHR22+/LR8fn6ouCZUgKipKMTExeuWVV9SoUaOqLgdVyGw2S7r0g9ett95a6OjsO+64Q+7u7nrkkUf07rvvKiQkhEBfDfz222964IEH1LhxY61bt06NGzeWdOkZtfHjx+vjjz+Wh4eHnnjiiSquFFWh4ICp0v5dYLFYKqOcKsdOGsrE3d1d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la+vr86fP68NGzYoLCxM69atu+p6zp07p3vuuUcffvihzpw5I39/fzVq1Ejx8fF67733FBISorS0NLvnW7hwoSZMmKBjx46pVatWysnJ0dq1azVs2DDt2LHjqust4Ofnp/bt29t+3bFjRwUFBcnV1VVDhgyRJH311VfFfnb37t06duyYmjRpok6dOpVbTQBQ3RHSAAD/OGlpaVqzZo0kqVevXiWOM5vNmjRpkrKzsxUWFqadO3dq9erV+vrrr/XDDz/o5ptvltVq1fz586+6pqioKJ04cUL/+te/tH37dq1evVrr1q3TN998o2bNmuno0aMl7swVZ9euXbrnnnu0fft2ff7559q2bZuGDBminJwcPfvss0pPT7/qmiXp0Ucf1TvvvGP79aJFi/Tpp5+qbt26GjRokJycnLRv3z4dOXKkyGfXrl0rSRo8eLBMJlO51AMAIKQBAP4hrFarLly4oK1bt+qhhx5SSkqKPD099eCDD5b4mb179yozM1P169fXhAkTCh3pf9111+mxxx6TJCUmJspisVxVfYcOHZIkDRo0SO7u7rZ2X19fPfPMM+rbt69q165t93yBgYGaNm2a3NzcJF06aGTGjBlq0aKFzp07p9WrV19Vvfbw8fFRjx49JBXdTcvNzdXXX38t6VJIAwCUH47gBwAY0l+fkypO7dq1NWfOnMve7hgUFKRdu3YpOztbjo6ORfpr1KghSbJYLMrJybH9uiyaNm0qSXr99dfl7Oysbt26ydXVVZI0YMAADRgw4IrmGz58uBwcCv9dqpOTkwYPHqy3335b27Zt0+jRo8tcr72GDBmizZs3a926dYqMjLS1b9++XampqerQoYOaN29e4XUAQHVCSAMAGNLfX2bt4OAgd3d31a9fXx07dtTAgQML7Vhdjpubm/bt26f9+/crOTlZycnJOnTokBITE21jrnYn7YEHHtD69euVmJiohx9+WDVq1FDnzp3Vo0cP3XbbbcW+8+1yrr/++mLbW7VqJUmFaq9It912m7y8vJSUlKS9e/fanl8ruN204Lk1AED5IaQBAAyppJdZX6lffvlFM2fO1L59+2xtJpNJzZo106BBg2xh42r5+vrqyy+/1Pz58/Xdd98pNTVV27Zt07Zt2zRjxgz16tVL06ZNs+tdZpJKDKAF7VlZWeVSd2lcXFw0cOBALV++XOvWrVP79u118eJFbdq0Sc7Ozho4cGCl1AEA1QnPpAEArlmHDh3SAw88oH379qlz586aNm2aVqxYoV9//VXffvutxo0bd9nPW63WYtuzs7OLbW/QoIGmTp2qnTt3asWKFXryySfVqVMnmUwmbdmyRY8++miJc/5dSSGs4JUDlfky6oLdsq+//lpWq1UbN25Udna2evToIR8fn0qrAwCqC3bSAADXrMWLF8tsNqt79+5atGhRkefSTp48WeznCsaZzeYifVarVWfPni3S/ueffyoxMVHdu3eXg4ODOnTooA4dOujRRx/Vjz/+qLCwMO3fv1/x8fG2WxYvJykpSW3bti3SfuDAAUmSv79/qXOUl06dOqlp06ZKTk7W3r17tWnTJknc6ggAFYWdNADANev48eOSpICAgGIPDlm5cqXtf+fn59v+d8EuVXHPfe3atavI+87MZrPuuusuhYeH6/fffy/ymc6dO8vZ2bnIOpdT3OmN2dnZtvY+ffrYNY89/npASUk7fQWB7Pvvv9eOHTvk5eWlvn37llsNAID/IaQBAK5Zfn5+kqT169fr6NGjtva0tDTNmDGj0Eusc3JybP87KChIkrRu3Trt2rXL1r5v3z5NnDixyDouLi620xsnT55cKNyZzWa9+eabys3NVePGje3eAduyZYveeecd5eXlSZLS09P11FNP6fjx42revLnuvPNOu+axx1+ffztx4kSxY4YMGSKTyaTFixcrPT1d//rXvwod7AIAKD/c7ggAuGaFh4dr7dq1On36tO644w41b95cJpNJSUlJMpvNatOmjU6ePKnz58/r9OnTqlu3riTp7rvv1ieffKJjx44pNDRU/v7+ys/P15EjR+Tn56e77rqrUMCTpIkTJ2rXrl06fPiw7rzzTvn6+qpmzZo6duyYLly4IFdXV82YMUNOTvb9p7d///6aP3++li1bpkaNGunIkSPKzMxU3bp1NXfu3HINSN7e3mrQoIFOnjyp++67T76+vnr11VcL3Zbp6+tre6WBxK2OAFCR2EkDAFyzCk5cHDZsmBo2bKikpCT9+eefatOmjSZNmqTPPvtMt9xyiyRp8+bNts95enpqxYoVGj16tO1zOTk5CgsL08qVK4s9LMPb21vLli3TAw88oObNm+vkyZM6fPiwvLy8FBISorVr16pbt2521/7MM8/oP//5j2rXrq24uDh5enpq5MiR+uKLL+x6pu1KzZkzRzfccIOys7N17NgxJScnFxlTEMwaN26sTp06lXsNAIBLTFZ7j5kCAADV2ty5czVv3jyNGzdOTzzxRFWXAwDXLHbSAABAqSwWi1avXi2TyaTg4OCqLgcArmk8kwYAAIplNpt15MgR1ahRQwsWLNAff/yhPn36yNfXt6pLA4BrGrc7AgCAYmVnZ6tDhw62X7u5uemLL75QixYtqrAqALj2cbsjAAAolpubm9q3by8XFxe1a9dOUVFRBDQAqATspAEAAACAgbCTBgAAAAAGQkgDAAAAAAMhpAEAAACAgRDSAAAAAMBACGkAAAAAYCCENAAAAAAwkP8H2VjrzCw19ywAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 1008x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# visualize the plausibility distribution for the two groups\n",
    "sns.set_style(\"white\")\n",
    "with sns.plotting_context(\"paper\", font_scale=2.5):\n",
    "\n",
    "    fig, ax = plt.subplots(figsize=(14,8))\n",
    "    plt.grid(color='white',  zorder=2)\n",
    "\n",
    "\n",
    "    g=sns.histplot(ax = ax, data=data, x=\"Plausibility\", hue=\"Agreement_xai\",discrete=True, stat=\"probability\", common_norm=False, multiple=\"dodge\", shrink=.8)#, stat=\"density\")\n",
    "    plt.xlabel(\"Plausibility\")\n",
    "    plt.ylabel(\"Probability\")\n",
    "    g.legend_.set_title(None)\n",
    "    plt.savefig('../draft/plausibility_hist.pdf', bbox_inches = None)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 2. Stat. test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "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>W</th>\n",
       "      <th>pval</th>\n",
       "      <th>equal_var</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>levene</th>\n",
       "      <td>0.554367</td>\n",
       "      <td>0.456775</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "               W      pval  equal_var\n",
       "levene  0.554367  0.456775       True"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# one side t-test: whether agree has higher xai_qual vs. disagree\n",
    "agree = data[data['Agreement_xai']==\"Agree\"]['Plausibility'].to_list()\n",
    "disagree = data[data['Agreement_xai']==\"Disagree\"]['Plausibility'].to_list()\n",
    "# test for assumption of t-test: Homogeneity of Variances\n",
    "pg.homoscedasticity([agree,disagree])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(          W          pval  normal\n",
       " 0  0.914885  1.269209e-18   False,\n",
       "           W      pval  normal\n",
       " 0  0.956661  0.003209   False)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# test for assumption of t-test: normal distribution\n",
    "pg.normality(agree), pg.normality(disagree)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "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>T</th>\n",
       "      <th>dof</th>\n",
       "      <th>alternative</th>\n",
       "      <th>p-val</th>\n",
       "      <th>CI95%</th>\n",
       "      <th>cohen-d</th>\n",
       "      <th>BF10</th>\n",
       "      <th>power</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>T-test</th>\n",
       "      <td>9.236328</td>\n",
       "      <td>129.678812</td>\n",
       "      <td>greater</td>\n",
       "      <td>3.193105e-16</td>\n",
       "      <td>[2.16, inf]</td>\n",
       "      <td>0.94491</td>\n",
       "      <td>2.974e+16</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "               T         dof alternative         p-val        CI95%  cohen-d  \\\n",
       "T-test  9.236328  129.678812     greater  3.193105e-16  [2.16, inf]  0.94491   \n",
       "\n",
       "             BF10  power  \n",
       "T-test  2.974e+16    1.0  "
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# test of assumption for t-test failed on normality test, use nonparametric test instead\n",
    "pg.ttest(x = agree, y = disagree, alternative = 'greater')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "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>U-val</th>\n",
       "      <th>alternative</th>\n",
       "      <th>p-val</th>\n",
       "      <th>RBC</th>\n",
       "      <th>CLES</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>MWU</th>\n",
       "      <td>46533.0</td>\n",
       "      <td>greater</td>\n",
       "      <td>3.294012e-16</td>\n",
       "      <td>-0.509464</td>\n",
       "      <td>0.754732</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       U-val alternative         p-val       RBC      CLES\n",
       "MWU  46533.0     greater  3.294012e-16 -0.509464  0.754732"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Mann–Whitney U test\n",
    "pg.mwu(x = agree, y = disagree, alternative = 'greater')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 3. Causal analysis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-9-23becd8fc78e>:3: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  data['Plausibility_binary'][data['Plausibility'] > 5] = 1\n",
      "<ipython-input-9-23becd8fc78e>:4: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  data['Plausibility_binary'][data['Plausibility'] <= 5] = 0\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>Agreement_xai</th>\n",
       "      <th>Plausibility</th>\n",
       "      <th>MRI_easiness</th>\n",
       "      <th>Plausibility_binary</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>9.0</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1</td>\n",
       "      <td>8.0</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1</td>\n",
       "      <td>7.0</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "      <td>9.0</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>754</th>\n",
       "      <td>1</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.870968</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>755</th>\n",
       "      <td>1</td>\n",
       "      <td>8.0</td>\n",
       "      <td>0.870968</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>756</th>\n",
       "      <td>1</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.870968</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>757</th>\n",
       "      <td>1</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.870968</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>758</th>\n",
       "      <td>1</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.870968</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>744 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Agreement_xai  Plausibility  MRI_easiness Plausibility_binary\n",
       "0                1           9.0      1.000000                   1\n",
       "1                1          10.0      1.000000                   1\n",
       "2                1           8.0      1.000000                   1\n",
       "3                1           7.0      1.000000                   1\n",
       "4                1           9.0      1.000000                   1\n",
       "..             ...           ...           ...                 ...\n",
       "754              1           0.0      0.870968                   0\n",
       "755              1           8.0      0.870968                   1\n",
       "756              1           3.0      0.870968                   0\n",
       "757              1           2.0      0.870968                   0\n",
       "758              1          10.0      0.870968                   1\n",
       "\n",
       "[744 rows x 4 columns]"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data['Agreement_xai'] = data['Agreement_xai'].replace({'Agree': 1, 'Disagree': 0})\n",
    "data['Plausibility_binary'] = data['Plausibility'] >5\n",
    "data['Plausibility_binary'][data['Plausibility'] > 5] = 1\n",
    "data['Plausibility_binary'][data['Plausibility'] <= 5] = 0\n",
    "data"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Logistic regression adjustment as an outcome model for $P(Y=1|X,Z)$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([[2.19925395, 1.65659278]]), 0.8696236559139785)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.linear_model import LogisticRegression as LR\n",
    "adj_set = {'MRI_easiness'}\n",
    "x_var = 'Plausibility_binary'\n",
    "y_var = 'Agreement_xai'\n",
    "X = data[list(adj_set) + [x_var]]\n",
    "y = data[y_var]\n",
    "clf = LR(random_state=0).fit(X, y)\n",
    "clf.coef_, clf.score(X,y)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "$ATE = P(Y^1=1) - P(Y^0=1) =0.94-0.77=0.17$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.9410095547716161, 0.771288752720601, 0.16972080205101503)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_0 = X.copy()\n",
    "X_0[x_var] = 0\n",
    "X_1 = X.copy()\n",
    "X_1[x_var] = 1\n",
    "\n",
    "P_0 = clf.predict_proba(X_0)\n",
    "P_1 = clf.predict_proba(X_1)\n",
    "\n",
    "P_1[:,1].mean(),P_0[:,1].mean(), P_1[:,1].mean()-P_0[:,1].mean()"
   ]
  }
 ],
 "metadata": {
  "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
