{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "21f27749-00ed-47e0-9912-80aedc092dcc",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append(\"../../src\")\n",
    "sys.path.append(\"..\")\n",
    "\n",
    "import numpy as np\n",
    "import jax.numpy as jnp\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from utils.kernel_utils import RBF, ColumnwiseRBF\n",
    "from causal_models.causal_learning import KernelATE, KernelATT\n",
    "from utils.experimental_data_functions import generate_train_jobcorp_data\n",
    "from utils.ml_utils import data_transform\n",
    "\n",
    "from jax import config\n",
    "config.update(\"jax_enable_x64\", True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "5bb77d92-0d97-4035-a337-adb91d6254b1",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)\n"
     ]
    }
   ],
   "source": [
    "data_path = '../../data/JCdata.csv'\n",
    "\n",
    "U, Y, A = generate_train_jobcorp_data(data_path)\n",
    "U = jnp.array(U, dtype = jnp.float64)\n",
    "Y = jnp.array(Y, dtype = jnp.float64)\n",
    "A = jnp.array(A, dtype = jnp.float64)\n",
    "\n",
    "U_transformed, U_transformer = data_transform(U)\n",
    "A_transformed, A_transformer = data_transform(A)\n",
    "\n",
    "data_size = A_transformed.shape[0]\n",
    "A_transformed = jnp.array(A_transformed).reshape(data_size, -1)\n",
    "U_transformed = jnp.array(U_transformed).reshape(data_size, -1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "adefa0a9-1445-4d78-b05c-26e94c9785b6",
   "metadata": {},
   "source": [
    "# Average Treatment Effect Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ee13bce2-f887-44ed-bb73-8fe321490884",
   "metadata": {},
   "outputs": [],
   "source": [
    "kernel_X = RBF(use_length_scale_heuristic = True, use_jit_call = True)\n",
    "kernel_A = RBF(use_length_scale_heuristic = True, )\n",
    "optimize_regularization_parameters = True\n",
    "lambda_optimization_range = (1e-5, 1.0)\n",
    "regularization_grid_points = 150\n",
    "\n",
    "KernelATE_model = KernelATE(kernel_X = kernel_X,\n",
    "                            kernel_A = kernel_A, \n",
    "                            optimize_regularization_parameters = optimize_regularization_parameters, \n",
    "                            lambda_optimization_range = lambda_optimization_range, \n",
    "                            regularization_grid_points = regularization_grid_points)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "62d4edfd-5092-4257-bd93-26ee163c69da",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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vk04h6SIiIg6DcONCaVdnEwc7sUhKSIios7CcGNCaReHpboz3BAREXUahhsT+mdYiuGGiIioszDcmEhFrQZ5ZY1PSnX35JwbIiKizsJwYyIZhVUAAC9HNZzt+KQUERFRZ2G4MZG0i9sucEiKiIioczHcmEjTfJvungw3REREnYnhxkTSmsIN17ghIiLqVAw3JtL0GDjXuCEiIupcDDcmUFOvxbkLNQAYboiIiDobw40JZBRWQhQBN3sV3B3UUpdDRERkVRhuTEA/mZi9NkRERJ2O4cYEuO0CERGRdBhuTIAbZhIREUmH4cYE0gubwg0fAyciIupsDDdGVtegxZniagBcnZiIiEgKDDdGllVUDa1OhKONAl6OfFKKiIioszHcGNm/JxMLgiBxNURERNaH4cbImh4D52RiIiIiaTDcGFlaAScTExERSYnhxsjS85s2zGTPDRERkRQYboyoQavD6SIOSxEREUmJ4caIzpRUQ6MVYauUw8/ZVupyiIiIrBLDjRH9e08pmYxPShEREUmB4caI+KQUERGR9BhujCgt/+IaN5xMTEREJBmGGyOqa9BBIRP4GDgREZGEFFIXYEk+mD4Q9Q06qcsgIiKyagw3RqZSsDOMiIhISvwkJiIiIovCcENEREQWheGGiIiILArDDREREVkUhhsiIiKyKAw3REREZFEYboiIiMiiMNwQERGRRWG4ISIiIovCcENEREQWheGGiIiILArDDREREVkUhhsiIiKyKFa5K7goigCA8vLyNr9Ho9Gguroa5eXlUCqVpipNctbQTmtoI2Ad7bSGNgLW0U5raCNgHe00ZRubPrebPscvxSrDTUVFBQAgMDBQ4kqIiIiovSoqKuDs7HzJ1wXxSvHHAul0OuTm5sLR0RGCILTpPeXl5QgMDMTZs2fh5ORk4gqlYw3ttIY2AtbRTmtoI2Ad7bSGNgLW0U5TtlEURVRUVMDPzw8y2aVn1lhlz41MJkNAQECH3uvk5GSxfyD/zRraaQ1tBKyjndbQRsA62mkNbQSso52mauPlemyacEIxERERWRSGGyIiIrIoDDdtpFar8dxzz0GtVktdiklZQzutoY2AdbTTGtoIWEc7raGNgHW00xzaaJUTiomIiMhyseeGiIiILArDDREREVkUhhsiIiKyKAw3REREZFEYbtrovffeQ0hICGxsbDBkyBDs379f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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "KernelATE_model.fit((A_transformed, U_transformed), Y)\n",
    "\n",
    "do_A = jnp.linspace(40, 2000, 1000)[:, jnp.newaxis]\n",
    "A_linspace = do_A\n",
    "do_A_size = do_A.shape[0]\n",
    "\n",
    "do_A_transformed = (A_transformer.transform(do_A)).reshape(do_A_size, -1)\n",
    "\n",
    "f_struct_pred = KernelATE_model.predict(do_A_transformed)\n",
    "# f_struct_pred = Y_transformer.inverse_transform(f_struct_pred_transformed.reshape(do_A_size, -1)).reshape(do_A_size, -1)\n",
    "\n",
    "plt.plot(do_A, f_struct_pred, label = \"Pred\")\n",
    "# plt.plot(A_linspace, EY_do_A, linewidth = 4, color = \"red\", alpha=0.7, linestyle = \"dashed\", label = \"f-struct\")\n",
    "plt.grid()\n",
    "plt.xlabel(\"a (treatment)\")\n",
    "plt.ylabel(r\"$Y^{(a)}$ (treatment effect)\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e6efe120-e1e3-4527-b7a4-c2fe1c67cf2b",
   "metadata": {},
   "source": [
    "# Average Treatment on the Treated Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "aed51b52-6de7-4701-9fc4-d43eff5ab1a1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "RBF_Kernel_A_ = RBF(use_length_scale_heuristic = True, use_jit_call = True)\n",
    "RBF_Kernel_X_ = RBF(use_length_scale_heuristic = True, use_jit_call = True)\n",
    "optimize_regularization_parameters = True\n",
    "lambda_optimization_range = (1e-5, 1.0)\n",
    "regularization_grid_points = 150\n",
    "\n",
    "model_KernelATT = KernelATT(\n",
    "    kernel_A = RBF_Kernel_A_,\n",
    "    kernel_X = RBF_Kernel_X_,\n",
    "    optimize_regularization_parameters = optimize_regularization_parameters, \n",
    "    lambda_optimization_range = lambda_optimization_range, \n",
    "    regularization_grid_points = regularization_grid_points\n",
    ")\n",
    "\n",
    "model_KernelATT.fit((A_transformed, U_transformed), Y)\n",
    "\n",
    "a_prime = jnp.array([2000])\n",
    "f_struct_pred_katt= model_KernelATT.predict(do_A_transformed, A_transformer.transform(a_prime.reshape(-1, 1)))\n",
    "# f_struct_pred_katt = Y_transformer.inverse_transform(f_struct_pred_transformed.reshape(do_A_size, -1)).reshape(do_A_size, -1)\n",
    "\n",
    "plt.plot(do_A, f_struct_pred_katt, label = \"Pred\")\n",
    "# plt.plot(A_linspace, EY_do_A, linewidth = 4, color = \"red\", alpha=0.7, linestyle = \"dashed\", label = \"f-struct\")\n",
    "plt.grid()\n",
    "plt.xlabel(\"a (treatment)\")\n",
    "plt.ylabel(r\"$Y^{(a)}$ (treatment effect)\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "149327c3-9a7a-44ef-8419-ff6d25b6f2eb",
   "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
}
