{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from simulations.simulations import path_wise_dataset_1, treatment_col_index, confounder_col_index, mediator1_col_index, mediator2_col_index, ModelWrapper, calculate_true_cate_but_mediator2\n",
    "import numpy as np\n",
    "\n",
    "np.random.seed(0)\n",
    "from sklearn.experimental import enable_iterative_imputer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "from re import L\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.impute import IterativeImputer\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "import time\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from simulations.simulations import ModelWrapper\n",
    "\n",
    "\n",
    "def model_outcomes_coal(model, coal, local_obs, ref_point, imp=None, predict_proba=False, seed=0):\n",
    "    \n",
    "    start = time.time()\n",
    "    \n",
    "    ## this function outputs a list of all model predictions for a single coalition\n",
    "    # the input is the coalition of interest as a binary vector eg. [1,1,0,1]\n",
    "    # ref point is the entire reference distirbution (here we take x_train)\n",
    "    # local_obs is the instance we aim to explain\n",
    "    \n",
    "    n_obs, d_obs = np.shape(local_obs)\n",
    "\n",
    "    # we consider all 2**n coalitions and all n reference points\n",
    "    # get constants\n",
    "    \n",
    "    n, d = np.shape(ref_point)\n",
    "    assert d == d_obs\n",
    "    \n",
    "    # train imputation algorithm for conditional references   \n",
    "    # create an \"all_imputed_coalitions\" 3D matrix with all \"artificial inputs\" we get by imputing\n",
    "    coalitions = np.array([[int(i) for i in '0'*((d)-len(bin(j))+2) + bin(j)[2:]] for j in range(2**d)]) \n",
    "    all_imputed_coalitions = np.zeros((n_obs, n, d))\n",
    "\n",
    "    \n",
    "     ## below we build the concatenated inputs using conditional imputation for dropped features and averages\n",
    "    for k in range(n):#reference point index\n",
    "        vect=(1-coal) \n",
    "        vect = vect.astype('float')\n",
    "        vect[vect == 1] = 'nan'    # vect is a binary vector of being \"absent\" ('nan') or \"present\" (1)\n",
    "        # impute conditionally with Bayesian Ridge MICE \n",
    "        imputed_coalitions = coal * local_obs + vect #either local obs value or 'nan'\n",
    "        #print(imputed_coalitions)\n",
    "        nans = (np.isnan(imputed_coalitions).sum(axis=0) > 0)\n",
    "        if (~nans).sum() == 0 or imp is None:\n",
    "            idx = np.random.randint(n, size=n_obs)\n",
    "            imputation = ref_point[idx]\n",
    "            imputed_coalitions[:,nans] = imputation[:,nans]\n",
    "        else:\n",
    "            imputed_coalitions = imp.transform(imputed_coalitions)       \n",
    "        all_imputed_coalitions[:, k, :] = imputed_coalitions\n",
    "        \n",
    "    end = time.time()\n",
    "    print('Execution time (s) :', end - start)\n",
    "    #we ultimately return the model predictions\n",
    "    if predict_proba:\n",
    "        return model.predict_proba(all_imputed_coalitions.reshape(n_obs * n, d))[:,1].reshape(n_obs, n)\n",
    "    else:\n",
    "        return model.predict(all_imputed_coalitions.reshape(n_obs * n, d)).reshape(n_obs, n)\n",
    "\n",
    "\n",
    "class IterativeImputerSubsets(object):\n",
    "\n",
    "    def __init__(self, subsets=[], **kwargs):\n",
    "\n",
    "        self.imps = []\n",
    "        self.subsets = subsets\n",
    "        for subset in self.subsets:\n",
    "            self.imps.append(IterativeImputer(**kwargs))\n",
    "\n",
    "    def fit(self, x_train):\n",
    "        for imp, subset in zip(self.imps, self.subsets):\n",
    "            x_train_subset = x_train[:, subset]\n",
    "            imp.fit(x_train_subset)\n",
    "\n",
    "    def transform(self, x):\n",
    "        x_new = x\n",
    "        for imp, subset in zip(self.imps, self.subsets):\n",
    "            x_new[:, subset] = imp.transform(x[:, subset])\n",
    "        return x_new\n",
    "\n",
    "psis_specific_q_ratios = []\n",
    "psis_specific_d_ratios = []\n",
    "phi_direct_cs_ratios = []\n",
    "phi_indirect_cs_ratios = []\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def compute_effects(local_obs, outcome, data, y, cate_only_mode=False):\n",
    "\n",
    "    start = time.time()\n",
    "\n",
    "    # p = 0.5 * np.ones(N)\n",
    "    # t = np.random.binomial(n=1, p=p)\n",
    "\n",
    "    # q = np.random.uniform(size=N)\n",
    "    # q = t * 3 / 5 * q + (1 - t) * (3 / 5 * q + 2 / 5)\n",
    "    # d = np.random.binomial(n=1, p=4 / 5 - 3 / 5 * t)\n",
    "\n",
    "    # loc=5\n",
    "    # scale=10\n",
    "    # (coef_t, coef_q, coef_d, coef_t_q, coef_t_d) = tuple(np.random.normal(loc=loc, scale=scale, size=5))\n",
    "    # y = coef_t*t + coef_q*q + coef_d*d + coef_t_q*t*q + coef_t_d*t*d\n",
    "\n",
    "    x = pd.DataFrame({'t': data[:, 0], 'c': data[:, 1], 'q': data[:, 2], 'd': data[:, 3]})\n",
    "    prop_train = 0.3\n",
    "    N_train = int(prop_train * data.shape[0])\n",
    "    x_train = x.iloc[:N_train]\n",
    "    y_train = y[:N_train]\n",
    "    x_test = x.iloc[N_train:]\n",
    "    y_test = y[N_train:]\n",
    "    imp = IterativeImputer(max_iter=100, random_state=0, sample_posterior=True)\n",
    "    imp.fit(x.values) #imputer learns from marginal distribution\n",
    "\n",
    "\n",
    "    imp_all_but_t = IterativeImputer(max_iter=100, random_state=0, sample_posterior=True)\n",
    "    imp_all_but_t.fit(x_train[['c','q','d']].values)\n",
    "\n",
    "    propensity = LogisticRegression()\n",
    "    propensity.fit(x_train[['c','q','d']], x_train['t'])\n",
    "\n",
    "    local_obs_propensity = [local_obs[0][1:]]\n",
    "\n",
    "\n",
    "    print('outcomes_all_but_d')\n",
    "    outcomes_all_but_d = model_outcomes_coal(model=outcome, coal=np.array([1,1,1,0]), local_obs=local_obs, ref_point=x_train.values, imp=imp)\n",
    "    print('outcomes_all_but_d_t')\n",
    "    outcomes_all_but_d_t = model_outcomes_coal(model=outcome, coal=np.array([0,1,1,0]), local_obs=local_obs, ref_point=x_train.values, imp=imp)\n",
    "    print('propensities_all_but_d')\n",
    "    propensities_all_but_d =  model_outcomes_coal(model=propensity, coal=np.array([1,1,0]), local_obs=local_obs_propensity, ref_point=x_train[['c','q','d']].values, imp=imp_all_but_t, predict_proba=True)\n",
    "\n",
    "\n",
    "    print(\"outcomes_all_but_d.mean(axis=1)\")\n",
    "    print(outcomes_all_but_d.mean(axis=1))\n",
    "\n",
    "    print(\"outcomes_all_but_d_t.mean(axis=1)\")\n",
    "    print(outcomes_all_but_d_t.mean(axis=1))\n",
    "\n",
    "\n",
    "    psis_coal_all_but_d = (outcomes_all_but_d.mean(axis=1) - outcomes_all_but_d_t.mean(axis=1)) / (local_obs[0][0] - propensities_all_but_d.mean(axis=1))\n",
    "\n",
    "\n",
    "    print(\"propensities_all_but_d.mean(axis=1)\")\n",
    "    print(propensities_all_but_d.mean(axis=1))\n",
    "\n",
    "    if cate_only_mode:\n",
    "        return {\n",
    "            \"path_wise_shap_t_m2_y\": 0,\n",
    "            \"path_wise_shap_t_m1_y\": 0,   \n",
    "            \"cate_mediator1_mediator2_confounder\": 0,\n",
    "            \"cate_mediator1_confounder\": psis_coal_all_but_d,\n",
    "            \"cate_mediator2_confounder\": 0,\n",
    "        }\n",
    "\n",
    "\n",
    "    print('outcomes_all')\n",
    "    outcomes_all = model_outcomes_coal(model=outcome, coal=np.array([1,1,1,1]), local_obs=local_obs, ref_point=x_train.values, imp=imp)\n",
    "    print('outcomes_all_but_t')\n",
    "    outcomes_all_but_t = model_outcomes_coal(model=outcome, coal=np.array([1,1,1,0]), local_obs=local_obs, ref_point=x_train.values, imp=imp)\n",
    "    print('propensities_all')\n",
    "    propensities_all =  model_outcomes_coal(model=propensity, coal=np.array([1,1,1]), local_obs=local_obs_propensity, ref_point=x_train[['c','q','d']].values, imp=imp_all_but_t, predict_proba=True)\n",
    "\n",
    "    print(propensities_all)\n",
    "    \n",
    "    psis_coal_all = (outcomes_all.mean(axis=1) - outcomes_all_but_t.mean(axis=1)) / (local_obs[0][0] - propensities_all.mean(axis=1))\n",
    "    \n",
    "    psis_specific_d = psis_coal_all - psis_coal_all_but_d\n",
    "\n",
    "\n",
    "\n",
    "    print(\"___________\")\n",
    "    print(psis_coal_all)\n",
    "\n",
    "    print('outcomes_all_but_q')\n",
    "    outcomes_all_but_q = model_outcomes_coal(model=outcome, coal=np.array([1, 1,0,1]), local_obs=local_obs, ref_point=x_train.values, imp=imp)\n",
    "    print('outcomes_all_but_q_t')\n",
    "    outcomes_all_but_q_t = model_outcomes_coal(model=outcome, coal=np.array([0, 1,0,1]), local_obs=local_obs, ref_point=x_train.values, imp=imp)\n",
    "    print('propensities_all_but_q')\n",
    "    propensities_all_but_q =  model_outcomes_coal(model=propensity, coal=np.array([1,0,1]), local_obs=local_obs_propensity, ref_point=x_train[['c','q','d']].values, imp=imp_all_but_t, predict_proba=True)\n",
    "\n",
    "    psis_coal_all_but_q = (outcomes_all_but_q.mean(axis=1) - outcomes_all_but_q_t.mean(axis=1)) / (local_obs[0][0] - propensities_all_but_q.mean(axis=1))\n",
    "\n",
    "    psis_specific_q = psis_coal_all - psis_coal_all_but_q\n",
    "\n",
    "    print('psis_specific_q_ratio: ', np.abs(psis_specific_q))\n",
    "    psis_specific_q_ratios.append(np.abs(psis_specific_q))\n",
    "\n",
    "    print('psis_specific_d_ratio: ', np.abs(psis_specific_d))\n",
    "    psis_specific_d_ratios.append(np.abs(psis_specific_d))\n",
    "\n",
    "    return {\n",
    "            \"path_wise_shap_t_m2_y\": psis_specific_d,\n",
    "            \"path_wise_shap_t_m1_y\": psis_specific_q,\n",
    "            \"cate_mediator1_mediator2_confounder\": psis_coal_all,\n",
    "            \"cate_mediator1_confounder\": psis_coal_all_but_d,\n",
    "            \"cate_mediator2_confounder\": psis_coal_all_but_q,\n",
    "    }   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.542139053344727\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.360275268554688\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.45119309425354\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.11552459]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.73358676]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.70174081]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "{'path_wise_shap_t_m2_y': 0,\n",
       " 'path_wise_shap_t_m1_y': 0,\n",
       " 'cate_mediator1_mediator2_confounder': 0,\n",
       " 'cate_mediator1_confounder': array([1.28055682]),\n",
       " 'cate_mediator2_confounder': 0}"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_test1, y_test1 = path_wise_dataset_1(num_samples=1000)\n",
    "\n",
    "compute_effects([[1, 0.2, 0.6, 1]], ModelWrapper(), X_test1, y_test1, cate_only_mode=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def monte_carlo_evaluation_all_models_path_wise_approach(sample, model_types=None, \n",
    "                                                  num_runs=100, num_samples=1000, base_seed=42):\n",
    "    \"\"\"\n",
    "    Perform Monte Carlo evaluation for all specified model types using doubly robust estimator.\n",
    "    \n",
    "    Args:\n",
    "        sample: The sample for which to evaluate CATE\n",
    "        model_types: List of model types to test\n",
    "        num_runs: Number of Monte Carlo runs\n",
    "        num_samples: Number of samples per run for training the estimator\n",
    "        base_seed: Base seed for reproducibility (each run gets base_seed + run_number)\n",
    "    \n",
    "    Returns:\n",
    "        Dictionary with results for each model type\n",
    "    \"\"\"\n",
    "    results = {}\n",
    "    true_value = calculate_true_cate_but_mediator2(sample)\n",
    "    \n",
    "    print(f\"True CATE without mediator2: {true_value:.4f}\")\n",
    "    print(f\"Testing {len(model_types)} model types: {model_types}\")\n",
    "    print(f\"Running {num_runs} Monte Carlo simulations for each model...\")\n",
    "    \n",
    "    for model_type, propensity_model_type in model_types:\n",
    "        print(f\"\\n{'='*60}\")\n",
    "        print(f\"EVALUATING MODEL: {model_type}\")\n",
    "        print(f\"{'='*60}\")\n",
    "        \n",
    "        estimates = []\n",
    "        \n",
    "        for run in range(num_runs):\n",
    "            # Generate new dataset for this run\n",
    "            X_test, y_test = path_wise_dataset_1(num_samples=num_samples, seed=base_seed+run)\n",
    "            # Get estimate from the doubly robust estimator with specific model type\n",
    "            result = compute_effects(\n",
    "                [sample], \n",
    "                ModelWrapper(), \n",
    "                X_test, \n",
    "                y_test,\n",
    "                cate_only_mode=True\n",
    "            )\n",
    "\n",
    "            estimate = result[\"cate_mediator1_confounder\"]  # Extract scalar value\n",
    "            print(\"@@@@@@@@@@@@@@@@@@\")\n",
    "            print(true_value)\n",
    "            print(\"@@@@@@@@@@@@@@@@@@\")\n",
    "            print(estimate)\n",
    "            print(\"@@@@@@@@@@@@@@@@@@\")\n",
    "\n",
    "            if estimate == np.nan:\n",
    "                raise Exception(\"Failed to indetify\")\n",
    "            estimates.append(estimate)\n",
    "            \n",
    "            if (run + 1) % 20 == 0:\n",
    "                print(f\"  {model_type}_{propensity_model_type}: Completed {run + 1}/{num_runs} runs\")\n",
    "        \n",
    "        estimates = np.array(estimates)\n",
    "        \n",
    "        # Calculate only MAE and Monte Carlo Error\n",
    "        errors = estimates - true_value\n",
    "        mae = np.mean(np.abs(errors))\n",
    "        \n",
    "        # Monte Carlo Error (standard error of the mean)\n",
    "        monte_carlo_error = np.std(estimates) / np.sqrt(num_runs)\n",
    "        \n",
    "        results[f\"{model_type}_{propensity_model_type}\"] = {\n",
    "            'true_value': true_value,\n",
    "            'estimates': estimates,\n",
    "            'mae': mae,\n",
    "            'monte_carlo_error': monte_carlo_error\n",
    "        }\n",
    "        \n",
    "        print(f\"  {model_type}_{propensity_model_type} Results:\")\n",
    "        print(f\"    MAE: {mae:.4f}\")\n",
    "        print(f\"    Monte Carlo Error: {monte_carlo_error:.4f}\")\n",
    "    \n",
    "    return results\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def evaluate_multiple_samples_averaged_doubly_robust(samples, model_types=None, \n",
    "                                                   num_runs=5, num_samples=10000, base_seed=42):\n",
    "    \"\"\"\n",
    "    Evaluate multiple samples and return averaged results across all samples for doubly robust estimator.\n",
    "\n",
    "    Args:\n",
    "        samples: List of samples to evaluate\n",
    "        model_types: List of model types to test\n",
    "        num_runs: Number of Monte Carlo runs per sample\n",
    "        num_samples: Number of samples per run\n",
    "        base_seed: Base seed for reproducibility\n",
    "\n",
    "    Returns:\n",
    "        Dictionary with averaged results and individual sample results\n",
    "    \"\"\"\n",
    "    import pandas as pd\n",
    "    import numpy as np\n",
    "    \n",
    "    all_results = {}\n",
    "    sample_results = {}\n",
    "    \n",
    "    print(f\"Evaluating {len(samples)} samples with {len(model_types)} model types each (Doubly Robust)\")\n",
    "    print(f\"Total evaluations: {len(samples)} × {len(model_types)} = {len(samples) * len(model_types)}\")\n",
    "    print(\"=\"*80)\n",
    "    \n",
    "    # Evaluate each sample\n",
    "    for i, sample in enumerate(samples):\n",
    "        print(f\"\\nSAMPLE {i+1}: {sample}\")\n",
    "        print(f\"True CATE: {calculate_true_cate_but_mediator2(sample):.4f}\")\n",
    "        print(\"-\" * 60)\n",
    "        \n",
    "        # Run evaluation for this sample\n",
    "        sample_result = monte_carlo_evaluation_all_models_path_wise_approach(\n",
    "            sample, \n",
    "            model_types, \n",
    "            num_runs, \n",
    "            num_samples, \n",
    "            base_seed + i  # Different seed for each sample\n",
    "        )\n",
    "\n",
    "        sample_results[f\"sample_{i+1}\"] = sample_result\n",
    "        \n",
    "        # Print results for this sample\n",
    "        for model_type, propensity_model_type in model_types:\n",
    "            mae = sample_result[f\"{model_type}_{propensity_model_type}\"]['mae']\n",
    "            mce = sample_result[f\"{model_type}_{propensity_model_type}\"]['monte_carlo_error']\n",
    "            print(f\"  {model_type}_{propensity_model_type}: MAE={mae:.4f}, MCE={mce:.4f}\")\n",
    "    \n",
    "    # Calculate averaged results\n",
    "    print(\"\\n\" + \"=\"*80)\n",
    "    print(\"AVERAGED RESULTS ACROSS ALL SAMPLES (DOUBLY ROBUST)\")\n",
    "    print(\"=\"*80)\n",
    "    \n",
    "    averaged_results = {}\n",
    "    for model_type, propensity_model_type in model_types:\n",
    "        # Collect all estimates and true values for this model type across samples\n",
    "        all_estimates = []\n",
    "        all_true_values = []\n",
    "        \n",
    "        for i in range(len(samples)):\n",
    "            estimates = sample_results[f\"sample_{i+1}\"][f\"{model_type}_{propensity_model_type}\"]['estimates']\n",
    "            true_value = sample_results[f\"sample_{i+1}\"][f\"{model_type}_{propensity_model_type}\"]['true_value']\n",
    "            all_estimates.extend(estimates)\n",
    "            all_true_values.extend([true_value] * len(estimates))\n",
    "        \n",
    "        # Compute MAE for all samples combined\n",
    "        all_estimates = np.array(all_estimates)\n",
    "        all_true_values = np.array(all_true_values)\n",
    "        combined_mae = np.mean(np.abs(all_estimates - all_true_values))\n",
    "        \n",
    "        # Compute Monte Carlo error for all samples combined\n",
    "        # Monte Carlo error is the standard error of the mean: std(estimates) / sqrt(n)\n",
    "        combined_mce = np.std(all_estimates) / np.sqrt(len(all_estimates))\n",
    "        \n",
    "        averaged_results[f\"{model_type}_{propensity_model_type}\"] = {\n",
    "            'mae_combined': combined_mae,\n",
    "            'mce_combined': combined_mce,\n",
    "            'total_estimates': len(all_estimates)\n",
    "        }\n",
    "    \n",
    "    # Create comparison table\n",
    "    comparison_data = []\n",
    "    for model_type, propensity_model_type in model_types:\n",
    "        result = averaged_results[f\"{model_type}_{propensity_model_type}\"]\n",
    "        comparison_data.append({\n",
    "            'Model': f\"{model_type}_{propensity_model_type}\",\n",
    "            'MAE (Combined)': f\"{result['mae_combined']:.4f}\",\n",
    "            'Monte Carlo Error (Combined)': f\"{result['mce_combined']:.4f}\",\n",
    "            'Total Estimates': result['total_estimates']\n",
    "        })\n",
    "    \n",
    "    df_comparison = pd.DataFrame(comparison_data)\n",
    "    print(df_comparison.to_string(index=False))\n",
    "    \n",
    "    # Find best performing model by combined MAE\n",
    "    best_model = min(model_types, key=lambda x: averaged_results[f\"{x[0]}_{x[1]}\"]['mae_combined'])\n",
    "    print(f\"\\nBest performing model (by combined MAE): {best_model[0]}_{best_model[1]}\")\n",
    "    print(f\"Combined MAE: {averaged_results[f\"{best_model[0]}_{best_model[1]}\"]['mae_combined']:.4f}\")\n",
    "    print(f\"Total estimates used: {averaged_results[f\"{best_model[0]}_{best_model[1]}\"]['total_estimates']}\")\n",
    "    \n",
    "    return averaged_results, sample_results, df_comparison\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Testing 3 samples with all model types and computing averaged results (Doubly Robust)...\n",
      "================================================================================\n",
      "Evaluating 5 samples with 1 model types each (Doubly Robust)\n",
      "Total evaluations: 5 × 1 = 5\n",
      "================================================================================\n",
      "\n",
      "SAMPLE 1: [1, 0.2, 0.3, 1]\n",
      "True CATE: 1.1930\n",
      "------------------------------------------------------------\n",
      "True CATE without mediator2: 1.1930\n",
      "Testing 1 model types: [('any', 'any')]\n",
      "Running 10 Monte Carlo simulations for each model...\n",
      "\n",
      "============================================================\n",
      "EVALUATING MODEL: any\n",
      "============================================================\n",
      "outcomes_all_but_d\n",
      "Execution time (s) : 13.608947992324829\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.898927211761475\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.240002155303955\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.47939603]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.96167764]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.61529195]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.193\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.34574358]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.65187406539917\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.58021306991577\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.980210781097412\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.41968569]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.91791596]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.56332209]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.193\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.14906139]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.894316911697388\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.681375980377197\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.394752025604248\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.45758212]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.94714639]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.62445349]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.193\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.35918112]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.572264194488525\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.420082092285156\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.330143928527832\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.44271417]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.94395436]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.59999432]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.193\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.24688183]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.43998408317566\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.370580911636353\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.519069910049438\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.49607291]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.96245876]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.60002502]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.193\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.33411881]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.628891944885254\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.619768142700195\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.518996953964233\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.48179353]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.96460159]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.61867083]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.193\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.35628738]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.63036584854126\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.469848155975342\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.286846160888672\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.50627034]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.97364731]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.57514284]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.193\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.253652]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.570065021514893\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.695462942123413\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.524933815002441\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.42991676]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.90283497]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.57644715]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.193\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.24442981]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.730687141418457\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.610882997512817\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.504923105239868\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.46620905]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.95846885]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.61954115]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.193\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.33454695]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.691431760787964\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.73093295097351\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.374284029006958\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.46047536]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.98104151]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.56346803]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.193\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.0982789]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "  any_any Results:\n",
      "    MAE: 0.1070\n",
      "    Monte Carlo Error: 0.0274\n",
      "  any_any: MAE=0.1070, MCE=0.0274\n",
      "\n",
      "SAMPLE 2: [1, 0.2, 0.4, 1]\n",
      "True CATE: 1.1430\n",
      "------------------------------------------------------------\n",
      "True CATE without mediator2: 1.1430\n",
      "Testing 1 model types: [('any', 'any')]\n",
      "Running 10 Monte Carlo simulations for each model...\n",
      "\n",
      "============================================================\n",
      "EVALUATING MODEL: any\n",
      "============================================================\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.508869886398315\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.516993045806885\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.494647026062012\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.31533494]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.86070999]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.60616362]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.143\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.1543498]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.575440168380737\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.76364803314209\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.547393083572388\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.35243924]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.89023738]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.65804989]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.143\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.35166461]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.771315097808838\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.719882011413574\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.591315984725952\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.34113789]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.88825668]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.63587408]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.143\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.2437489]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.504720211029053\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.68732500076294\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.568984985351562\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.38802501]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.90693032]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.63861084]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.143\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.33123721]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.646007061004639\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 23.3836669921875\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 12.1164231300354\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.37923163]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.9058138]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.64601036]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.143\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.33737766]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.837357997894287\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.754786014556885\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.452600955963135\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.39673625]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.91418096]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.62042034]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.143\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.27128861]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.532588005065918\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.736519813537598\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.530500888824463\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.32398202]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.84565581]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.60288861]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.143\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.20451394]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.772404193878174\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.80435085296631\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.64064884185791\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.36155888]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.90102213]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.64896217]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.143\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.31192914]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.7985200881958\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.73945188522339\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.58256483078003\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.3532583]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.91868208]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.60319957]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.143\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.09520098]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.461230993270874\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.74288320541382\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.471733093261719\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.36929178]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.90249092]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.64941202]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.143\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.33147993]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "  any_any Results:\n",
      "    MAE: 0.1298\n",
      "    Monte Carlo Error: 0.0263\n",
      "  any_any: MAE=0.1298, MCE=0.0263\n",
      "\n",
      "SAMPLE 3: [1, 0.2, 0.5, 1]\n",
      "True CATE: 1.0930\n",
      "------------------------------------------------------------\n",
      "True CATE without mediator2: 1.0930\n",
      "Testing 1 model types: [('any', 'any')]\n",
      "Running 10 Monte Carlo simulations for each model...\n",
      "\n",
      "============================================================\n",
      "EVALUATING MODEL: any\n",
      "============================================================\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.723925113677979\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.76926016807556\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.502758741378784\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.23131056]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.81545556]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.69035292]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.093\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.34299666]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.82725191116333\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.828490018844604\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.556265115737915\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.2236061]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.81474645]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.67050468]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.093\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.24086634]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.688827991485596\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.420549869537354\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.565561056137085\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.26399596]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.83329299]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.67571909]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.093\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.3281786]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.759066820144653\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.721455812454224\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.536432027816772\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.26070038]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.82936689]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.67255648]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.093\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.317276]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.819774866104126\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.950540781021118\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.617847919464111\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.27123108]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.83666931]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.66396103]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.093\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.2931886]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.687656879425049\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.558645963668823\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.482955932617188\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.20206016]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.7704375]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.62881531]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.093\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.16282451]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.829384803771973\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 23.07689380645752\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.56423020362854\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.24092357]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.82566113]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.67744839]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.093\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.28742946]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 12.124320983886719\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.88938593864441\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 12.02453875541687\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.23005705]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.83845473]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.64178815]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.093\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.09321432]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.850965023040771\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.77307391166687\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.449342012405396\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.24425589]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.82665423]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.68913531]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.093\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.34335507]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.658210039138794\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.775843858718872\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.455424070358276\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.25950876]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.82313946]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.6439615]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.093\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.22562391]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "  any_any Results:\n",
      "    MAE: 0.1705\n",
      "    Monte Carlo Error: 0.0250\n",
      "  any_any: MAE=0.1705, MCE=0.0250\n",
      "\n",
      "SAMPLE 4: [1, 0.2, 0.6, 1]\n",
      "True CATE: 1.0430\n",
      "------------------------------------------------------------\n",
      "True CATE without mediator2: 1.0430\n",
      "Testing 1 model types: [('any', 'any')]\n",
      "Running 10 Monte Carlo simulations for each model...\n",
      "\n",
      "============================================================\n",
      "EVALUATING MODEL: any\n",
      "============================================================\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.897171974182129\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.615581035614014\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.250679969787598\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.0901188]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.72342349]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.70361849]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.043\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.23724083]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 12.22045373916626\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.76532292366028\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.62442398071289\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.12398578]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.74154662]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.7110227]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.043\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.32342284]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.6392080783844\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.94274616241455\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.575562000274658\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.12619977]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.73526068]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.69819262]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.043\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.29532649]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.356587171554565\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 23.269511938095093\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.597486019134521\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.12975484]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.74111222]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.70521923]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.043\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.3184124]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.610563039779663\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.518374919891357\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 12.08937382698059\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.06415118]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.67717984]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.65411318]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.043\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.11878025]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.301537990570068\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.79279899597168\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.060006141662598\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.10430312]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.73238568]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.70485504]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.043\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.26011788]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 12.392684936523438\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.154513835906982\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.329450130462646\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.09087162]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.74035928]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.67884553]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.043\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.09141353]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.432049989700317\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.549694299697876\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.129985094070435\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.10324701]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.73257106]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.7266029]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.043\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.3558152]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.087577104568481\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.756805896759033\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.537383079528809\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.12157932]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.73001268]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.67958032]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.043\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.22204304]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.2101469039917\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.733222007751465\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.107784032821655\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[1.08629644]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.71599821]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.74113326]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "1.043\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.43045888]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "  any_any Results:\n",
      "    MAE: 0.2223\n",
      "    Monte Carlo Error: 0.0311\n",
      "  any_any: MAE=0.2223, MCE=0.0311\n",
      "\n",
      "SAMPLE 5: [1, 0.2, 0.7, 1]\n",
      "True CATE: 0.9930\n",
      "------------------------------------------------------------\n",
      "True CATE without mediator2: 0.9930\n",
      "Testing 1 model types: [('any', 'any')]\n",
      "Running 10 Monte Carlo simulations for each model...\n",
      "\n",
      "============================================================\n",
      "EVALUATING MODEL: any\n",
      "============================================================\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.358522891998291\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.74083709716797\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 10.796402215957642\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[0.96799447]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.63169103]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.74425448]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "0.9930000000000001\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.31499249]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.488934755325317\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.99040198326111\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.335169076919556\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[0.97572981]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.62349501]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.72281778]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "0.9930000000000001\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.27076983]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.83668303489685\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.688480854034424\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.04394006729126\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[0.97230753]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.62750949]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.74375382]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "0.9930000000000001\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.34557334]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.601974964141846\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.82825016975403\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 10.997908115386963\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[0.91025509]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.56588263]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.67867933]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "0.9930000000000001\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.07174075]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.114987850189209\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.88612985610962\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.124269962310791\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[0.95169751]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.62119561]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.73105839]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "0.9930000000000001\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.22889837]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.298110961914062\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.913685083389282\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 10.883483171463013\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[0.93570199]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.62439554]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.71403941]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "0.9930000000000001\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.0886341]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.161938905715942\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.79758906364441\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.067558765411377\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[0.94626513]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.62024124]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.76150215]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "0.9930000000000001\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.3669888]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.178538084030151\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.74679207801819\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.115144968032837\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[0.96766178]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.61896052]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.71349578]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "0.9930000000000001\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.21708946]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 11.37397575378418\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 21.889163970947266\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.062670946121216\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[0.92529919]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.60000375]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.77393268]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "0.9930000000000001\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.43893173]\n",
      "@@@@@@@@@@@@@@@@@@\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "outcomes_all_but_d\n",
      "Execution time (s) : 10.91623306274414\n",
      "outcomes_all_but_d_t\n",
      "Execution time (s) : 22.041145086288452\n",
      "propensities_all_but_d\n",
      "Execution time (s) : 11.286768198013306\n",
      "outcomes_all_but_d.mean(axis=1)\n",
      "[0.9667625]\n",
      "outcomes_all_but_d_t.mean(axis=1)\n",
      "[0.65730598]\n",
      "propensities_all_but_d.mean(axis=1)\n",
      "[0.82321025]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "0.9930000000000001\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "[1.75042115]\n",
      "@@@@@@@@@@@@@@@@@@\n",
      "  any_any Results:\n",
      "    MAE: 0.3164\n",
      "    Monte Carlo Error: 0.0581\n",
      "  any_any: MAE=0.3164, MCE=0.0581\n",
      "\n",
      "================================================================================\n",
      "AVERAGED RESULTS ACROSS ALL SAMPLES (DOUBLY ROBUST)\n",
      "================================================================================\n",
      "  Model MAE (Combined) Monte Carlo Error (Combined)  Total Estimates\n",
      "any_any         0.1912                       0.0162               50\n",
      "\n",
      "Best performing model (by combined MAE): any_any\n",
      "Combined MAE: 0.1912\n",
      "Total estimates used: 50\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/maksym/Documents/Files/Heavy/Work/NYU_NEW/.venv/lib/python3.12/site-packages/sklearn/utils/validation.py:2739: UserWarning: X does not have valid feature names, but LogisticRegression was fitted with feature names\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "# Test with 3 different samples and compute averaged results for doubly robust estimator\n",
    "samples = [\n",
    "    [1, 0.2, 0.3, 1],\n",
    "    [1, 0.2, 0.4, 1],\n",
    "    [1, 0.2, 0.5, 1],\n",
    "    [1, 0.2, 0.6, 1],\n",
    "    [1, 0.2, 0.7, 1],\n",
    "]\n",
    "\n",
    "print(\"Testing 3 samples with all model types and computing averaged results (Doubly Robust)...\")\n",
    "print(\"=\"*80)\n",
    "\n",
    "# Run comprehensive evaluation for all samples\n",
    "averaged_results, sample_results, comparison_df = evaluate_multiple_samples_averaged_doubly_robust(\n",
    "    samples, \n",
    "    model_types=[(\"any\", \"any\")],\n",
    "    num_runs=10,\n",
    "    num_samples=1000,\n",
    "    base_seed=0\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.12.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
