{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.linear_model import LogisticRegression \n",
    "from scipy.stats import norm\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_dataset(N):\n",
    "    # generate noises\n",
    "    n_T = np.random.binomial(1, 0.5, N)\n",
    "    n_W = np.random.normal(0, 1, N)\n",
    "    n_X = np.random.normal(0, 1, N)\n",
    "    n_Y = np.random.normal(0, 1, N)\n",
    "\n",
    "    # structural equation\n",
    "    T = n_T\n",
    "    W = n_W\n",
    "    X = T + W + n_X\n",
    "    Y = ((X + n_Y)>0).astype(int)\n",
    "    return T, W, X, Y\n",
    "\n",
    "def predict(X, Y):\n",
    "    model = LogisticRegression()\n",
    "    X_ = np.column_stack([np.ones(X.shape[0]), X])\n",
    "    model.fit(X_, Y)\n",
    "    f = model.predict_proba(X_)[:,1]\n",
    "    f_dis = model.predict(X_)\n",
    "    return f, f_dis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ATE (Y):  0.21950371589709572\n",
      "ATE (f):  0.21904246043359044\n",
      "ATE (f_dis):  0.26133721421096257\n"
     ]
    }
   ],
   "source": [
    "# Instance 1\n",
    "N = 1000000\n",
    "T, W, X, Y = generate_dataset(N)\n",
    "\n",
    "ATE = np.mean(Y[T==1]) - np.mean(Y[T==0])\n",
    "print(\"ATE (Y): \", ATE)\n",
    "f, f_dis = predict(X, Y)\n",
    "ATE_f = np.mean(f[T==1]) - np.mean(f[T==0])\n",
    "print(\"ATE (f): \", ATE_f)\n",
    "ATE_f_dis = np.mean(f_dis[T==1]) - np.mean(f_dis[T==0])\n",
    "print(\"ATE (f_dis): \", ATE_f_dis)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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>seed</th>\n",
       "      <th>n</th>\n",
       "      <th>EAD_Y</th>\n",
       "      <th>EAD_f</th>\n",
       "      <th>EAD_f_bin</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>100</td>\n",
       "      <td>0.264106</td>\n",
       "      <td>0.166009</td>\n",
       "      <td>0.204482</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>100</td>\n",
       "      <td>0.126050</td>\n",
       "      <td>0.119008</td>\n",
       "      <td>0.108844</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>100</td>\n",
       "      <td>0.326299</td>\n",
       "      <td>0.241401</td>\n",
       "      <td>0.240260</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>100</td>\n",
       "      <td>0.251706</td>\n",
       "      <td>0.205988</td>\n",
       "      <td>0.230430</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>100</td>\n",
       "      <td>0.163961</td>\n",
       "      <td>0.136808</td>\n",
       "      <td>0.176948</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>995</th>\n",
       "      <td>45</td>\n",
       "      <td>100000</td>\n",
       "      <td>0.220750</td>\n",
       "      <td>0.219686</td>\n",
       "      <td>0.264563</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>996</th>\n",
       "      <td>46</td>\n",
       "      <td>100000</td>\n",
       "      <td>0.217390</td>\n",
       "      <td>0.219880</td>\n",
       "      <td>0.260759</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>997</th>\n",
       "      <td>47</td>\n",
       "      <td>100000</td>\n",
       "      <td>0.221723</td>\n",
       "      <td>0.220650</td>\n",
       "      <td>0.260857</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>998</th>\n",
       "      <td>48</td>\n",
       "      <td>100000</td>\n",
       "      <td>0.217252</td>\n",
       "      <td>0.219197</td>\n",
       "      <td>0.261651</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>999</th>\n",
       "      <td>49</td>\n",
       "      <td>100000</td>\n",
       "      <td>0.223452</td>\n",
       "      <td>0.221693</td>\n",
       "      <td>0.262582</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1000 rows × 5 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     seed       n     EAD_Y     EAD_f  EAD_f_bin\n",
       "0       0     100  0.264106  0.166009   0.204482\n",
       "1       1     100  0.126050  0.119008   0.108844\n",
       "2       2     100  0.326299  0.241401   0.240260\n",
       "3       3     100  0.251706  0.205988   0.230430\n",
       "4       4     100  0.163961  0.136808   0.176948\n",
       "..    ...     ...       ...       ...        ...\n",
       "995    45  100000  0.220750  0.219686   0.264563\n",
       "996    46  100000  0.217390  0.219880   0.260759\n",
       "997    47  100000  0.221723  0.220650   0.260857\n",
       "998    48  100000  0.217252  0.219197   0.261651\n",
       "999    49  100000  0.223452  0.221693   0.262582\n",
       "\n",
       "[1000 rows x 5 columns]"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data_sizes = np.logspace(2, 5, 20).astype(int)\n",
    "seeds = np.arange(50)\n",
    "\n",
    "columns = ['seed', 'n', 'EAD_Y', 'EAD_f', 'EAD_f_bin']\n",
    "results = pd.DataFrame(columns=columns)\n",
    "i = 0\n",
    "for n in data_sizes:\n",
    "    for seed in seeds:\n",
    "        np.random.seed(seed)\n",
    "        E, L, X, Y = generate_dataset(n)\n",
    "        f, f_bin = predict(X, Y)\n",
    "        EAD_Y = np.mean(Y[E==1]) - np.mean(Y[E==0])\n",
    "        EAD_f = np.mean(f[E==1]) - np.mean(f[E==0])\n",
    "        EAD_f_bin = np.mean(f_bin[E==1]) - np.mean(f_bin[E==0])\n",
    "        results.loc[i] = {\n",
    "            'seed': seed,\n",
    "            'n': n,\n",
    "            'EAD_Y': EAD_Y,\n",
    "            'EAD_f': EAD_f,\n",
    "            'EAD_f_bin': EAD_f_bin\n",
    "        }\n",
    "        i += 1\n",
    "results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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54MzDxp3Q6gOisfatS6qrGwqhBCie0lNizh0qg75Q+2gsvsD2PWe1LoIIYTodlLTIrpPotalqcoOLcVjIX+Y1LoIIYToFlLTIrqXqsf7uqiwe63UugghBq3FixdzxhlndLjPZZddxrnnnpu8PWvWLK699toeK9Py5cuZNm0apmn22GP0JAktome48+0p/5t2w8419ky6ppHrUgkhRNLq1avRNI2zzjqr1X2ffvopiqIkL36/n8MPP5zvfe97fPzxxwc9dygU4pZbbuG2227Lqkx/+MMfuOuuu7I6Jhtz587F4XDwm9/8psceoydJaBE9R3NAYCioij2T7u73IdSQ61IJIQRg14RcddVVvPbaa+zatavNfVasWMHu3bt5//33ufvuu9mwYQNTp05l5cqVHZ77ueeeIxAI8PnPfz6rMhUVFeH3+7M6prOi0Shg1+488MADPfIYPU1Ci+h57gLwlULjLtj5DtRtl1oXIURONTU1sWzZMr7zne9w1lln8cQTT7S5X3FxMeXl5YwZM4b/+q//YsWKFcycOZMrrrgCw2j/fezZZ5/l7LPPzthmGAbz58+noKCA4uJibrjhBg5cs/jA5qFf/vKXjB8/HrfbTVlZGRdccEHyPtM0WbhwIePGjcPlcjFixAh+8pOfAKmaomXLlnHyySfjdruTtStnn30277zzDlu2bMnmV9YnSGgRvSO91mX3WqhaK7UuQgxUzc3tX0Khzu8bDHZu3y747W9/y6RJk5g4cSJf/epXWbJkSasA0RZVVbnmmmvYtm0ba9asaXe/119/nenTp2ds+9nPfsYTTzzBkiVLeP3116mtreWPf/xju+d45513uPrqq7nzzjvZtGkTy5cv56STTkref9NNN3HPPfdwyy23sH79ep555hnKysoyznHjjTdyzTXXsGHDBubMmQPAiBEjKCsr45///OdBn29fI6OHRO9yF4AjDxo+g5Y6KBkbDzMywkiIAcPna/++L3wBXnwxdbu0FFpa2t735JNh1arU7VGjYN++1vt1YeX5xYsX89WvfhWw+3nU19fzj3/8g1mzZh302EmTJgF2bcaMGTNa3V9XV0d9fT2VlZUZ2xctWsRNN93EeeedB8AjjzzCX//613YfZ/v27eTl5fHFL34Rv9/PyJEjOeqoowBobGzk5z//OQ8++CDz5s0DYOzYsZxwwgkZ57j2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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# lineplot True Associational Difference and Estimated Associational Difference vs N (with confidence interval using seed)\n",
    "plt.figure(figsize=(6, 4))\n",
    "plt.axhline(norm.cdf(1/np.sqrt(3))-0.5, color='b', linestyle='--', label=r'AD')\n",
    "#sns.lineplot(data=results, x='n', y='EAD_Y', label=r'EAD$_{Y,E}$', errorbar='sd')\n",
    "sns.lineplot(data=results, x='n', y='EAD_f', label=r'EAD', errorbar='sd')\n",
    "plt.axhline(norm.cdf(1/np.sqrt(2))-0.5, color='r', linestyle='--', label=r'AD (discr)')\n",
    "#sns.lineplot(data=results, x='n', y='AD_star', label=r'EAD$(Y^*,E)$', errorbar='sd')\n",
    "sns.lineplot(data=results, x='n', y='EAD_f_bin', label=r'EAD (discr)', errorbar='sd')\n",
    "plt.xlabel('n')\n",
    "plt.ylabel('Associational Difference')\n",
    "plt.xscale('log')\n",
    "plt.ylim(0.12, 0.35)\n",
    "plt.xlim(10**2, 10**5)\n",
    "plt.legend(loc='upper right')\n",
    "plt.savefig('discretization.pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "crl",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
