{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d38c4a5b-a726-41c6-b566-7e1afa2feb03",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append(\"../../src/other_methods/DoublyRobustPCL\")\n",
    "sys.path.append(\"../..\")\n",
    "\n",
    "import yaml\n",
    "import os\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from utils.data_class import PVTrainDataSet,PVTestDataSet\n",
    "from model.rkhs.Trainer import RKHS_Trainer\n",
    "from src.utils.experimental_data_functions import generate_synthetic_ATE_data\n",
    "from src.utils.ml_utils import data_transform"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "64f7ec05-a8f9-4c1c-9878-9190a638bb2e",
   "metadata": {},
   "outputs": [],
   "source": [
    "cfg = \"../../src/other_methods/DoublyRobustPCL/config/job/train/default.yaml\"\n",
    "\n",
    "with open(cfg) as stream:\n",
    "    try:\n",
    "        cfg = yaml.safe_load(stream)\n",
    "        # print(yaml.safe_load(stream))\n",
    "    except yaml.YAMLError as exc:\n",
    "        print(exc)\n",
    "\n",
    "class obj(object):\n",
    "    def __init__(self, d):\n",
    "        for k, v in d.items():\n",
    "            if isinstance(k, (list, tuple)):\n",
    "                setattr(self, k, [obj(x) if isinstance(x, dict) else x for x in v])\n",
    "            else:\n",
    "                setattr(self, k, obj(v) if isinstance(v, dict) else v)\n",
    "\n",
    "cfg = obj(cfg)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b9b4257b-fa9e-493c-b0d2-77206d4ddbef",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_size = 1000\n",
    "test_data_size = 1000\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",
    "\n",
    "_, W_test, Z_test, A_test, Y_test, *_ = generate_synthetic_ATE_data(size = test_data_size, seed = seed + 1)\n",
    "\n",
    "\n",
    "A_transformed, A_transformer = data_transform(A)\n",
    "Z_transformed, Z_transformer = data_transform(Z)\n",
    "W_transformed, W_transformer = data_transform(W)\n",
    "Y_transformed, Y_transformer = data_transform(Y)\n",
    "\n",
    "data_size = A_transformed.shape[0]\n",
    "A_transformed = np.array(A_transformed).reshape(data_size, -1)\n",
    "Z_transformed = np.array(Z_transformed).reshape(data_size, -1)\n",
    "W_transformed = np.array(W_transformed).reshape(data_size, -1)\n",
    "Y_transformed = np.array(Y_transformed).reshape(data_size, -1)\n",
    "\n",
    "train_dataset = PVTrainDataSet( treatment = A_transformed,\n",
    "                                treatment_proxy = Z_transformed,\n",
    "                                outcome_proxy = W_transformed,\n",
    "                                outcome = Y_transformed,\n",
    "                                backdoor = None)\n",
    "\n",
    "A_test_transformed = A_transformer.transform(A_test).reshape(test_data_size, -1)\n",
    "Z_test_transformed = Z_transformer.transform(Z_test).reshape(test_data_size, -1)\n",
    "W_test_transformed = W_transformer.transform(W_test).reshape(test_data_size, -1)\n",
    "Y_test_transformed = Y_transformer.transform(Y_test).reshape(test_data_size, -1)\n",
    "\n",
    "test_dataset = PVTrainDataSet(  treatment = A_test_transformed,\n",
    "                                treatment_proxy = Z_test_transformed,\n",
    "                                outcome_proxy = W_test_transformed,\n",
    "                                outcome = Y_test_transformed,\n",
    "                                backdoor = None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "024cc9a0-2b13-4b2d-bd50-ab740dd74aa3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Structured function test set MSE: 0.03561670248119402\n",
      "Structured function test set MAE: 0.1538864923573096\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "rkhs_train = RKHS_Trainer(cfg, train_dataset)\n",
    "\n",
    "# Train q\n",
    "rkhs_train.fit_q_cv()\n",
    "rkhs_train.fit_h_cv()\n",
    "do_A_size = do_A.shape[0]\n",
    "do_A_transformed = (A_transformer.transform(do_A)).reshape(do_A_size, -1)\n",
    "ATE_q_transformed = rkhs_train._drtest(do_A_transformed, test_dataset)\n",
    "f_struct_pred = Y_transformer.inverse_transform(np.array(ATE_q_transformed).reshape(-1, 1))\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",
    "\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()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2174ce1e-c70d-4390-b01b-6c56d05ac628",
   "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
}
