{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "0760f316-c694-412f-91a8-93bcc438e64e",
   "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.ml_utils import data_transform\n",
    "from src.utils.experimental_data_functions import read_legalized_abortion_and_crime_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "70dc87a4-e232-4328-8ee6-faf8c3d7969e",
   "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": "9f6efedd-b773-4ab1-ac9b-81bea5c62047",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_path = '../../data/abortion'\n",
    "return_test = True\n",
    "seed = 0\n",
    "W, Z, A, Y, W_test, Z_test, A_test, Y_test, do_A, EY_do_A = read_legalized_abortion_and_crime_dataset(data_path, return_test, seed)\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",
    "test_shape = A_test.shape[0]\n",
    "A_test_transformed = A_transformer.transform(A_test).reshape(test_shape, -1)\n",
    "Z_test_transformed = Z_transformer.transform(Z_test).reshape(test_shape, -1)\n",
    "W_test_transformed = W_transformer.transform(W_test).reshape(test_shape, -1)\n",
    "Y_test_transformed = Y_transformer.transform(Y_test).reshape(test_shape, -1)\n",
    "\n",
    "do_A_size = do_A.shape[0]\n",
    "do_A_transformed = (A_transformer.transform(do_A)).reshape(do_A_size, -1)\n",
    "EY_do_A_transformed = (Y_transformer.transform(EY_do_A)).reshape(do_A_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",
    "\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": "0a9c4a7c-60a4-4c9a-a61a-689ab53225ba",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Structured function test set MSE: 0.018358390727328144\n",
      "Structured function test set MAE: 0.11263274937919923\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": "f8ab850b-b87d-426a-bac5-f4b5036ee1cb",
   "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
}
