{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "44aab8b4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Importting clipped adam...\n"
     ]
    }
   ],
   "source": [
    "import numpy as np \n",
    "import matplotlib.pyplot as plt \n",
    "\n",
    "from bartpy.sklearnmodel import SklearnModel\n",
    "\n",
    "from matplotlib import style\n",
    "\n",
    "from sklearn.preprocessing import MinMaxScaler\n",
    "from variationalRegressionTree import CVTree \n",
    "import torch \n",
    "\n",
    "\n",
    "style.use('ggplot')\n",
    "\n",
    "SEED = 314159\n",
    "\n",
    "N = 500\n",
    "\n",
    "train = False\n",
    "\n",
    "rng = np.random.default_rng(SEED)\n",
    "torch.manual_seed(SEED)\n",
    "\n",
    "A = rng.binomial(1,0.5,size=(N,))\n",
    "X = A*rng.normal(50,10, size=(N,)) + (1-A)*rng.normal(40,10, size=(N,))\n",
    "X[X < 0] = 0.0\n",
    "A, X = A.reshape(-1,1), X.reshape(-1,1)\n",
    "Y = (1-A)*rng.normal(72 + 3*np.sqrt((1-A)*X), 1) + (A)*rng.normal(90 + np.exp(0.06*X), 1)\n",
    "\n",
    "DATA = np.hstack((A,X))\n",
    "A, X = A.reshape(-1), X.reshape(-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3052bc08",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9.560403531302061\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "### True effects ###\n",
    "\n",
    "plt.title(\"Causal Effect Computation\")\n",
    "\n",
    "x_range_min = 20\n",
    "x_range = 50\n",
    "\n",
    "\n",
    "plt.plot(np.arange(0,x_range),72 + 3*np.sqrt(np.arange(0,x_range)), label=r\"$Y(0)$\")\n",
    "plt.scatter(X[A == 0], Y[A == 0])\n",
    "\n",
    "plt.plot(np.arange(0,x_range),90 + np.exp(0.06*np.arange(0,x_range)), label=r\"$Y(1)$\")\n",
    "plt.scatter(X[A == 1], Y[A == 1])\n",
    "\n",
    "plt.legend();\n",
    "\n",
    "\n",
    "print(( (90 + np.exp(0.06*np.arange(x_range_min,x_range))) - (72 + 3*np.sqrt(np.arange(x_range_min,x_range)))).mean() )\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "20e5e47d",
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "all the input array dimensions for the concatenation axis must match exactly, but along dimension 0, the array at index 0 has size 50 and the array at index 1 has size 30",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Input \u001b[1;32mIn [4]\u001b[0m, in \u001b[0;36m<cell line: 26>\u001b[1;34m()\u001b[0m\n\u001b[0;32m     23\u001b[0m X_train[:,\u001b[38;5;241m1\u001b[39m] \u001b[38;5;241m=\u001b[39m scaler_features\u001b[38;5;241m.\u001b[39mtransform(X_train[:,\u001b[38;5;241m1\u001b[39m]\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m))\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m)\n\u001b[0;32m     24\u001b[0m y_train \u001b[38;5;241m=\u001b[39m scaler_target\u001b[38;5;241m.\u001b[39mtransform(y_train\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m))\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m)\n\u001b[1;32m---> 26\u001b[0m X_1 \u001b[38;5;241m=\u001b[39m \u001b[43mnp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mhstack\u001b[49m\u001b[43m(\u001b[49m\u001b[43m(\u001b[49m\u001b[43mnp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mones\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx_range\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mreshape\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m-\u001b[39;49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m,\u001b[49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mnp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43marange\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx_range_min\u001b[49m\u001b[43m,\u001b[49m\u001b[43mx_range\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mreshape\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m-\u001b[39;49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m,\u001b[49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mnp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mones\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx_range\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mreshape\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m-\u001b[39;49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m,\u001b[49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     27\u001b[0m X_0 \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mhstack(((\u001b[38;5;241m1\u001b[39m \u001b[38;5;241m-\u001b[39m np\u001b[38;5;241m.\u001b[39mones(x_range)\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m)), np\u001b[38;5;241m.\u001b[39marange(x_range_min,x_range)\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m), np\u001b[38;5;241m.\u001b[39mones(x_range)\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m)))\n\u001b[0;32m     29\u001b[0m X_1[:,\u001b[38;5;241m1\u001b[39m] \u001b[38;5;241m=\u001b[39m scaler_features\u001b[38;5;241m.\u001b[39mtransform(X_1[:,\u001b[38;5;241m1\u001b[39m]\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m))\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m)\n",
      "File \u001b[1;32m<__array_function__ internals>:180\u001b[0m, in \u001b[0;36mhstack\u001b[1;34m(*args, **kwargs)\u001b[0m\n",
      "File \u001b[1;32m~\\anaconda3\\envs\\my-torch\\lib\\site-packages\\numpy\\core\\shape_base.py:345\u001b[0m, in \u001b[0;36mhstack\u001b[1;34m(tup)\u001b[0m\n\u001b[0;32m    343\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m _nx\u001b[38;5;241m.\u001b[39mconcatenate(arrs, \u001b[38;5;241m0\u001b[39m)\n\u001b[0;32m    344\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m--> 345\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_nx\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mconcatenate\u001b[49m\u001b[43m(\u001b[49m\u001b[43marrs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "File \u001b[1;32m<__array_function__ internals>:180\u001b[0m, in \u001b[0;36mconcatenate\u001b[1;34m(*args, **kwargs)\u001b[0m\n",
      "\u001b[1;31mValueError\u001b[0m: all the input array dimensions for the concatenation axis must match exactly, but along dimension 0, the array at index 0 has size 50 and the array at index 1 has size 30"
     ]
    }
   ],
   "source": [
    "import scipy.stats\n",
    "DEVICE = 'cpu'\n",
    "MAX_TREE_DEPTH = 7\n",
    "EPOCHS = 2500\n",
    "LR0 = 0.01\n",
    "LRF = 0.01\n",
    "CLIP_NORM = 1.0\n",
    "\n",
    "\n",
    "regressionTrees = [] \n",
    "\n",
    "X_train = DATA\n",
    "y_train = Y\n",
    "\n",
    "#Add intercept\n",
    "X_train = np.hstack((X_train, np.ones(X_train.shape[0]).reshape(-1,1)))\n",
    "\n",
    "scaler_features = MinMaxScaler(feature_range=(-1,1), copy=True)\n",
    "scaler_target = MinMaxScaler(feature_range=(-1,1), copy=True)\n",
    "\n",
    "scaler_features.fit(X_train[:,1].reshape(-1,1))\n",
    "scaler_target.fit(y_train.reshape(-1,1))\n",
    "\n",
    "X_train[:,1] = scaler_features.transform(X_train[:,1].reshape(-1,1)).reshape(-1)\n",
    "y_train = scaler_target.transform(y_train.reshape(-1,1)).reshape(-1)\n",
    "\n",
    "X_1 = np.hstack((np.ones(x_range).reshape(-1,1), np.arange(x_range_min,x_range).reshape(-1,1), np.ones(x_range).reshape(-1,1)))\n",
    "X_0 = np.hstack(((1 - np.ones(x_range).reshape(-1,1)), np.arange(x_range_min,x_range).reshape(-1,1), np.ones(x_range).reshape(-1,1)))\n",
    "\n",
    "X_1[:,1] = scaler_features.transform(X_1[:,1].reshape(-1,1)).reshape(-1)\n",
    "X_0[:,1] = scaler_features.transform(X_0[:,1].reshape(-1,1)).reshape(-1)\n",
    "\n",
    "X_1 = torch.from_numpy(X_1).to(DEVICE)\n",
    "X_0 = torch.from_numpy(X_0).to(DEVICE)\n",
    "\n",
    "X_train = torch.from_numpy(X_train).to(DEVICE)\n",
    "y_train = torch.from_numpy(y_train).to(DEVICE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "69fd951f",
   "metadata": {},
   "outputs": [],
   "source": [
    "from bartpy.sklearnmodel import SklearnModel\n",
    "# train = False\n",
    "if not train:\n",
    "    model = SklearnModel(n_trees=200) # Use default parameters\n",
    "    model.fit(X_train.cpu().numpy(), y_train.cpu().numpy())\n",
    "    train = True "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e4af1aff",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                                                                                       \r"
     ]
    },
    {
     "data": {
      "text/plain": [
       "0.01711526125153251"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "s = 5\n",
    "num_depths = 3\n",
    "depths = [6]\n",
    "epochs = [1000]\n",
    "\n",
    "vTrees = CVTree(X_train, y_train, n_trees = len(depths), device = DEVICE, tree_depth = depths)\n",
    "vTrees.train_trees(epochs = epochs, samples=1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "4618185a",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                                                                                       \r"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from tqdm import tqdm \n",
    "from warnings import filterwarnings\n",
    "\n",
    "filterwarnings(\"ignore\")\n",
    "\n",
    "predictions_1 = vTrees.predict(torch.tensor(X_1).to(DEVICE), samples=100)\n",
    "predictions_0 = vTrees.predict(torch.tensor(X_0).to(DEVICE), samples=100)\n",
    "    \n",
    "predictions_1, predictions_0 = np.array(predictions_1), np.array(predictions_0)\n",
    "\n",
    "predictions_1 = scaler_target.inverse_transform(predictions_1.reshape(-1,1)).reshape(-1,)\n",
    "predictions_0 = scaler_target.inverse_transform(predictions_0.reshape(-1,1)).reshape(-1,)\n",
    "\n",
    "predictions_0_BART = model.predict(X_0.cpu().numpy())\n",
    "predictions_1_BART = model.predict(X_1.cpu().numpy())\n",
    "\n",
    "predictions_0_BART = scaler_target.inverse_transform(predictions_0_BART.reshape(-1,1)).reshape(-1,)\n",
    "predictions_1_BART = scaler_target.inverse_transform(predictions_1_BART.reshape(-1,1)).reshape(-1,)\n",
    "\n",
    "\n",
    "### True effects ###\n",
    "\n",
    "plt.xlabel(r\"Covariates $X$\")\n",
    "plt.ylabel(r\"Outcome $Y$\")\n",
    "\n",
    "plt.plot(np.arange(0,x_range),72 + 3*np.sqrt(np.arange(0,x_range)), label=r\"$Y(0)$\")\n",
    "plt.scatter(X[A == 0], Y[A == 0])\n",
    "\n",
    "plt.plot(np.arange(0,x_range),90 + np.exp(0.06*np.arange(0,x_range)), label=r\"$Y(1)$\")\n",
    "plt.scatter(X[A == 1], Y[A == 1])\n",
    "\n",
    "\n",
    "plt.plot(np.arange(0,x_range), predictions_0, label=\"Y(0) pred VaRT\", linestyle='--')\n",
    "plt.plot(np.arange(0,x_range), predictions_1, label=\"Y(1) pred VaRT\", linestyle='--')\n",
    "\n",
    "plt.plot(np.arange(0,x_range), predictions_1_BART, label=\"Y(1) pred BART\", linestyle='--')\n",
    "plt.plot(np.arange(0,x_range), predictions_0_BART, label=\"Y(0) pred BART\", linestyle='--')\n",
    "plt.legend();\n",
    "\n",
    "VaRT_ATE = (predictions_1 - predictions_0).mean()\n",
    "BART_ATE = (predictions_1_BART - predictions_0_BART).mean()\n",
    "\n",
    "\n",
    "plt.title(f\"Conditional Causal Effect Estimation \\n VaRT: {VaRT_ATE:.2f} \\n BART: {BART_ATE:.2f} \\n Ground Truth: {17.88}\");\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8ca45e41",
   "metadata": {},
   "source": [
    "To install the anaconda environment to be used for reproduction of the results, run\n",
    "the following command in an anaconda prompt:\n",
    "\n",
    "```console\n",
    "conda env create -f environment.yml\n",
    "```\n",
    "\n",
    "**** Note that a CUDA enabled machine is required as the enviroment \n",
    "uses a CUDA enabled version of torch ****\n",
    "\n",
    "**** To import the UCI datasets see the following github repo: https://github.com/treforevans/uci_datasets **** \n",
    "\n",
    "This directory contains the following files:\n",
    "\n",
    "(1) variationalRegressionTree.py:\n",
    "\tContains the main VaRT class that is used in all the experiments. \n",
    "\tIt features an sklearn-like interface for fitting the model.\n",
    "\n",
    "(2) utils_reg.py:\n",
    "\tContains several useful helper functions.\n",
    "\n",
    "(3) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "10dc7c16",
   "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
