{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "908079c6-6f56-428b-9ab6-a82659a2600d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import os\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "sys.path.append(\"../../src\")\n",
    "import jax.numpy as jnp\n",
    "from tqdm import tqdm\n",
    "from copy import deepcopy\n",
    "\n",
    "from utils.kernel_utils import Kernel, ColumnwiseRBF, RBF, MaternKernel, ColumnwiseMaternKernel, EpanechnikovKernel, LinearKernel\n",
    "from causal_models.proxy_causal_learning import KernelProxyVariableATE\n",
    "from utils.experimental_data_functions import generate_synthetic_ATE_data\n",
    "from utils.ml_utils import data_transform"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "9b2e1ff6-7b09-4ff7-9caf-2f56a9c26872",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_size = 1000\n",
    "train_size = 900\n",
    "test_size = 100\n",
    "seed = np.random.randint(1000000)\n",
    "np.random.seed(seed)\n",
    "\n",
    "U, W, Z, A, Y, do_A, EY_do_A = generate_synthetic_ATE_data(size = data_size, seed = seed, do_A_range = (-1, 2))\n",
    "W_train, Z_train, A_train, Y_train = W[:train_size], Z[:train_size], A[:train_size], Y[:train_size]\n",
    "W_test, Z_test, A_test, Y_test = W[train_size: train_size + test_size], Z[train_size: train_size + test_size], A[train_size: train_size + test_size], Y[train_size: train_size + test_size]\n",
    "\n",
    "A_transformed, A_transformer = data_transform(A_train)\n",
    "Z_transformed, Z_transformer = data_transform(Z_train)\n",
    "W_transformed, W_transformer = data_transform(W_train)\n",
    "Y_transformed, Y_transformer = data_transform(Y_train)\n",
    "\n",
    "A_test_transformed = jnp.array(A_transformer.transform(A_test).reshape(test_size, -1))\n",
    "Z_test_transformed = jnp.array(Z_transformer.transform(Z_test).reshape(test_size, -1))\n",
    "W_test_transformed = jnp.array(W_transformer.transform(W_test).reshape(test_size, -1))\n",
    "Y_test_transformed = jnp.array(Y_transformer.transform(Y_test).reshape(test_size, -1))\n",
    "\n",
    "A_transformed = jnp.array(A_transformed).reshape(train_size, -1)\n",
    "Z_transformed = jnp.array(Z_transformed).reshape(train_size, -1)\n",
    "W_transformed = jnp.array(W_transformed).reshape(train_size, -1)\n",
    "Y_transformed = jnp.array(Y_transformed).reshape(train_size, -1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "206ca19d-070f-4f2f-a2b6-088bc6f2a189",
   "metadata": {},
   "outputs": [],
   "source": [
    "RBF_Kernel_Z = RBF(use_length_scale_heuristic = True, use_jit_call = True)\n",
    "RBF_Kernel_A = RBF(use_length_scale_heuristic = True, use_jit_call = True)\n",
    "RBF_Kernel_W = 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",
    "\n",
    "lambda1_ = 0.01\n",
    "lambda2_ = 1.2*1e-1\n",
    "optimize_lambda1_parameter = True\n",
    "optimize_lambda2_parameter = True\n",
    "lambda1_optimization_range = (1e-7, 1.0)\n",
    "lambda2_optimization_range = (1e-7, 1.0)\n",
    "stage1_perc = 0.5\n",
    "regularization_grid_points = 150\n",
    "make_psd_eps = 5*1e-9\n",
    "\n",
    "model = KernelProxyVariableATE(\n",
    "                                     kernel_A = RBF_Kernel_A,\n",
    "                                     kernel_W = RBF_Kernel_W, \n",
    "                                     kernel_Z = RBF_Kernel_Z,\n",
    "                                     kernel_X = RBF_Kernel_X,\n",
    "                                     lambda1_ = lambda1_,\n",
    "                                     lambda2_ = lambda2_,\n",
    "                                     optimize_lambda1_parameter = optimize_lambda1_parameter,\n",
    "                                     optimize_lambda2_parameter = optimize_lambda2_parameter,\n",
    "                                     lambda1_optimization_range = lambda1_optimization_range,\n",
    "                                     lambda2_optimization_range = lambda2_optimization_range,\n",
    "                                     stage1_perc = stage1_perc,\n",
    "                                     regularization_grid_points = regularization_grid_points, \n",
    "                                     make_psd_eps = make_psd_eps,\n",
    "                                     )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "15bb78d6-c837-4664-84ae-80bf2299f215",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Structured function test set MSE: 0.0623924308828267\n",
      "Structured function test set MAE: 0.2043114573673207\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x74df302dc250>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model.fit((A_transformed, W_transformed, Z_transformed,), Y_transformed)\n",
    "do_A_size = do_A.shape[0]\n",
    "do_A_transformed = (A_transformer.transform(do_A.reshape(-1, 1))).reshape(do_A_size, -1)\n",
    "f_struct_pred_transformed = 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",
    "structured_pred_mse = (np.mean((f_struct_pred.reshape(-1, 1) - EY_do_A.reshape(-1, 1)) ** 2))\n",
    "structured_pred_mae = (np.mean(np.abs(f_struct_pred.reshape(-1, 1) - EY_do_A.reshape(-1, 1))))\n",
    "print(\"Structured function test set MSE: {}\".format(structured_pred_mse))\n",
    "print(\"Structured function test set MAE: {}\".format(structured_pred_mae))\n",
    "\n",
    "plt.plot(do_A, f_struct_pred, label = \"ATE prediction\")\n",
    "plt.plot(do_A, 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()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5db74194-43e6-4360-bcac-be859acd181d",
   "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
}
