{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 144,
   "id": "93d79484",
   "metadata": {},
   "outputs": [],
   "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 multiprocessing import Process\n",
    "from multiprocessing import Pool \n",
    "\n",
    "\n",
    "style.use('ggplot')\n",
    "\n",
    "SEED = 2\n",
    "\n",
    "N = 500\n",
    "\n",
    "train = False\n",
    "\n",
    "rng = np.random.default_rng(SEED)\n",
    "\n",
    "A = rng.binomial(1,0.5,size=(N,))\n",
    "X = A*rng.normal(40,10, size=(N,)) + (1-A)*rng.normal(20,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": 145,
   "id": "a2c58ec4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "17.87791772821296\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXcAAAEJCAYAAABv6GdPAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy89olMNAAAACXBIWXMAAAsTAAALEwEAmpwYAAA800lEQVR4nO3deXxTZb4/8M85WbumSbfQUtYWENkcYNgpQkdkBkeGO+LGODhwvSqOSFFZBRS9cq/sm3iBEQUcdUYWx9/oOBWFlxaQXaBAoRZooemWdEmbNNvz+yNtaJqlaZu93/frxYvm5CT5psunT5/zLBxjjIEQQkhY4QNdACGEEO+jcCeEkDBE4U4IIWGIwp0QQsIQhTshhIQhCndCCAlDFO7EJ3bv3g2hUOiV51qyZAmSk5PBcRx2794NANi8eTO6du0KnuexcuVKr7wO6bhZs2YhKysr0GUQAGAkZFRUVLBXXnmF9enTh0kkEpaYmMjGjRvHPvjgA2Y0GgNdnp3333+fCQQCt+f88Y9/ZAAc/kVFRdnOOX78OAPADh48yEpKSlh9fT27ffs243mebdmyhd25c4fV1tZ6peZJkyaxP/7xjx6dazQa2aZNm9jw4cNZdHQ0i42NZUOGDGFvvvkmU6vVXqnHH9rynpvbs2cPcxYfVVVVIfX+w5l3mlbE54qLizFmzBgIhUK88cYbuO+++yASiZCbm4s1a9Zg0KBBGDJkSKDLbLNx48bh008/tTvG83f/oLx27Rp4nsfDDz9sO3b69GlYLBb89re/RZcuXfxWaxOj0YipU6fi2LFjWL58OTIzM5GYmIi8vDy8++67iIqKwksvveT3uoKBTCYLdAmkSaB/uxDPTJ06lSUnJ7OqqiqH+wwGA9NqtYwxxr7++muWmZnJ5HI5i42NZePHj2cnTpywOx8A27Nnj92xli24gwcPsiFDhrCIiAgmk8nY8OHD2ZkzZxhjjFksFjZnzhzWq1cvJpVKWc+ePdnixYuZXq+3Pd7TlvukSZPc3o8WrfoVK1Y4HCssLLS999GjRzOpVMpSUlLYrFmzWEVFhd1zfvzxx+wXv/gFk0gkTKFQsAcffJCp1Wqnr/Xtt986rWvNmjWM4ziWm5vr9P7mLdfdu3eze+65h4nFYpaamsqWLl1q91dWZmYm+9Of/sSWLl3KEhMTmUwmY0uWLGFms5m9/vrrLCkpiSUkJLAlS5bYvUb37t3ZkiVL2OzZs1lMTAyLj49nr776KjObzXbnrFq1yu5xs2fPZpmZmS4/v03vecmSJaxfv34sIiKCde3alf3Xf/2X7Xvv22+/dXhc0/dOy6+pxWJh77zzDuvZsycTiUSsV69ebP369Q7v5bXXXmMvvvgik8vlLCkpiS1YsICZTCann1/iGQr3EFBZWcl4nnf4QXVm//797NNPP2VXr15lFy9eZLNnz2Zyudwu5FoL95KSEiYSidj//M//sJ9//pnl5eWxffv2sZ9++okxxpjZbGZLly5lx48fZ4WFhezQoUNMqVSy5cuX257PG+FeVVXFNmzYwAQCASspKWElJSWstraWffbZZwwAO3PmDCspKWEmk4l98803LCIigm3atInl5+ezH3/8kU2YMIGNGzeOWSwWxhhjf/nLX5hQKGRvvPEGu3TpEjt//jzbsGEDKy8vZ1VVVWzcuHFsxowZttdqaGhwWtfgwYPd1t3kiy++YDzPs//+7/9mV69eZR9//DGLi4tjy5Yts52TmZnJYmNj2auvvsquXr3Kdu3axQCwKVOmsFdeeYVdvXqV7d69mwFg//znP22P6969O4uJiWGvvfYau3LlCvvwww9ZZGQkW7t2rd057sLd3XtetWoVO3r0KCssLGQ5OTmsb9++7KmnnmKMMdbQ0MC2bNnCANge1xT8Lb+mW7ZsYVKplL333nssPz+fvfvuu0wikbCdO3fa1RkXF8fefvttlp+fzz7++GMmEAjYX/7yl1Y/x8Q1CvcQcOLECQaAffbZZ21+rNlsZnFxcWzv3r22Y62F+5kzZ+xaxJ5Yt24dS09Pt932NNwFAgGLioqy+zd16lS3z9PUciwqKrIdy8zMZAsXLrQ77+bNmwwAO3v2LGOMsbS0NDZ37lyX9Xja/xwREcH+/Oc/t3re2LFj2SOPPGJ3bMOGDUwqldpCNDMzkw0ePNjunP79+7MBAwbYHRs0aBBbsGCB7Xb37t3Z2LFj7c5ZvHgxS01NtTvHXbgz5vl73r9/PxOLxba/DFz1ubcM965du7JXXnnF7pyXXnqJ9ezZ067Ohx56yO6cyZMns8cee6zVuohrNFomBLDGtd04jmv13MLCQvzhD39Aeno6YmNjERsbi+rqaty8edPj1xs0aBAmT56MAQMG4He/+x02btyIoqIiu3N27NiBESNGIDk5GdHR0Vi8eHGbXqPJiBEjcO7cObt/7733Xpuf5+TJk9iwYQOio6Nt//r37w/A2m9fVlaGoqIiPPDAA21+7pYYYx59LS5duoTx48fbHcvMzIRer0dBQYHt2ODBg+3OUSqVGDRokMOxsrIyu2OjRo2yuz1mzBjcvn0bNTU1Hr0Pd/bv34/x48cjJSUF0dHRePLJJ2EwGKBSqTx+jpqaGhQXFzv9HNy4cQP19fW2Yy2vF6WmpqK0tLRD76Gzo3APARkZGeB5HpcuXWr13KlTp+LWrVvYunUrjh8/jnPnziEpKQkGg8F2Dsdxtl8YTYxGo+1jgUCAL7/8EocPH8bw4cPx2WefoU+fPvjiiy8AAH/7298wd+5cPProo/jnP/+Js2fPYvny5XbP4amIiAikp6fb/UtJSWnz81gsFixcuNDhF8W1a9cwZcoUu/feUX379vXoa+Hs9Zz9ohaJRA6PcXbMYrG4fa2WX1Oe591+nV05ceIEHnnkEYwfPx4HDhzAmTNnsH37dgCw+z7ylKvPQXNisdjhMa29X+IehXsIUCgUmDJlCrZs2YLq6mqH+41GI+rq6lBZWYm8vDwsWrQIkydPRv/+/SGVSh1afElJSbhz547tdkNDA/Ly8uzO4TgOv/zlL7FkyRIcPXoUmZmZeP/99wEAR48exX333Yfs7GwMHToUGRkZuHHjhvffeBsMGzYMly5dcvhFkZ6ejujoaCQlJaFr167417/+5fI5xGIxzGZzq681c+ZMHD58GMeOHXN6v0ajAQDce++9OHLkiN19R48eRUREBHr16tWGd+fc8ePH7W4fO3YMKSkpiI2NBeD4dQaAs2fP2t129p6///57JCQk4M0338SIESPQp08fFBcXOzwOgNvPV2xsLLp27er0c9CzZ09ERkZ68C5Je1G4h4ht27ZBJBJh6NCh+Oijj5CXl4fr169j7969GDZsGK5duwa5XI7ExETs2LED+fn5OHbsGB5//HFERETYPVdWVha2b9+OY8eO4eLFi5g1a5Zdiyw3NxerVq3CiRMncOvWLXzzzTf46aefbN0cffv2xYULF3Do0CEUFBRg48aN2L9/f7veV9Of+i3/OWvdufPGG2/g0KFDmD9/Ps6dO4eCggJ89dVXmD17NnQ6HQBgxYoVeO+997Bq1SpcvnwZly5dwpYtW1BRUQEA6NmzJ06fPo2CggJUVFS4bOXOmzcPkyZNwuTJk7FmzRqcOnUKN2/exFdffYVp06bhww8/BAAsXrwYn332GVavXo38/Hx8+umnWLlyJRYsWODQUm2Pc+fOYeXKlcjPz8dHH32EjRs3Yv78+bb7s7Ky8Mknn+Drr7/G1atXMX/+fIeuM2fvuW/fvigvL8euXbvw888/48MPP8S2bdscHgcAn3/+OcrLy6HVap3WuHjxYmzevBk7duzAtWvX8N577+Hdd9/FkiVLOvz+SSsC191P2qqsrIxlZ2ezjIwM2ySm8ePHsz179tiG13333Xds0KBBTCKRsD59+rC///3vrHfv3mzFihW25ykpKWFTp05lMTExrGvXrmzbtm12F9YuXrzIpkyZwpKTk5lYLGbdunVjL7/8su0ioMFgYM888wyTy+UsJiaGPf7442zz5s12F9g6MokJACsvL3f5PM4uqDLG2NGjR9mkSZNYdHQ0i4yMZP369WPz5s2zG3q4d+9eNmjQICYWi5lCoWC//vWvmUajYYwxVlBQwMaNG8eioqLcDoVkzDqJacOGDWzo0KEsMjKSxcTEsCFDhrC33nrL9nyMWYdC9uvXj4lEIpaSksKWLFniMBRy9uzZds/t7CLn5MmT2ZNPPmm73TQUctasWSwmJobJ5XL28ssv2w0frKmpYTNnzmRxcXEsMTGRrVixwuGCqqv3vGzZMpaUlMQiIyPZlClT2EcffeRwkX3evHksKSmJcRzndijk//7v/7IePXowoVDIevbs6XQoZGsXfknbcYzRTkyEhJoePXpgzpw5WLZsWaBLIUGKumUIISQMUbgTQkgYom4ZQggJQ9RyJ4SQMEThTgghYSholvxtOdmiLRISEmxjlYNZqNQJUK2+QrV6X6jUCXi/VnezuanlTgghYYjCnRBCwhCFOyGEhKGg6XNviTEGvV4Pi8XS6kp+paWlaGho8FNl7de8TsYYeJ6HVCr1ykqFhBDSXNCGu16vh0gkglDYeolCoRACgcAPVXVMyzpNJhP0er3Dwl6EENJRQRvuFovFo2APZUKhMCT+4iCEeJ9Ka8C+8xXQ1BshjxThycEJUEZ3fLXQJkGbnp2lq6KzvE9CyF0qrQErvimCStu0rLQO+RU6vD4pzWsBTxdUCSHEz/adr2gW7FYqrRH7zntvDDyFOyGE+Jmm3vlGMBpd27eqdIXCnRBC/EweKXJ+PML58fZoNdy3bduGOXPmYMGCBXbHv/zyS8ybNw/Z2dnYu3ev7fiBAwfw5z//GfPmzcO5c+e8VmggXLt2DSNHjrRt1GuxWPD444/jb3/7G3Q6Hf7jP/7Dtofkt99+i3HjxmHMmDHYsmULAOsWctOnT4fJZArYeyCEBB/rxVP7IFdGWy+qekur4T5hwgSH/Q4vXryIU6dOYc2aNVi3bh0eeughAEBxcTFyc3Oxbt06LF26FLt27QrpHcwzMjKQnp6OnJwcAMDq1avRu3dvPPLII/jkk08wZcoUCAQCmM1mLF26FHv37sW3336LgwcPIj8/H2KxGGPHjsXnn38e4HdCCAkmymgxnhmeDLGAQ2+5BON7xHr1YirgwWiZ/v37o6yszO7Y119/jYcffhgikfU3j0wmAwCcPHkSo0ePhkgkQlJSEpRKJa5fv44+ffp0qEjLxzvAigpd389xbd5QmUvrCf6x/2z1vP/8z//Ejh07YDQacfLkSXz66acAgP3792Pr1q0ArDvK9+jRA927dwcAPPzww/jXv/6FPn36YPLkyVi9ejWmT5/epvoIIeHt8M/VEHAcXp/UDTES78/TaVefe0lJCa5cuYIlS5ZgxYoVuH79OgBArVYjPj7edp5CoYBarfZOpQGSmZmJkpISvP3229i+fTtEIhEMBgNu3bqFtLQ0AIBKpbJbna1Lly5QqVQAgH79+oV89xQhxLuKaxrww81a/LpPnE+CHWjnOHeLxQKtVou33noLBQUFWL9+PbZs2dKm1nNOTo5dd0dCgn1fU2lp6d1JTDOfa0+ZXjN8+HAMHDgQqampAICKigrIZDJbfTzPg+M4222BQACe5yEUCiEUCiEWi6HX6xEdHe0wMUsikTi892AgFAqDsi5nqFbfCJVaQ6VO4G6t28/kQyzk8fSYdMgjvdcVY/da7XmQQqHAiBEjwHEc0tPTwfM8amtrER8fj8rKStt5arUaCoXC6XNkZWUhKyvLdrvlGscNDQ0eLykgFAp9etHy6tWreOSRR2yvIRQKodfrbbeTkpJw+/Zt2+3i4mIkJSXZbjd/Ly3rbGhoCMq1qDvzGtm+RLV6X6jUCVhrvVh4B/+6Uobf9JXDXF+Divr2P5/X13MfPnw4Ll68CMC6yYbJZEJMTAyGDRuG3NxcGI1GlJWVoaSkBOnp6e2rOojk5+ejX79+tttxcXEwm83Q6/UAgCFDhqCwsBC3bt2CwWDAoUOH8MADDwC421XVdH2CENK57c9Tg+c4/O4e5w1fb2m15b5hwwbk5eWhtrYWzz77LGbMmIGJEydi27ZtWLBgAYRCIebOnQuO45CWloZRo0YhOzsbPM9j9uzZ4PnQHkp/+/ZtxMbGIioqyu54ZmYmfvzxR4wfPx5CoRBvvvkmnnjiCVgsFjz66KPo27cvACA3NxcTJ04MROmEkCBTVtuAb36uwq96xyHexVh3b+FYW4eZ+EjLbfbq6+sRGRnp0WN93S3jzMWLF/Hee+9h8+bNbs+bM2cOFi1ahPT0dKd1tuV9+lOo/alLtXpfqNQaCnU2LRJ2uUKPCq0Bb/4qDQOSolp/YCtomz0fGDBgAMaMGWObxOSMwWDA5MmTw6JrihDSPk2LhB29UYNyrQEMwOZjKqi0Bp++LoV7Bzz22GNuL/qKxWI88sgjfqyIEBJs/LFImDMU7oQQ4kP+WCTMGQp3QgjxIX8sEuYMhTshhPjQlIw4h2PeXiTMmaDdiYkQQsLBt4XVEPLAL1KiYYIA0ULm9S31nKFwJ4QQHympNSCnoBpT+sjxzLBkvw7bpG4ZQgjxkY8vVEDIc/j9vfGtn+xlFO6EEOIDt6obcKSwBr/pI4ciwv+dJBTubrRlJ6bs7GwMGjTIbqkB2omJkM5FpTVg7Q93sOzfN/H64SKIBRym9/ftGjKuULi74elOTAAwY8YM7Nu3z+7xtBMTIZ1H85moF8p0qKg3QchzqDcFZje6kLiguvNUKQo1epf3c+3YiamnXIo5w5JbPc+TnZgAYOTIkSgqKnJ4PO3EREjn4Gwmap3Rgn3nK7BgjOs1YHyFWu6t8GQnJndoJyZCOodAzUR1JSRa7q21sH29KuTQoUMxYMAAJCdb61Cr1YiNjfXosQKBAGKxGFqtFnFxcT6rkRASWNaZqDrH4z6eieoKtdw9cO3aNdx7772221KpFA0NDR4/vqGhARKJxBelEUKCxJODExDbYj9Uf8xEdSUkWu6B5m4nJqlU6vaxtBMTIZ2DTGKN01iJAN1kIigixX6ZieoKtdxb0dpOTE2ef/55/Pa3v0VBQQGGDh2Kv/71rwBoJyZCOotDV9SoaTBjSWYq3vpVDywYkxKwYAeo5d6q1NRUHDt2zOH4008/jffeew/jx48HAGzbts3p4w8ePIhFixb5tEZCSGBpdCYcyKvEqLRo3JMYHDurUcu9nWgnJkJIkw/PlcNkYXhqSFKgS7GhlnsHPPbYY27vp52YCAl/+RU6HP65Gr+7R4GU2MB1w7RELXdCCGknC2PYcaoUcVIBZgz0/+Jg7gRtuLd1xmmo6izvk5BwdKSwBvmVejw1JBGRItf7KQdC0IY7z/Nhv+CWyWQCzwftl4AQ4ka90YwPzpUjI16K+3vJAl2Og6Dtc5dKpdDr9WhoaADHcW7PlUgkbZpUFCjN62SMgef5VsfJE0KC02eX1NDoTFg8PhV8KxkVCEEb7hzHISIiwqNz/bm7SUeESp2EEHsqrQH7zldAU2+EPFKEB9JlOHhZjft7xqJvgmc55W9BG+6EEBIMmpbyvbviow7Hi2oh4IA/DEkMaG3uUIcvIYS44WwpX4OZoatMjPjI4F1WhMKdEELccLWUb4Qw+PrZm6NwJ4QQN+QuWueKyOCZsOQMhTshhLhhXdnRPuADuZSvpyjcCSHEDWW0GCsmdkWMmIeQB0anxeD1SWkBXfHREzRahhBCWnGupB61BgsWjEnB+B6e7cIWaNRyJ4QQN8rrjPjwbDkGKyMxrntMoMvxGLXcCSGkhaZJS+o6A25rjbAwhrkjlK3Olg8mrYb7tm3bcObMGchkMqxdu9buvs8//xx79+7Fzp07bRtGHzhwAIcPHwbP83j66acxZMgQnxROCCG+4DhpCYgR8wi1Jf5a7ZaZMGEClixZ4nC8oqICFy5cQELC3SvGxcXFyM3Nxbp167B06VLs2rULFovFuxUTQogPOZu0VGuwYN/50Fo6pNVw79+/P6Kjox2Of/DBB3jyySft/kw5efIkRo8eDZFIhKSkJCiVSly/ft27FRNCiA+5mrSk0Tk/Hqza1ed+6tQpKBQK9OjRw+64Wq1GRkaG7bZCoYBarXb6HDk5OcjJyQEArF692u4vgLYSCoUdery/hEqdANXqK1Sr93m7TqW8EhfKdI7H46I7/Dr+/Jy2OdwbGhqwf/9+LFu2zOG+tmw8kZWVhaysLNvtjqyWGCqrLYZKnQDV6itUq/d5u84HekTgm3zA0izOlNEi/L5fTIdfx9u1pqSkuLyvzeFeWlqKsrIyvPLKKwCAyspKLFy4EG+//Tbi4+NRWVlpO1etVkOhULSjZEII8T/GGD69qAbPcbivSyQMZgvkEaLGWarBPWmppTaHe7du3bBz507b7blz5+Ltt99GbGwshg0bhk2bNmHq1KnQaDQoKSlBenq6VwsmhBBf+XdBNU7e1mLO0CQ81C+0G6athvuGDRuQl5eH2tpaPPvss5gxYwYmTpzo9Ny0tDSMGjUK2dnZ4Hkes2fPpm3kCCEhoaTWgF2nSzFIGYnf9JUHupwOazXcX3rpJbf3b9261e729OnTMX369A4VRQgh/mS2MKzPLYGA5zBvVJeg3DavrahZTQjp9D7Lq8TVCh2eHa5EQhBvwNEWFO6EkE7tWqUOH/9UgXHdY0JmUTBPULgTQjqtOoMZa76/A0WEEM8OVwa6HK+icCeEdEqMMWw9oUJZnRELxqYgWiIIdEleRatCEkI6jabVHjX1RujNDNcq9fjDkETckxgZ6NK8jsKdENIpOFvtUSzgMLqb49pZ4YC6ZQghnYKz1R4NZoa//lTp4hGhjcKdENIphMtqj56icCeEdApyF+PX5RHhMa69JQp3QkinMDLNsW9dGW1dFCwc0QVVQkjY0+hM2HmqDAmRQmTER0BrMIXsao+eonAnhIQ1k4Xhne9vQ2sw453J3dFDLg10SX5B3TKEkLD2wdkyXCrTYe4IZacJdoDCnRASxnIKqvD5FQ2m9pVjQk9ZoMvxK+qWIYSEHZXWgG0nVPhJVQ+5VIBf94kLdEl+Ry13QkhYUWkNWPrvWzivqgcDoNGb8ca3xVBpDYEuza8o3AkhYeWDs+WoqDfZHVNpjdh3Pvg3+/YmCndCSNgwWxguqOqc3heuM1FdoXAnhIQFxhh2nCpFrcHi9P5wnYnqCoU7ISQs7M9T48trVXggXQZltH2Qh/NMVFdotAwhJOR9V1iND8+VY3yPWDz3SyXK6qx97BqdMexnorpC4U4ICWmnblVh8/ESDEyOxIsjleA5DspoMRaMSQl0aQFF4U4ICVmFGj2W5hQhNVaCxeNTIRJQT3MT+kwQQkLS7RoDVhwuQrRYiOX3d0WUOLz2QO0oarkTQkJOeZ0Ry7+5BTBgw/QBiDQ7H/7YmVHLnRASUqp0Jiz/pgg6owUrJ6ahmzwi0CUFJQp3QkjI0DaYsfLbIlTWG/HahK7opeg8qzy2FYU7ISQk1BnMeP3bIhRVG7A4syvuSYoMdElBjcKdEBL06gxmrDxchAK1Hq+OTcF9XaICXVLQowuqhJCgVqjR47VvilDbYEb/pAh0l0sCXVJIoJY7ISRoFWr0eOWrm6htMAMA8sp0WPFNUadbvrc9KNwJIUFJazDjtW+KYLQwu+Odcfne9qBwJ4QEnSq9CctybkHb2GJvqbMt39seFO6EkKBSXmfEkn/fwu0aA+5Ndj4iprMt39serV5Q3bZtG86cOQOZTIa1a9cCAPbs2YPTp09DKBQiOTkZzz//PKKirFevDxw4gMOHD4PneTz99NMYMmSIT98AISR8lNQasPybW9AaLHh9YhoUkcLGPva7LfXOuHxve7Qa7hMmTMCDDz6IrVu32o4NGjQITzzxBAQCAfbu3YsDBw5g5syZKC4uRm5uLtatWweNRoNVq1Zh48aN4Hn6A4EQcpdKa8C+8xVQ1TSgqsGMOKkQ0RIBrlfqwQC8mdUNvRsnKL0+Ka3TL9/bHq2Ge//+/VFWVmZ3bPDgwbaP+/Tpg+PHjwMATp48idGjR0MkEiEpKQlKpRLXr19Hnz59vFw2ISSUNIW5pt4IjgMul+tgbLZhUlmddc9TngNem9DVFuwAaPnedurwOPfDhw9j9OjRAAC1Wo2MjAzbfQqFAmq12unjcnJykJOTAwBYvXo1EhLa/2eWUCjs0OP9JVTqBKhWX+mMtd6p1uGN727gdrW+1XMtDPjmZj0eGNTD4+fvjJ9Tj16rIw/ev38/BAIBxo0bB8C6h6GnsrKykJWVZbtdUdH+oU0JCQkdery/hEqdANXqK52x1s0/3PEo2JucuKHGxRt3PO566Yyf0yYpKa7/oml3Z/h3332H06dP48UXXwTHcQCA+Ph4VFZW2s5Rq9VQKBTtfQlCSBjQ1Ldt2KLRAhrH7gXtCvdz587h0KFDWLhwISSSu1OBhw0bhtzcXBiNRpSVlaGkpATp6eleK5YQEnqkorbHDI1j77hWu2U2bNiAvLw81NbW4tlnn8WMGTNw4MABmEwmrFq1CgCQkZGBZ555BmlpaRg1ahSys7PB8zxmz55NI2UI6eSa/rJvCxrH3nGthvtLL73kcGzixIkuz58+fTqmT5/eoaIIIaGr+cgYeaQIZbVtWweGxrF7B60KSQjxCpXWgF2ny3C6WIu7iwboPH68TCLA4C5RNI7dSyjcCSEdptIasOzft1Beb2rX45XRIrw+KY1C3Yso3AkhHbbrdFmbgj01WoDeCVE069SHKNwJIe3S1A1ztVyHGherN7piZBzNOvUxCndCSJt1tBtGLqXo8TUap0gIaROV1oDXctof7ACQHENdML5G4U4I8ZhKa8CKb4psC321Bw119A/624gQ0qqm/vWzd7R2qzl6SiHlkSqT0MVTP6JwJ4S4pdIasPjrm1Dr2nbRtElChABvPdCdAt3PKNwJIW7tOl3W7mBPihJiVVY3CvYAoD53QohLKq0BZ+9o2/345GgRBXuAULgTQpw6W6zBvP9X2K4+9ia0AFjgULcMIZ1Iy0W9XF3cVGkNeOWfN6A3ud+AJ0rEwWAGhDyDhXFoMN89n0bFBBaFOyGdRNMwRpW2aa10HfIrdE7XdNl3vgI6N012MQ8sn9gVA5Oj7Z6fNrIOHhTuhHQS+85XNAt2K5XWiFe/uok+CVJwHAedwQxZhBBXyupdPo+ri6S0kXVwoXAnJIw174a5Ve18XfXqBjNO3q7z6PmkQo5Gv4QICndCwpRjN0zbSARA8/XApEIOyyakUrCHCAp3QsKUs26YtpCKhBiRFkl96CGKwp2QMOBsFIymvmObTPMcqA89hFG4ExLiXI2CiRW3fWPq5u7tEtvx4kjAULgTEuK2nihxOgpG1YHnTIwUYt74noDRswutJPhQuBMSwi6UavGTyvNNqN2RCjl0l0mQHCPGk4MTkCKLQEUFhXuoonAnJEQ461ffdKwj7XNAIuDQPU4MZYyELpiGGQp3QoJQU5CrahpQ1WBGlIhHidbYbDkAa796jb79m2ZIhRw2/qYnBXqYonAnJMh4Oj5dpTVC3IGl/7rLJBTsYYzCnRA/a23xrraMTzd0YMVG2sc0vFG4E+IHTYFeqS9GQUWdQ/fKCyOT8fX1GrfLBHgTrdgY/ijcCfGx1rpZVFojluUU+6WWKBGHoakxdPG0E6BwJ8THOroMgDcNTY2hWaedBO3ERIiPFVXpA10CAOqK6Wyo5U6IjxXV+L4P3Z0YMY/7UqKpK6aToXAnxAeaLqDeUutg6sCIFk/1jZcie2yKQ9++MlrkdKclEv4o3AnxQGvDF22TjmoNqKg3olpnhtnN83lbcowYymgxXp+URlvdEQAU7oS0qrW9Ry+UavHmd7db3UzaW6RCzu61mvel01Z3pEmr4b5t2zacOXMGMpkMa9euBQBotVqsX78e5eXlSExMxPz58xEdbd0o98CBAzh8+DB4nsfTTz+NIUOG+PQNEOJLKq0Bi/91A2q9pcVxIxb8sxBiAQeN3gL/xLo1yG1j4ql1TtxoNdwnTJiABx98EFu3brUdO3jwIAYOHIhp06bh4MGDOHjwIGbOnIni4mLk5uZi3bp10Gg0WLVqFTZu3Aiep0E5JPRcKNXijcPFLmeBao0MMPou1hMiBHhpTBenQT4wOdpnr0vCQ6up279/f1urvMnJkyeRmZkJAMjMzMTJkydtx0ePHg2RSISkpCQolUpcv37dB2UT4lsqrQFvfne7Q9P7O0ImEeCtB7pjYHI0FoxJwZtZ3bFgTAq10InH2tXnXl1dDblcDgCQy+WoqakBAKjVamRkZNjOUygUUKvVTp8jJycHOTk5AIDVq1cjIaH942+FQmGHHu8voVInEL613qnW4f+O3cKdqnpU1psQHyVCiiwCDw9IwqGLZbhTrUNlnRH1BqPf+tCd+WUPBQb0CGzfeah8D4RKnYB/a/XqBVXGPP9hyMrKQlZWlu12RUVFu183ISGhQ4/3l1CpEwi/Wi+UarH+BxUqdfZL5KpqG3BJpcXh/HKYA5fldpTRIvy+X0zAP/+h8j0QKnUC3q81JcV1A6Bd4S6TyaDRaCCXy6HRaBAba91rMT4+HpWVlbbz1Go1FApFe16CkHZrOWxxWEoENh4rdRvegQx2RYQAvRVS6E0WukBKvKZd4T5s2DAcOXIE06ZNw5EjRzB8+HDb8U2bNmHq1KnQaDQoKSlBenq6VwsmxJnmm1vcqjHYrbp49EZNQGtzhyYZEV9pNdw3bNiAvLw81NbW4tlnn8WMGTMwbdo0rF+/HocPH0ZCQgKys7MBAGlpaRg1ahSys7PB8zxmz55NI2WIW61NDmpyoVSLdd/fQXWDBTwH3JMUgbkjukAZLcadap1Hm1v4Ew9gQHIEJEIeJ2877kMqkwgwuEsUtdI7OWYxA+DA+SAnOdaWjnIfunPnTrsfGyp9bqFSJ+CfWlVaA5b9+xbK6+/2gydGCjFvtNK2tnlTt8q63FKHxysiBHj7ge7Yc6EK3//s/MK9v0kEHF67P9U2VNHZcr+h0loPle/XYKuTmc1AbTVQowFqqsBqqoDGf5IGHfQVZbbbqK0Bv3QNuO7t6+Hwep87Id6w63SZXbADQHm9Ca/lFDebFKTD9zedd6uodWYs+foWahr8OdHfUYyYRw+5xGl/ecslAZRx0fh9v5igD3Zij5nNgLYGqG4KbM3dgK6uAqtt+lgD1NUCztrMYjEMcfFAVAwQnwSuZx8gJg6IjvVJzRTuxCdUWgO2Hi/B5XI9LIxBJhUge0wXJEaJbd0wVyp0Th/b8sfC4uZvy5ajXwLhvpRot1P+my8JEGytzM6MMQbUa62BXK2xtrCrNXdb3NVV1o+rNdZgdxrYEkAmB2LjgMQu4NLvsX4cGweu8X/bP0kEEhMT/fb1p3AnbeLJAlo7T5Xi9O06NJ//o9aZ8VpOMeIkPDQNAZoZ1AYCwOnCXzxg975ojfTgw4xGayhXqRtDWg00BjVrDHJraFcBZieNA6HIGsYyubWF3atvs8CWA7I4INYa6Jw0wq/vrS0o3InHWltAq7Xt5BgQEsE+PDUK1Xoz8isdN9nIiJciOUZM67r4GWMM0NU3trLVjSGtBqo1qNbXw1ymsrXAUa91fAKOs3Z/yBSALA5cl662jyFTNLayG4M7Igocx/n5HXofhTtxqWUrXWc0OwS3SmvEvvMVWDAmJai2k2uvxEgh5gxLxr7zFU7DPTmGVl30JmvXSJ21lV2tBqtS2wIcVc1DXA0YnGx6IhTBoEgAYmRAl67g+g60trhlcnAyeWOAy4EYGTiBwP9vMIAo3DuZ5oEtFfHgOA46g9mhi8VxeKEOrn40VLUNuFCqRa6LC5++JhXyyFCIAY6DPEKEB9JjseV4qd0vGp4DuseJkSaTYlhKBLb9WGa3vAAHYKDy7vDKJwcnIL9C5zDKhbpgPHO3pd0Y0lXqZgFeaQ3wpiA3OgltaQQQp7C2qnv2aQxsxd3QjmsM7Ygov/ZjhxIK907EfbeJDpfL6tFDLoHeaEG5zuJwnqsxKQXqBizLKfZ6vZ7SmyworzfbDS98fZLY7aYVfROj3N4f6I0vLOUq4NA+sCo1uDgF8PCT4BOVfnnt1jCjwRrMVY1B3RTcVZWNId54zNDg+ODmod27nzWwG4OaazwOmTyo+7JDBY1z96NA17n2hztBPVuzo8b3iA36LhNPvgcs5Sqw9cuBctXdg4lKcPPf8GnAM8YAbS2gqQCqKhFlaoC26FZjaFcCmsbQrqt1fLBIbA3pOAW4uHhbgNvf9k1oB/rnqi2Cfm0ZErwYY9CZLChQ6/H3S2po6o2QCHkMSI5EXlm9X2sRcMC23/YCgHbNIJVLeNSbGBqaLfwiEgAiDqh3MsihtDawG1F7zaF99sEOWG8f2gfMWdCup2Rms7ULRFNhbXFrKhrDutL6cZXaett092tUC1gvRMbGAXHxQEIyuIz+1tCWx4Nr/B9x8UBkeFyEDCcU7kGKMQa9iUFrMKPOYEatwQytwWL9uMH6T2uwoLbxdk3D3f9NTgaG51fq4asfPSEPp5tAx0cKm3WTWLs4SmsNuFHVYBfYLUWJOAxNjbH1b7fsGnkt5xbqTY7prtEHfsx7c866VuDBcq+syvlsW5fHTSZr37amAkzdGNqaCrDG/6Fp7ONmLb5ITa1teby1X/sX1qDm5AlAnAKK3hlQmxg4IcVEKKKvmg+YLQw6owU6kwX1Rgt0RgvqjWYINUBpZRXqG2/XGS2oN9h/XGc0o64xxN2tVCjggBiJANFiAWIlAiijRciIlyJWIsDZkjoUahz7O4elRqGo2uD1ES33JEiRV663q1fAAS+OutuF0HwiT9NY+HMl9TA6+UU0NDXGrnulZVdLnESAsjrHII+Temc0hDf6u1t2rTAA+PkqTG9sAYSO/fbNXxOlLroozSZYvj4AqJsFt7rCOma7Ze+qJAJQJFiDu0va3Y/lCXdb21ExblvbgoQEcCHS3UEcdcpwZ4zBZLH+ud9gssDQ+H/z23qTBXqTBQ0m6zG92QK90QJ9i9s6k/VcndFi+99ZYDkjFfKIEvOIEvGIFAkgkwqQEiO2HhMLECXmES0WINr2v/VYjESACCHv8gfzWsVNp8f1JovdRUJp43PojGZEiAT4uVKHCl3bpvIro0V4YVQKyusM2HRMhTqDGVFiAV4cpXS5FZwyWoxlE9JcrrvS2ogUZawE+WrHX17KGEmbanfGaSifyYW5/31A1sPgvv/as9B30bWifnU2mEBoHSHCcUD3dOAXo4FDe63T1925fhns+mVAIgXkCYAiAdyA+wB5ovVjebz1Y3k8uMiojn4qSIgL6XAv0xrx+VU1BKIq1NTpYDRbg9lgZnYfG8zW4DY2fmwwM7dT2l2RCDhIhTwkQh5SIYcIEQ+pkEecVIQIIY8IEW87FiHiESHkESm6ezwlMR6GuhpENp4j4H3TUSKPFAFwnNovjxDZtaBbsrWoVXUwNst4AWe/3rlUyKG7TILkGLFtBIkyWowd09q2+FF7R6Q4G6aYbKnD4z/uh+WypGMjS5yFstEInP8RuHC6cRW/uy1xi4uLnC67UGqr7Q9cOmP915qefcA/Ndca3tS/TTwQ0uGuNZhxuKAaYqEAQo5BJOAhEnAQN/6LEgsgF3AQCThIBDzEAg4SIW+7/+7H1rCWCHjbMWuIc41Bbj3Gd/AHKiEhChVOQtfb2jtGu3mL+u9XaqGq0trGjTvbpNkb3P2yaa55t0VSnAIrfvUY/locAXV1HRSFl/D45QNIbtDYhS6Au10dTaM0mhZ7ipWDS1KCDRwGHNhjnUgTGQVEuGnxWlr8VVOuAvt4B9j9vwGrLAMqywB1OVhlOXCroB2fDTfEEnBde3r3OUlYo6GQfuTPOm2TldoZyJ7W2t7+aUu5CuyTncDPV60HevUF9+gcp491OjRQIgX+MNcazJVlji8gEAICgfOx1r7C89bukvhEICoWuHwe0HtnhBI3IhN8O0fKtBf9XHkfDYUkHeZpi7gjXF00dNVV0cR85QKw6XX7mYnnfwS7dBbm7r0B1W2gQW9dcS+jP9DQ4NhV0qAHdq51XZzZ5HxRKF+QKYD/egV8r362Ke6WchXYO0u8E+6JSutIG0LagMKdtF87xmNbylXAllXOp5ybjEDBFfvb53/0YsE+Uq0Gd+QrcBn33j12aJ91NEt7RUYDaT2DbnYqCR0U7sQlW5dLWYldP3VT2Li8aHg6F+axD4CLT3Ts875+2drqDjMtPxeuPjc2AqG1j18gtE7Xb4EbONTv3TAkvFC4E6dMqjuO/dyVZWCFV21dL1ycwmFjDeuDjcDaZWAyuXVyTTjgBY4XVJvh4hQOt11ezGq2lICrpQaoG4Z0FIU7carur//n2OXSpFwFtnaZdVq6SOy8iwUs9IM9Psk65T5OATb2AesY93IVcPum/V8fzsL44SetF4ubfw5FIoiHjIDxd0/Zuln4RKV1ZE+QLhJGQheFO3HKrG6lv7hp6F+4crZQV7+BADwbIeQqtOX3DHAYLcEnKtu9ZgwhrlC4dxKeBFLzc5imPECVehHH2U/Ll0gBRSJQUuT8XJEYSOoCLrW729azp2FMoU0CicI9hLkK7JbH2dgHgB3v2Ka3MwA49QPML70OQWNr1HzlgnUUS2N3Q9BvhsfzwIO/B776zHVf+KDh4KQR9gt3HdoH5iTcuV+OpwuYJKxQuIcIp4H94WaHMebmp/7sePzEEccnNJuAtUth7tUP+N0f7II9aMTGWXedt7T4VdNvMLin5oJPVMJ8z2Dw72+ARd3iL41EpdNJURZnfeF0AZOEIZqh6kftrdPlDM1gC2NviZGB6z8EePhJ61T+3RvvLg8wa57tr40mCQkJKLt80eOLkoHc5ShUvleB0Kk1VOoEaIYqacZ85QKw+Q3HafThEuw8b98yb3khM1EJrN7Z+tO0oX+b+sJJZ0DhHsTMJ464n2IfDuav8nwZXUKIxyjcA8hug4amGZx6nbVPfeCw0Ah2XgD0GWDd5aeitG3DI+PirV0sLbpZCCEdR+EeIJZyFdjqhdZddFpweRE0mHAc0HcguKdesLW0LeUqsNdf9KzLiBcAs7N9XCQhnReFe4CwD7c4DfaQIBSBe2Or04k75hdecxx5IxQB3XoD6nLrcRcXRgkh3kPh7gOWcpU1vK9ftl4sjI2ztlLH3m/risGVnwJdZvvde5/LfnFBv4GwrNhE0+kJCTAK9w5wurs9APbWy0Bdzd0TqyqBtUtRo54H9sUnrtds8QdFIpDWE6itBm5ccxxD3hqJFNyjc9yeQqNRCAk8Cnc3XI2HNl+5AOxaZ7dUa9MkIsQn2Qd7M7r3N/qncFfi4sG9/JatFd1yVioAW/gL6utgvlVgf59ECrzwGrXCCQkBFO4uuNplyPzwk8BfNjif8l6uAspLfV8cx1tHp7SFItEu2AH3XShtnRhECAkuHQr3L774AocPHwbHcUhLS8Pzzz8Pg8GA9evXo7y8HImJiZg/fz6io6O9Va9P2Q1NdDasr1wF7N7kdl1vuF7F23t6ZgAxMiDvLGC8uwk2hCJAKgXq662jWSKjrJOCEpUug9ldFwp1rxASutod7mq1Gl9++SXWr18PsViMdevWITc3F8XFxRg4cCCmTZuGgwcP4uDBg5g5c6Y3a/YJp1P8nTEZ3d/vB1yiEvycBQGdRk8ICW4darlbLBYYDAYIBAIYDAbI5XIcOHAAK1euBABkZmZi5cqVAQ93lxc+P9lp7ScHXG53FnSaLXJFLWtCiCvtDneFQoGHHnoIzz33HMRiMQYPHozBgwejuroacrkcACCXy1FT4/ziYk5ODnJycgAAq1evRkJCQntLgVAodPl4k+oOqja+DnPpbQDWThO+4AosRmPI7BTESSMg6NYbQmUKoh5/BkKl68WCvMXd5zTYUK2+ESq1hkqdgH9rbXe4a7VanDx5Elu3bkVkZCTWrVuHo0ePevz4rKwsZGVl2W53ZKU0dyutWXZvBmsMdtuxCj9c9OwosQRI7Q4uqYt1dcREJYwAqgDADyvgdeaV9nyJavW+UKkTCJFVIS9cuICkpCTExsYCAEaMGIH8/HzIZDJoNBrI5XJoNBrb/YHS6i70/hYjA3r1tX5cUwVoKq1jzs2mu+c42+KNEELaoN3hnpCQgGvXrqGhoQFisRgXLlxA7969IZFIcOTIEUybNg1HjhzB8OHDvVlvm7ndhb5DT8xZl6uNllkDu7jQs8eldIPghWV2h+jCKCHE29od7hkZGRg5ciQWLlwIgUCAHj16ICsrC3q9HuvXr8fhw4eRkJCA7OzALg7Fxj4AnDvh3fXPW7SsLTvXgnkY7lycwuEYXRglhHhbh0bLzJgxAzNmzLA7JhKJsHz58g4V1R6uRsTgw83eC3aRCOh/n+P2bc62bpMnWFv3zbZ/EySnWrd5I4QQHwuLGaom1R2ns0kRn+SddVyEIuBeJ6HeiE9UwjL/Dee/XJodi5v1Z1QJxR2vhxBCWhEW4V731/9zDPFyVfuCvTHIAdg2zvCkD9xl10qzY8KEBL+MdCGEkJAO96auGP2F09570nkraZ1xQkjIC9lw93i5AGeiYwFti8lVkdHAc4sp2AkhYSFkwx2H9rkPdpHIflGt5nr3AyeNoKGHhJCwFbLhzspKXN8pElsvppbeBpiTUe56HfgWY80JISSchGy4Q+NmkS+jAVAVu7zb2VhzQggJJ3ygC2g3o6F9j2u2qiIhhISr0G25m91tmNFCjAxI6Ub964SQTiN0w70NLXeu/xDwNL2fENKJhG63TPNVFN2hbhhCSCcUui13d+KTAJnc7d6hhBASzsIy3AWrdwa6BEIICajQ7ZYhhBDiEoU7IYSEodANd5GkbccJIaQTCd1w7z+4bccJIaQTCdlw5x6dY93tqDl5gvU4IYR0ciE7WoZPVMLyyn8Dh/ZBWFcLU1QMDXskhJBGIRvuwN3djxQJCaigHY4IIcQmZLtlCCGEuEbhTgghYYjCnRBCwhCFOyGEhCEKd0IICUMcY842GSWEEBLKwqLlvmjRokCX4JFQqROgWn2FavW+UKkT8G+tYRHuhBBC7FG4E0JIGAqLcM/Kygp0CR4JlToBqtVXqFbvC5U6Af/WShdUCSEkDIVFy50QQog9CndCCAlDIb0q5Llz5/D+++/DYrFg0qRJmDZtWqBLstm2bRvOnDkDmUyGtWvXAgC0Wi3Wr1+P8vJyJCYmYv78+YiOjg5wpUBFRQW2bt2KqqoqcByHrKws/PrXvw66eg0GA1asWAGTyQSz2YyRI0dixowZQVdncxaLBYsWLYJCocCiRYuCtta5c+dCKpWC53kIBAKsXr06aGutq6vD9u3bUVRUBI7j8NxzzyElJSXoar1z5w7Wr19vu11WVoYZM2YgMzPTP7WyEGU2m9kLL7zAVCoVMxqN7OWXX2ZFRUWBLsvm0qVLrKCggGVnZ9uO7dmzhx04cIAxxtiBAwfYnj17AlSdPbVazQoKChhjjNXX17MXX3yRFRUVBV29FouF6XQ6xhhjRqORLV68mF29ejXo6mzuH//4B9uwYQN7++23GWPB+z3w/PPPs+rqartjwVrr5s2bWU5ODmPM+n2g1WqDttYmZrOZzZkzh5WVlfmt1pDtlrl+/TqUSiWSk5MhFAoxevRonDx5MtBl2fTv39/ht/HJkyeRmZkJAMjMzAyaeuVyOXr16gUAiIiIQGpqKtRqddDVy3EcpFIpAMBsNsNsNoPjuKCrs0llZSXOnDmDSZMm2Y4Fa63OBGOt9fX1uHz5MiZOnAgAEAqFiIqKCspam7tw4QKUSiUSExP9VmvIdsuo1WrEx8fbbsfHx+PatWsBrKh11dXVkMvlAKyBWlNTE+CKHJWVlaGwsBDp6elBWa/FYsHChQuhUqkwefJkZGRkBGWdALB7927MnDkTOp3OdixYawWAt956CwDwq1/9CllZWUFZa1lZGWJjY7Ft2zbcvHkTvXr1wqxZs4Ky1uZ++OEHjBkzBoD/vgdCNtyZkxGcHMcFoJLwodfrsXbtWsyaNQuRkZGBLscpnufxzjvvoK6uDmvWrMGtW7cCXZJTp0+fhkwmQ69evXDp0qVAl9OqVatWQaFQoLq6Gm+++SZSUlICXZJTZrMZhYWF+NOf/oSMjAy8//77OHjwYKDLcstkMuH06dN44okn/Pq6IRvu8fHxqKystN2urKy0/TYMVjKZDBqNBnK5HBqNBrGxsYEuycZkMmHt2rUYN24cRowYASC4642KikL//v1x7ty5oKzz6tWrOHXqFM6ePQuDwQCdTodNmzYFZa0AoFAoAFi/5sOHD8f169eDstb4+HjEx8cjIyMDADBy5EgcPHgwKGttcvbsWfTs2RNxcXEA/PdzFbJ97r1790ZJSQnKyspgMpmQm5uLYcOGBbost4YNG4YjR44AAI4cOYLhw4cHuCIrxhi2b9+O1NRUTJ061XY82OqtqalBXV0dAOvImQsXLiA1NTXo6gSAJ554Atu3b8fWrVvx0ksvYcCAAXjxxReDsla9Xm/rOtLr9fjpp5/QrVu3oKw1Li4O8fHxuHPnDgBrX3bXrl2DstYmzbtkAP/9XIX0DNUzZ87ggw8+gMViwf3334/p06cHuiSbDRs2IC8vD7W1tZDJZJgxYwaGDx+O9evXo6KiAgkJCcjOzg74cC0AuHLlCpYvX45u3brZurYef/xxZGRkBFW9N2/exNatW2GxWMAYw6hRo/D73/8etbW1QVVnS5cuXcI//vEPLFq0KChrLS0txZo1awBYuz3Gjh2L6dOnB2WtAHDjxg1s374dJpMJSUlJeP7558EYC8paGxoa8Nxzz2HLli22rk5/fV5DOtwJIYQ4F7LdMoQQQlyjcCeEkDBE4U4IIWGIwp0QQsIQhTshhIQhCndCCAlDFO6EEBKG/j9ZUFUFmfr05QAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "### True effects ###\n",
    "\n",
    "plt.title(\"Causal Effect Computation\")\n",
    "\n",
    "x_range = 72\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(0,x_range))) - (72 + 3*np.sqrt(np.arange(0,x_range)))).mean() )\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "406dd681",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82389231",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 146,
   "id": "d6a9ef77",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.preprocessing import MinMaxScaler\n",
    "from variationalRegressionTree import CVTree \n",
    "import torch \n",
    "\n",
    "DEVICE = 'cpu'\n",
    "MAX_TREE_DEPTH = 5\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(0,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(0,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": 147,
   "id": "3ca7ba51",
   "metadata": {},
   "outputs": [],
   "source": [
    "from bartpy.sklearnmodel import SklearnModel\n",
    "# train = False\n",
    "if not train:\n",
    "    model = SklearnModel(n_trees=30) # Use default parameters\n",
    "    model.fit(X_train.cpu().numpy(), y_train.cpu().numpy())\n",
    "    train = True "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "id": "dd03aa2d",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Iteration 800/800 : 100%|████████████████████████████████| 800/800 [00:19<00:00, 41.46it/s, ELBO=919, lr=0.01, τ=0.251]\n"
     ]
    }
   ],
   "source": [
    "elbos = [] \n",
    "rTree = variationalRegressionTree(MAX_TREE_DEPTH, X_train, y_train, device=DEVICE, bias = 1.0)\n",
    "elbo = rTree.train(epochs = 800, lr0 = LR0, lrf = LRF, clip_norm = CLIP_NORM ,optimizer='clippedAdam', h1 = 1, h2 = 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "id": "856e43d6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x22622bfa3d0>]"
      ]
     },
     "execution_count": 138,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(elbo)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "id": "4f03a7e6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([0.5863, 0.9905, 0.9928, 0.9953, 0.0796, 0.9960, 0.0120, 0.9961, 0.9857,\n",
      "        0.0279, 0.0468, 0.0083, 0.9927, 0.9932, 0.9622], device='cuda:0',\n",
      "       dtype=torch.float64)\n",
      "            _1_________  \n",
      "           /           \\ \n",
      "      _____2     ______3 \n",
      "     /      \\   /       \\\n",
      "   __4__    5   6___    7\n",
      "  /     \\      /    \\    \n",
      "  8_    9_    12   13_   \n",
      " /  \\  /  \\       /   \\  \n",
      "16 17 18 19      26  27  \n",
      "\n"
     ]
    }
   ],
   "source": [
    "from utils_reg import logistic, set_keys, create_tree\n",
    "from tqdm import tqdm \n",
    "\n",
    "hard_regression_trees = [] \n",
    "with torch.no_grad():\n",
    "    α = torch.round(logistic(rTree.γ) )\n",
    "    print(logistic(rTree.γ))\n",
    "    root = Node(depth = rTree.depth)\n",
    "    tree = create_tree(α, rTree.depth - 1, root)\n",
    "    set_keys(tree)\n",
    "    hard_regression_trees.append(tree)\n",
    "    tree.display()\n",
    "    print()\n",
    "\n",
    "        \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "id": "d71e82de",
   "metadata": {},
   "outputs": [],
   "source": [
    "#### SATT #####\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "id": "f0265b89",
   "metadata": {},
   "outputs": [],
   "source": [
    "# from tqdm import tqdm \n",
    "# predictions_1 = [] \n",
    "\n",
    "# for x1 in tqdm(X_1):\n",
    "#     sample = x1.view(-1).to(DEVICE)\n",
    "\n",
    "#     yhat = np.array(rTree.predictive_posterior(sample, samples = 100)).mean().item()\n",
    "        \n",
    "#     predictions_1.append(yhat)\n",
    "    \n",
    "# predictions_0 = [] \n",
    "\n",
    "# for x0 in tqdm(X_0):\n",
    "#     sample = x0.view(-1).to(DEVICE)\n",
    "#     yhat = 0.0\n",
    "\n",
    "#     yhat = np.array(rTree.predictive_posterior(sample, samples = 100)).mean().item()\n",
    "        \n",
    "#     predictions_0.append(yhat)\n",
    "\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.numpy())\n",
    "# predictions_1_BART = model.predict(X_1.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",
    "# (predictions_1 - predictions_0).mean(), (predictions_1_BART - predictions_0_BART).mean()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "id": "ff76499c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# ### True effects ###\n",
    "\n",
    "# plt.title(\"Causal Effect Computation\")\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",
    "\n",
    "# plt.plot(np.arange(0,x_range), predictions_0, label=\"Y(0) pred vTree\", linestyle='--')\n",
    "# plt.plot(np.arange(0,x_range), predictions_1, label=\"Y(1) pred vTree\", 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",
    "\n",
    "\n",
    "# (72 + 3*np.sqrt(np.arange(0,x_range)) - (90 + np.exp(0.06*np.arange(0,x_range)))).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 143,
   "id": "85b543b2",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\sebas\\AppData\\Local\\Temp\\ipykernel_5320\\2473371330.py:2: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predictions_1 = rTree.sample_posterior_predictive_vectorized(torch.tensor(X_1).to(DEVICE), samples=100)\n",
      "100%|█████████████████████████████████████████████████████████████████████████████████| 72/72 [00:00<00:00, 283.14it/s]\n",
      "C:\\Users\\sebas\\AppData\\Local\\Temp\\ipykernel_5320\\2473371330.py:3: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predictions_0 = rTree.sample_posterior_predictive_vectorized(torch.tensor(X_0).to(DEVICE), samples=100)\n",
      "100%|█████████████████████████████████████████████████████████████████████████████████| 72/72 [00:00<00:00, 319.39it/s]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "-17.87791772821296"
      ]
     },
     "execution_count": 143,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXcAAAEJCAYAAABv6GdPAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy89olMNAAAACXBIWXMAAAsTAAALEwEAmpwYAABwf0lEQVR4nO2dd5xU1fn/3/dOLzuzs72yS+9FAREQUFxEIgnYSCxJzFe/aSZRMYk11piYX1SwEY2aGEu+xkQFjRoNQSGKIkWQXpa2C9v7Tp+55/fHsMMOO1vZhd3lvF+vhbnnnnvvc6d85sxznvM8ihBCIJFIJJJ+hXq6DZBIJBJJ9yPFXSKRSPohUtwlEomkHyLFXSKRSPohUtwlEomkHyLFXSKRSPohUtwlPcKLL76IXq/vlnPdeeedpKenoygKL774IgBPPvkkOTk5qKrKfffd1y3XkZw81113HQUFBafbDAmAkPQZKisrxS9+8QsxbNgwYTKZRGpqqpgxY4b4y1/+IoLB4Ok2L4Y///nPQqfTtdnnu9/9rgBa/Nlstmifzz//XABi+fLloqSkRHg8HnHkyBGhqqp46qmnxNGjR0VDQ0O32HzhhReK7373ux3qGwwGxRNPPCEmT54s7Ha7cDgcYsKECeLXv/61qK6u7hZ7TgWduefmvPzyyyKefNTW1vap++/PdM/QStLjFBcXM336dPR6PQ888ABnnXUWBoOBtWvX8sgjjzBu3DgmTJhwus3sNDNmzOD111+PaVPV4z8o9+7di6qqLFiwINq2ceNGNE3jG9/4BpmZmafM1iaCwSDz58/ns88+45577mHWrFmkpqayY8cO/vCHP2Cz2bj55ptPuV29AafTebpNkDRxur9dJB1j/vz5Ij09XdTW1rbYFwgERGNjoxBCiA8//FDMmjVLuFwu4XA4xMyZM8W6deti+gPi5Zdfjmk7cQS3fPlyMWHCBGGxWITT6RSTJ08WmzZtEkIIoWmauOGGG8SgQYOE2WwWAwcOFHfccYfw+XzR4zs6cr/wwgvb3M8Jo/p77723RduBAwei9z5t2jRhNptFVlaWuO6660RlZWXMOV977TVx9tlnC5PJJJKSksTFF18sqqur417ro48+imvXI488IhRFEWvXro27v/nI9cUXXxQjR44URqNRZGdni7vuuivmV9asWbPE//zP/4i77rpLpKamCqfTKe68804RDofF/fffL9LS0kRKSoq48847Y66Rl5cn7rzzTnH99deLhIQEkZycLH75y1+KcDgc0+fBBx+MOe76668Xs2bNavX5bbrnO++8U4wYMUJYLBaRk5MjfvCDH0Tfex999FGL45reOye+ppqmid///vdi4MCBwmAwiEGDBoklS5a0uJdf/epX4mc/+5lwuVwiLS1N3HrrrSIUCsV9fiUdQ4p7H6CqqkqoqtrigxqPN998U7z++uti9+7dYtu2beL6668XLpcrRuTaE/eSkhJhMBjE7373O7F//36xY8cO8eqrr4qvvvpKCCFEOBwWd911l/j888/FgQMHxIoVK0RGRoa45557oufrDnGvra0VS5cuFTqdTpSUlIiSkhLR0NAg3njjDQGITZs2iZKSEhEKhcR//vMfYbFYxBNPPCH27NkjvvjiC3H++eeLGTNmCE3ThBBC/OlPfxJ6vV488MADYvv27WLLli1i6dKloqKiQtTW1ooZM2aIRYsWRa/l9/vj2jV+/Pg27W7in//8p1BVVfzmN78Ru3fvFq+99ppITEwUd999d7TPrFmzhMPhEL/85S/F7t27xQsvvCAAMW/ePPGLX/xC7N69W7z44osCEO+99170uLy8PJGQkCB+9atfiV27domXXnpJWK1W8eijj8b0aUvc27rnBx98UKxZs0YcOHBArFy5UgwfPlx85zvfEUII4ff7xVNPPSWA6HFNwn/ia/rUU08Js9ksnn32WbFnzx7xhz/8QZhMJvH888/H2JmYmCh++9vfij179ojXXntN6HQ68ac//and51jSOlLc+wDr1q0TgHjjjTc6fWw4HBaJiYnilVdeiba1J+6bNm2KGRF3hMcee0wMGTIkut1RcdfpdMJms8X8zZ8/v83zNI0ci4qKom2zZs0St912W0y/Q4cOCUB8+eWXQgghcnNzxY033tiqPR31P1ssFvHTn/603X7nnXeeuPLKK2Pali5dKsxmc1REZ82aJcaPHx/TZ9SoUWLMmDExbePGjRO33nprdDsvL0+cd955MX3uuOMOkZ2dHdOnLXEXouP3/Oabbwqj0Rj9ZdCaz/1Ecc/JyRG/+MUvYvrcfPPNYuDAgTF2fv3rX4/pM3fuXPGtb32rXbskrSOjZfoA4lhuN0VR2u174MABvv3tbzNkyBAcDgcOh4O6ujoOHTrU4euN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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from tqdm import tqdm \n",
    "predictions_1 = rTree.sample_posterior_predictive_vectorized(torch.tensor(X_1).to(DEVICE), samples=100)\n",
    "predictions_0 = rTree.sample_posterior_predictive_vectorized(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",
    "(predictions_1 - predictions_0).mean(), (predictions_1_BART - predictions_0_BART).mean()\n",
    "\n",
    "### True effects ###\n",
    "\n",
    "plt.title(\"Causal Effect Computation\")\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",
    "\n",
    "plt.plot(np.arange(0,x_range), predictions_0, label=\"Y(0) pred vTree\", linestyle='--')\n",
    "plt.plot(np.arange(0,x_range), predictions_1, label=\"Y(1) pred vTree\", 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",
    "\n",
    "\n",
    "(72 + 3*np.sqrt(np.arange(0,x_range)) - (90 + np.exp(0.06*np.arange(0,x_range)))).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "id": "240ff2eb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-17.87791772821296"
      ]
     },
     "execution_count": 114,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(72 + 3*np.sqrt(np.arange(0,x_range)) - (90 + np.exp(0.06*np.arange(0,x_range)))).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "id": "3c6805cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(8.850948, 9.58453680959834)"
      ]
     },
     "execution_count": 101,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(predictions_1 - predictions_0).mean(), (predictions_1_BART - predictions_0_BART).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9255ea94",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8af1db09",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1eb4be03",
   "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
}
