{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "671156ae-3e66-4997-85ba-b18bdfaec591",
   "metadata": {},
   "source": [
    "# Example Pipeline for Lalonde\n",
    "\n",
    "This notebook is a proof-of-concept for generating causal samples from external samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "94fec690-e143-4b90-a218-f6652bdb2a19",
   "metadata": {},
   "outputs": [],
   "source": [
    "import contextlib\n",
    "import sys\n",
    "import os\n",
    "sys.path.append(\"../\")  # go to parent dir\n",
    "# sys.path.append(\"../data/analysis/\")  # go to parent dir\n",
    "\n",
    "import jax\n",
    "import jax.random as jr\n",
    "import jax.numpy as jnp\n",
    "# jnp.set_printoptions(precision=2)\n",
    "jax.config.update(\"jax_enable_x64\", True)\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from scipy.stats import rankdata\n",
    "\n",
    "import rpy2.robjects as ro\n",
    "from rpy2.robjects.packages import importr\n",
    "from rpy2.robjects import pandas2ri\n",
    "from rpy2.robjects.vectors import StrVector\n",
    "from rpy2.robjects.packages import SignatureTranslatedAnonymousPackage\n",
    "\n",
    "from frugal_flows.causal_flows import independent_continuous_marginal_flow, get_independent_quantiles, train_frugal_flow\n",
    "from frugal_flows.sample_outcome import sample_outcome\n",
    "from frugal_flows.sample_marginals import from_quantiles_to_marginal_cont, from_quantiles_to_marginal_discr\n",
    "from frugal_flows.train_quantile_propensity_score import train_quantile_propensity_score\n",
    "from frugal_flows.bijections import UnivariateNormalCDF\n",
    "from frugal_flows.benchmarking import FrugalFlowModel\n",
    "from frugal_flows.sample_outcome import sample_outcome\n",
    "from frugal_flows.sample_marginals import from_quantiles_to_marginal_cont, from_quantiles_to_marginal_discr\n",
    "from frugal_flows.train_quantile_propensity_score import train_quantile_propensity_score\n",
    "\n",
    "\n",
    "import data.template_causl_simulations as causl_py\n",
    "import data.analysis.validationMethods as valMethods\n",
    "import wandb\n",
    "\n",
    "# Activate automatic conversion of rpy2 objects to pandas objects\n",
    "pandas2ri.activate()\n",
    "base = importr('base')\n",
    "utils = importr('utils')\n",
    "\n",
    "# Import the R library causl\n",
    "try:\n",
    "    causl = importr('causl')\n",
    "except Exception as e:\n",
    "    package_names = ('causl')\n",
    "    utils.install_packages(StrVector(package_names))\n",
    "\n",
    "seed = 0\n",
    "N = 2000\n",
    "B = 50\n",
    "sampling_size = 1000\n",
    "keys, *subkeys = jr.split(jr.PRNGKey(seed), 20)\n",
    "\n",
    "def clean_ate(value):\n",
    "    if isinstance(value, (list, tuple, np.ndarray)):\n",
    "        return np.mean(value)\n",
    "    return value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a96658fe-6620-4cfa-8de7-c1e6bdff8930",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  1%|   | 279/20000 [00:50<59:51,  5.49it/s, train=-0.8595963758529483, val=0.8211046335156056 (Max patience reached)]\n",
      "  1%|  | 223/20000 [00:14<21:50, 15.09it/s, train=-0.6331032134635899, val=-0.5172580268328977 (Max patience reached)]\n"
     ]
    }
   ],
   "source": [
    "hyperparam_dict = {\n",
    "    'learning_rate': 0.006335,\n",
    "    'RQS_knots': 4,\n",
    "    'flow_layers': 9,\n",
    "    'nn_depth': 10,    \n",
    "    'nn_width': 50,\n",
    "    'max_patience': 200,\n",
    "    'max_epochs': 20000\n",
    "}\n",
    "causal_margin_hyperparams_dict = {\n",
    "    'RQS_knots': 4,\n",
    "    'flow_layers': 8,\n",
    "    'nn_depth': 10,    \n",
    "    'nn_width': 50,\n",
    "}\n",
    "seed=1\n",
    "\n",
    "lalonde = pd.read_csv('../data/filtered_lalonde_dataset.csv')\n",
    "lalonde = lalonde\n",
    "\n",
    "outcome_col = 're78'\n",
    "treatment_col = 'treatment'\n",
    "standardised_outcome_col = f'{outcome_col}_standardised'\n",
    "Y_control = lalonde.loc[lalonde[treatment_col]==0, outcome_col]\n",
    "Y_control_mean = Y_control.mean()\n",
    "Y_control_std = Y_control.std()\n",
    "lalonde[standardised_outcome_col] = (lalonde[outcome_col] - Y_control_mean) / Y_control_std\n",
    "\n",
    "X = jnp.array(lalonde[treatment_col].values)[:, None]\n",
    "Y = jnp.array(lalonde[standardised_outcome_col].values)[:, None]\n",
    "\n",
    "covariate_colnames = ['treatment', 'age', 'education', 'black', 'hispanic', 'married', 'nodegree']\n",
    "Z_disc = jnp.array(lalonde[covariate_colnames].values)\n",
    "\n",
    "true_ATE = 1000\n",
    "benchmark_flow = FrugalFlowModel(Y=Y, X=X, Z_disc=Z_disc, Z_cont=None, confounding_copula=None)\n",
    "benchmark_flow.train_benchmark_model(\n",
    "    training_seed=jr.PRNGKey(seed),\n",
    "    marginal_hyperparam_dict=hyperparam_dict,\n",
    "    frugal_hyperparam_dict=hyperparam_dict,\n",
    "    causal_model='location_translation',\n",
    "    causal_model_args={'ate': 0, **causal_margin_hyperparams_dict},\n",
    "    prop_flow_hyperparam_dict=hyperparam_dict\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "91f27b4b-2005-4491-8d50-1529727b4f2f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def rescale_outcome(x, mean, std):\n",
    "    return x * std + mean"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4c3fe7f3-e6b2-4942-8912-807a4ad07966",
   "metadata": {},
   "source": [
    "### Unconfounded Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "198d01ae-2246-4f76-9d0b-80bed287bd91",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 9 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 10 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 11 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 12 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 13 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 14 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 15 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 16 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 17 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 18 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 19 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 20 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 21 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 22 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 23 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 24 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 25 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 26 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 27 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 28 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 29 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 30 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 31 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 32 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 33 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 34 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 35 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 36 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 37 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 38 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 39 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 40 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 41 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 42 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 43 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 44 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 45 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 46 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 47 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 48 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 49 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 50 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    }
   ],
   "source": [
    "non_confounded_results_list = []\n",
    "for seed in range(B):\n",
    "    print(f\"Run {seed+1} / {B}\")\n",
    "    sim_data_df = benchmark_flow.generate_samples(\n",
    "        key=jr.PRNGKey(10*seed),\n",
    "        sampling_size=sampling_size,\n",
    "        copula_param=0.,\n",
    "        outcome_causal_model='location_translation',\n",
    "        outcome_causal_args={'ate': true_ATE / Y_control_std},\n",
    "        with_confounding=False\n",
    "    )\n",
    "    sim_data_df['Y'] = sim_data_df['Y'].apply(lambda x: rescale_outcome(x, Y_control_mean, Y_control_std))\n",
    "    with open(os.devnull, \"w\") as f, contextlib.redirect_stdout(f):\n",
    "        model_fits = valMethods.run_model_fits('Y', 'X', sim_data_df, sample_frac=1, repeats=1, replace=True)\n",
    "    ate_reslts = pd.concat([\n",
    "        model_fits['nonbootstrap_results'][['method', 'ate']], \n",
    "        model_fits['bootstrap_results'][['method', 'ate']]\n",
    "    ])\n",
    "    non_confounded_results_list.append(ate_reslts)\n",
    "non_confounded_model_fit_results = pd.concat(non_confounded_results_list)\n",
    "non_confounded_model_fit_results = non_confounded_model_fit_results.loc[\n",
    "    ~non_confounded_model_fit_results['method'].isin(['Gradient Boosting Trees DML', 'Doubly Robust (Linear)'])\n",
    "]\n",
    "non_confounded_model_fit_results['ate'] = non_confounded_model_fit_results['ate'].apply(clean_ate)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "072ec25c-b320-44a7-9e4b-e637d2d6417f",
   "metadata": {},
   "source": [
    "### Confounded Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6d5ee374-828a-4e74-9978-5e5292b30572",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 9 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 10 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 11 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 12 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 13 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 14 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 15 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 16 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 17 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 18 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 19 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 20 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 21 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 22 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 23 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 24 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 25 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 26 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 27 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 28 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 29 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 30 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 31 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 32 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 33 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 34 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 35 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 36 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 37 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 38 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 39 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 40 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 41 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 42 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 43 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 44 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 45 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 46 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 47 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "lbfgs failed to converge (status=1):\n",
      "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT.\n",
      "\n",
      "Increase the number of iterations (max_iter) or scale the data as shown in:\n",
      "    https://scikit-learn.org/stable/modules/preprocessing.html\n",
      "Please also refer to the documentation for alternative solver options:\n",
      "    https://scikit-learn.org/stable/modules/linear_model.html#logistic-regression\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 48 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 49 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 50 / 50\n",
      "(1000, 7)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Since both frugal flow object and u_yx are provided to location_translation model, u_yx quantiles will be used to sample from the flow object. If you want to fully sample from the flow object, please provide only the frugal flow object.\n",
      "It looks like 'X' is not included in the outcome model.\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "                                                                                                                      \r"
     ]
    }
   ],
   "source": [
    "confounded_results_list = []\n",
    "for seed in range(B):\n",
    "    print(f\"Run {seed+1} / {B}\")\n",
    "    sim_data_df = benchmark_flow.generate_samples(\n",
    "        key=jr.PRNGKey(10*seed),\n",
    "        sampling_size=sampling_size,\n",
    "        copula_param=0.,\n",
    "        outcome_causal_model='location_translation',\n",
    "        outcome_causal_args={'ate': true_ATE / Y_control_std},\n",
    "        with_confounding=True\n",
    "    )\n",
    "    sim_data_df['Y'] = sim_data_df['Y'].apply(lambda x: rescale_outcome(x, Y_control_mean, Y_control_std))    \n",
    "    with open(os.devnull, \"w\") as f, contextlib.redirect_stdout(f):\n",
    "        model_fits = valMethods.run_model_fits('Y', 'X', sim_data_df, sample_frac=1, repeats=1, replace=True)\n",
    "    ate_reslts = pd.concat([\n",
    "        model_fits['nonbootstrap_results'][['method', 'ate']], \n",
    "        model_fits['bootstrap_results'][['method', 'ate']]\n",
    "    ])\n",
    "    confounded_results_list.append(ate_reslts)\n",
    "confounded_model_fit_results = pd.concat(confounded_results_list)\n",
    "confounded_model_fit_results = confounded_model_fit_results.loc[\n",
    "    ~confounded_model_fit_results['method'].isin(['Gradient Boosting Trees DML', 'Doubly Robust (Linear)'])\n",
    "]\n",
    "confounded_model_fit_results['ate'] = confounded_model_fit_results['ate'].apply(clean_ate)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2a152104-1a86-40cc-a277-97c09b3e553f",
   "metadata": {},
   "source": [
    "### Hidden Confounded Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1be9f569-3936-449d-bbb0-84b87fde60d8",
   "metadata": {},
   "outputs": [],
   "source": [
    "hidden_confounded_results_list = []\n",
    "for seed in range(B):\n",
    "    print(f\"Run {seed+1} / {B}\")\n",
    "    sim_data_df = benchmark_flow.generate_samples(\n",
    "        key=jr.PRNGKey(10*seed),\n",
    "        sampling_size=sampling_size,\n",
    "        copula_param=0.5,\n",
    "        outcome_causal_model='location_translation',\n",
    "        outcome_causal_args={'ate': true_ATE / Y_control_std},\n",
    "        with_confounding=True\n",
    "    )\n",
    "    sim_data_df['Y'] = sim_data_df['Y'].apply(lambda x: rescale_outcome(x, Y_control_mean, Y_control_std))    \n",
    "    with open(os.devnull, \"w\") as f, contextlib.redirect_stdout(f):\n",
    "        model_fits = valMethods.run_model_fits('Y', 'X', sim_data_df, sample_frac=1, repeats=1, replace=True)\n",
    "    ate_reslts = pd.concat([\n",
    "        model_fits['nonbootstrap_results'][['method', 'ate']], \n",
    "        model_fits['bootstrap_results'][['method', 'ate']]\n",
    "    ])\n",
    "    hidden_confounded_results_list.append(ate_reslts)\n",
    "hidden_confounded_model_fit_results = pd.concat(hidden_confounded_results_list)\n",
    "hidden_confounded_model_fit_results = hidden_confounded_model_fit_results.loc[\n",
    "    ~hidden_confounded_model_fit_results['method'].isin(['Gradient Boosting Trees DML', 'Doubly Robust (Linear)'])\n",
    "]\n",
    "hidden_confounded_model_fit_results['ate'] = hidden_confounded_model_fit_results['ate'].apply(clean_ate)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "75ea816a-a7cf-4596-82f0-8ad1dccfa232",
   "metadata": {},
   "source": [
    "## Some demo plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a595b056-8e33-4c42-9126-9fb807b861b1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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r9eazbPPPou5c+diw4YNQX/PnMRGQUEBbrrppoCTTuXG+74PU2BO4k+0X9N79NFHcerUKTQ2Ngb9vW/eWD+Mx1hpg/WeosHc+WN70p8IcUu0GLPejk48XN9pHVeurCUykVWrVg27smnp0qUxLI05RBJzvV5rJq+//jpuvvnmgIH89ddfV39mTmLj4MGDQeOhnMT43rOWOTGfgwcPBn1irlI/fJ/wy/phPMZKG6z3FA3mzh/bk/5EiFuixZj1NnLxcn2neVxlIjKNDz/8UAYgt7e3h7WdRnby5EkZgPzOO+8E/X0kMdfrtWbx4Ycfyi+99FLQ3/luZ05io6ioKOgxb9iwIaDNMCfms2HDhqDbX3rppZjlnPUjfIyVNljvKRrMnT+2p+jFw3VMvMV4pJiy3kYmnq7vtI4rJ2uJTGblypUBg0RRUVHIAYWG19jYKAOQt2zZEvI1kcRcr9cmupMnT8ozZsyQn3rqKXnDhg3yhg0b5Keeekp+6qmngsaEOdHfyZMn5ZUrV/qdmCgnsE899VTA65kTc2lvbw+oB42NjXJ6enpMc876ET7GKnqs9xQt5u4Gtqfoxct1TDzFeKSYst6GLx6v77SMqyTLshzZWlwiincvv/wyLl++jJtvvhknT57E0qVL/Z6oSCN79tlncerUKfWr3unp6SgqKsJNN92ELVu2BLw+kpjr9dpENtLDixobG/2+dg8wJ7HQ0dGBZ599Funp6ejo6MCpU6fwwx/+MOZxZk7E5Fs/lPb705/+NKCtKlg/jMdYRY/1nqLF3N3A9jQ68XgdI3qMI4kp62144vX6Tqu4crKWiIiIiIiIiIiISAB8wBgRERERERERERGRADhZS0RERERERERERCQATtYSERERERERERERCYCTtUREREREREREREQC4GQtERERERERERERkQA4WUtEREREREREREQkAE7WEhEREREREREREQmAk7VEREREREREREREAuBkLREREREREREREZEAbEYXgIiIxCJJEgDgww8/RFFRkbr94MGDePTRRyPe38mTJwP2PZyVK1finXfeifh9iIhIHxwXiIhIwTGBSH+crCUiItX27dvVn9955x2/E7AZM2Zg5cqV6v/ffPPNAIDf//73OHjwIFauXIm5c+cCAC5fvuz3Gl/p6el46aWXQpZhxowZ0R0EERFphuMCEREpOCYQxYYky7JsdCGIiEgMS5cuRXp6Ok6dOoVTp06hvb19xL/54Q9/iNdffz3g0/VgJEnCjBkz/D5BJyIicXFcICIiBccEotjgPWuJiAgA0NHRgdraWjz22GN47LHH1P8nIiJz4rhAREQKjglEscPJWiIiAgD84Q9/AAAUFRWpX2HasmWLkUUiIiIDcVwgIiIFxwSi2OE9a4mICMDgyVZRURHS09ORnp6OGTNm+N2XioiIzIXjAhERKTgmEMUOV9YSERE6OjoCnuCqfGLOkzAiIvPhuEBERAqOCUSxxclaIiLC66+/DgBYtWqVuu2xxx4DoP3Xm06dOgVJkkL+IyIi43FcICIiBccEotjibRCIiAi///3vkZ+fj/T0dHWb8v+1tbXo6Ojw+1000tPTUVlZqcm+iIhIHxwXiIhIwTGBKLY4WUtEZHKnTp3CwYMH8dJLLwX8btWqVXj99dfxhz/8AU899ZQm73fTTTepX5siIiLxcFwgIiIFxwSi2ONtEIiITE65z9Szzz4b8DUj5StP77zzjpFFJCKiGOK4QERECo4JRLHHlbVERCa3ZcsW5Ofnh/y60aOPPqr515uIiEhcHBeIiEjBMYEo9jhZS0RkYgcPHsSpU6fUk7BgVq5ciZdfflnTrzcREZGYOC4QEZGCYwKRMXgbBCIiE/v9738PwP/JrkP98Ic/BKD9k16JiEg8HBeIiEjBMYHIGFxZS0RkYq+//jqKioqG/crSjBkzMGPGDPWT9RkzZkT1nleuXMHLL7887Gs2bNgQ1XsQEdHocFwgIiIFxwQiY3CylojIpA4ePIiOjg48+uijI772hz/8IZ599lls37496pOjjo4OPPvssyF/n56ezhMwIiIDcFwgIiIFxwQi40iyLMtGF4KIiIiIiIiIiIjI7HjPWiIiIiIiIiIiIiIBcLKWiIiIiIiIiIiISACcrCUiIiIiIiIiIiISACdriYiIiIiIiIiIiATAyVoiIiIiIiIiIiIiAXCyloiIiIiIiIiIiEgAnKwlIiIiIiIiIiIiEgAna4mIiIiIiIiIiIgEwMlaIiIiIiIiIiIiIgFwspaIiIiIiIiIiIhIAJysJSIiIiIiIiIiIhIAJ2uJiIiIiIiIiIiIBMDJWiIiIiIiIiIiIiIB/P8BLCxoZoxkbuQAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1400x600 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "plt.rcParams['text.usetex'] = True\n",
    "\n",
    "def clean_ate(value):\n",
    "    if isinstance(value, (list, tuple, np.ndarray)):\n",
    "        return np.mean(value)\n",
    "    return value\n",
    "\n",
    "# Apply the cleaning function to the data\n",
    "df1 = non_confounded_model_fit_results.copy()\n",
    "df2 = confounded_model_fit_results.copy()\n",
    "df3 = hidden_confounded_model_fit_results.copy()\n",
    "\n",
    "# Group data by method\n",
    "grouped_df1 = df1.groupby('method')['ate'].apply(list).reset_index()\n",
    "grouped_df2 = df2.groupby('method')['ate'].apply(list).reset_index()\n",
    "grouped_df3 = df3.groupby('method')['ate'].apply(list).reset_index()\n",
    "\n",
    "# Plot the box and whisker diagrams side by side\n",
    "fig, axes = plt.subplots(nrows=1, ncols=3, figsize=(14, 6), sharey=True)\n",
    "\n",
    "# Define a common font size\n",
    "font_size = 16\n",
    "title_fontsize = font_size + 2\n",
    "\n",
    "# Create the boxplot for the first dataset\n",
    "axes[0].boxplot(grouped_df1['ate'], vert=False, patch_artist=True, labels=grouped_df1['method'])\n",
    "axes[0].axvline(x=true_ATE, color='red', linestyle='--')\n",
    "axes[0].set_xlabel('ATE', fontsize=font_size)\n",
    "axes[0].set_title('No Confounding', fontsize=title_fontsize)\n",
    "axes[0].tick_params(axis='both', which='major', labelsize=font_size)\n",
    "axes[0].grid(True, linestyle='--', alpha=0.7)\n",
    "\n",
    "# Create the boxplot for the second dataset\n",
    "axes[1].boxplot(grouped_df2['ate'], vert=False, patch_artist=True, labels=grouped_df2['method'])\n",
    "axes[1].axvline(x=true_ATE, color='red', linestyle='--')\n",
    "axes[1].set_xlabel('ATE', fontsize=font_size)\n",
    "axes[1].set_title(r'With Real-World Confounding', fontsize=title_fontsize)\n",
    "axes[1].tick_params(axis='both', which='major', labelsize=font_size)\n",
    "axes[1].grid(True, linestyle='--', alpha=0.7)\n",
    "\n",
    "# Create the boxplot for the third dataset\n",
    "axes[2].boxplot(grouped_df3['ate'], vert=False, patch_artist=True, labels=grouped_df3['method'])\n",
    "axes[2].axvline(x=true_ATE, color='red', linestyle='--')\n",
    "axes[2].set_xlabel('ATE', fontsize=font_size)\n",
    "axes[2].set_title(r'With Hidden Confounding $\\rho=0.5$', fontsize=title_fontsize)\n",
    "axes[2].tick_params(axis='both', which='major', labelsize=font_size)\n",
    "axes[2].grid(True, linestyle='--', alpha=0.7)\n",
    "\n",
    "# Adjust layout\n",
    "plt.tight_layout()\n",
    "\n",
    "# Save the plot as a PDF\n",
    "plt.savefig('lalonde_box_and_whisker_plots.pdf', format='pdf')\n",
    "\n",
    "# Display the plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6feda6a1-3543-4258-8e3c-d8f422a0508f",
   "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.11.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
