{"cells":[{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":28313,"status":"ok","timestamp":1767579025243,"user":{"displayName":"D K","userId":"02556183042422178006"},"user_tz":-540},"id":"PdT-NG4N5qb5","outputId":"b422524a-ef98-4364-c949-f1b6e173d623"},"outputs":[{"name":"stdout","output_type":"stream","text":["Mounted at /content/drive\n"]}],"source":["from google.colab import drive\n","drive.mount('/content/drive')\n"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"_yhJNFSDBzCX"},"outputs":[],"source":["from sklearn.ensemble import RandomForestRegressor"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"qyI5btjx6UG5"},"outputs":[],"source":["import os, sys, pathlib\n","import numpy as np\n","import pandas as pd\n","\n","# Your existing working directory (same as in your current Colab)\n","WORKDIR = \"/content/drive/MyDrive/Colab Notebooks/CTE_Baseline/DML_methods\"\n","\n","\n","os.makedirs(WORKDIR, exist_ok=True)\n","os.chdir(WORKDIR)\n","if WORKDIR not in sys.path:\n","    sys.path.insert(0, WORKDIR)\n","\n","SUPP_DIR = os.path.join(WORKDIR, \"Supplement\")\n","if os.path.isdir(SUPP_DIR) and SUPP_DIR not in sys.path:\n","    sys.path.insert(0, SUPP_DIR)\n","\n","# Ensure 'Supplement' is a package if only estimation.py exists\n","init_path = os.path.join(SUPP_DIR, \"__init__.py\")\n","if os.path.isdir(SUPP_DIR) and not os.path.exists(init_path):\n","    with open(init_path, \"w\", encoding=\"utf-8\") as f:\n","        f.write(\"from .estimation import *\\n\")\n","    print(\"[info] Created Supplement/__init__.py shim\")\n"]},{"cell_type":"code","execution_count":null,"metadata":{"colab":{"background_save":true,"base_uri":"https://localhost:8080/"},"id":"Ph62hZ-vjyrU","outputId":"2240e736-d91c-4813-a77f-3ea5c3cbf1cd"},"outputs":[{"name":"stderr","output_type":"stream","text":["/usr/local/lib/python3.12/dist-packages/torch/__init__.py:1275: UserWarning: torch.set_default_tensor_type() is deprecated as of PyTorch 2.1, please use torch.set_default_dtype() and torch.set_default_device() as alternatives. (Triggered internally at /pytorch/torch/csrc/tensor/python_tensor.cpp:434.)\n","  _C._set_default_tensor_type(t)\n"]},{"name":"stdout","output_type":"stream","text":["Drive already mounted at /content/drive; to attempt to forcibly remount, call drive.mount(\"/content/drive\", force_remount=True).\n","Working Directory: /content/drive/MyDrive/Colab Notebooks/CTE_Baseline/DML_methods\n","Results Directory: /content/drive/MyDrive/Colab Notebooks/CTE_Baseline/DML_methods/Empirical Application/Estimates\n","\n",">>> Starting 100 Monte Carlo simulations...\n","\n","[Progress] Processing Simulation 1/100 (Seed: 1)\n"]},{"name":"stderr","output_type":"stream","text":["100%|██████████| 47/47 [02:37<00:00,  3.35s/it]\n","100%|██████████| 47/47 [02:25<00:00,  3.10s/it]\n","100%|██████████| 47/47 [02:26<00:00,  3.13s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 2/100 (Seed: 2)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:27<00:00,  3.13s/it]\n","100%|██████████| 47/47 [02:29<00:00,  3.19s/it]\n","100%|██████████| 47/47 [02:26<00:00,  3.12s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 3/100 (Seed: 3)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:27<00:00,  3.13s/it]\n","100%|██████████| 47/47 [02:36<00:00,  3.33s/it]\n","100%|██████████| 47/47 [02:35<00:00,  3.32s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 4/100 (Seed: 4)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:36<00:00,  3.32s/it]\n","100%|██████████| 47/47 [02:37<00:00,  3.35s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.03s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 5/100 (Seed: 5)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:18<00:00,  2.94s/it]\n","100%|██████████| 47/47 [02:24<00:00,  3.08s/it]\n","100%|██████████| 47/47 [02:33<00:00,  3.27s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 6/100 (Seed: 6)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:28<00:00,  3.15s/it]\n","100%|██████████| 47/47 [02:24<00:00,  3.07s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.03s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 7/100 (Seed: 7)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:26<00:00,  3.12s/it]\n","100%|██████████| 47/47 [02:26<00:00,  3.11s/it]\n","100%|██████████| 47/47 [02:29<00:00,  3.19s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 8/100 (Seed: 8)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:27<00:00,  3.15s/it]\n","100%|██████████| 47/47 [02:21<00:00,  3.00s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.04s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 9/100 (Seed: 9)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:26<00:00,  3.12s/it]\n","100%|██████████| 47/47 [02:21<00:00,  3.01s/it]\n","100%|██████████| 47/47 [02:16<00:00,  2.90s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 10/100 (Seed: 10)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:28<00:00,  3.15s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.97s/it]\n","100%|██████████| 47/47 [02:20<00:00,  3.00s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 11/100 (Seed: 11)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:21<00:00,  3.02s/it]\n","100%|██████████| 47/47 [02:27<00:00,  3.13s/it]\n","100%|██████████| 47/47 [02:21<00:00,  3.01s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 12/100 (Seed: 12)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:28<00:00,  3.17s/it]\n","100%|██████████| 47/47 [02:34<00:00,  3.28s/it]\n","100%|██████████| 47/47 [02:21<00:00,  3.01s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 13/100 (Seed: 13)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:23<00:00,  3.06s/it]\n","100%|██████████| 47/47 [02:25<00:00,  3.10s/it]\n","100%|██████████| 47/47 [02:26<00:00,  3.11s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 14/100 (Seed: 14)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:29<00:00,  3.19s/it]\n","100%|██████████| 47/47 [02:16<00:00,  2.90s/it]\n","100%|██████████| 47/47 [02:08<00:00,  2.73s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 15/100 (Seed: 15)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:11<00:00,  2.79s/it]\n","100%|██████████| 47/47 [02:04<00:00,  2.65s/it]\n","100%|██████████| 47/47 [02:06<00:00,  2.69s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 16/100 (Seed: 16)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:07<00:00,  2.72s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.97s/it]\n","100%|██████████| 47/47 [02:20<00:00,  2.99s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 17/100 (Seed: 17)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:28<00:00,  3.17s/it]\n","100%|██████████| 47/47 [02:21<00:00,  3.00s/it]\n","100%|██████████| 47/47 [02:32<00:00,  3.24s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 18/100 (Seed: 18)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:29<00:00,  3.18s/it]\n","100%|██████████| 47/47 [02:30<00:00,  3.20s/it]\n","100%|██████████| 47/47 [02:27<00:00,  3.15s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 19/100 (Seed: 19)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:30<00:00,  3.21s/it]\n","100%|██████████| 47/47 [02:28<00:00,  3.15s/it]\n","100%|██████████| 47/47 [02:24<00:00,  3.08s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 20/100 (Seed: 20)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:22<00:00,  3.02s/it]\n","100%|██████████| 47/47 [02:06<00:00,  2.70s/it]\n","100%|██████████| 47/47 [02:14<00:00,  2.85s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 21/100 (Seed: 21)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:08<00:00,  2.73s/it]\n","100%|██████████| 47/47 [02:14<00:00,  2.86s/it]\n","100%|██████████| 47/47 [02:24<00:00,  3.07s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 22/100 (Seed: 22)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:19<00:00,  2.97s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.03s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.03s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 23/100 (Seed: 23)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:25<00:00,  3.10s/it]\n","100%|██████████| 47/47 [02:24<00:00,  3.06s/it]\n","100%|██████████| 47/47 [02:25<00:00,  3.09s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 24/100 (Seed: 24)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:18<00:00,  2.95s/it]\n","100%|██████████| 47/47 [02:26<00:00,  3.11s/it]\n","100%|██████████| 47/47 [02:24<00:00,  3.07s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 25/100 (Seed: 25)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:16<00:00,  2.90s/it]\n","100%|██████████| 47/47 [02:14<00:00,  2.86s/it]\n","100%|██████████| 47/47 [02:12<00:00,  2.83s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 26/100 (Seed: 26)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:12<00:00,  2.81s/it]\n","100%|██████████| 47/47 [02:10<00:00,  2.77s/it]\n","100%|██████████| 47/47 [02:12<00:00,  2.82s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 27/100 (Seed: 27)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:15<00:00,  2.89s/it]\n","100%|██████████| 47/47 [02:20<00:00,  2.99s/it]\n","100%|██████████| 47/47 [02:20<00:00,  2.98s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 28/100 (Seed: 28)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:20<00:00,  2.99s/it]\n","100%|██████████| 47/47 [02:18<00:00,  2.94s/it]\n","100%|██████████| 47/47 [02:18<00:00,  2.95s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 29/100 (Seed: 29)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:17<00:00,  2.93s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.96s/it]\n","100%|██████████| 47/47 [02:20<00:00,  2.99s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 30/100 (Seed: 30)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:16<00:00,  2.90s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.96s/it]\n","100%|██████████| 47/47 [02:17<00:00,  2.92s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 31/100 (Seed: 31)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:12<00:00,  2.82s/it]\n","100%|██████████| 47/47 [02:14<00:00,  2.86s/it]\n","100%|██████████| 47/47 [02:23<00:00,  3.06s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 32/100 (Seed: 32)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:19<00:00,  2.98s/it]\n","100%|██████████| 47/47 [02:18<00:00,  2.94s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.97s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 33/100 (Seed: 33)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:30<00:00,  3.21s/it]\n","100%|██████████| 47/47 [02:35<00:00,  3.31s/it]\n","100%|██████████| 47/47 [02:46<00:00,  3.53s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 34/100 (Seed: 34)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:37<00:00,  3.35s/it]\n","100%|██████████| 47/47 [02:42<00:00,  3.46s/it]\n","100%|██████████| 47/47 [02:39<00:00,  3.39s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 35/100 (Seed: 35)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:28<00:00,  3.17s/it]\n","100%|██████████| 47/47 [02:26<00:00,  3.11s/it]\n","100%|██████████| 47/47 [02:20<00:00,  2.99s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 36/100 (Seed: 36)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:26<00:00,  3.11s/it]\n","100%|██████████| 47/47 [02:26<00:00,  3.13s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.97s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 37/100 (Seed: 37)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:22<00:00,  3.04s/it]\n","100%|██████████| 47/47 [02:23<00:00,  3.05s/it]\n","100%|██████████| 47/47 [02:37<00:00,  3.35s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 38/100 (Seed: 38)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:20<00:00,  2.99s/it]\n","100%|██████████| 47/47 [02:17<00:00,  2.94s/it]\n","100%|██████████| 47/47 [02:16<00:00,  2.91s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 39/100 (Seed: 39)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:31<00:00,  3.22s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.02s/it]\n","100%|██████████| 47/47 [02:14<00:00,  2.87s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 40/100 (Seed: 40)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:12<00:00,  2.82s/it]\n","100%|██████████| 47/47 [02:17<00:00,  2.92s/it]\n","100%|██████████| 47/47 [02:29<00:00,  3.17s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 41/100 (Seed: 41)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:34<00:00,  3.28s/it]\n","100%|██████████| 47/47 [02:27<00:00,  3.14s/it]\n","100%|██████████| 47/47 [02:26<00:00,  3.13s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 42/100 (Seed: 42)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:30<00:00,  3.20s/it]\n","100%|██████████| 47/47 [02:27<00:00,  3.13s/it]\n","100%|██████████| 47/47 [02:33<00:00,  3.26s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 43/100 (Seed: 43)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:25<00:00,  3.11s/it]\n","100%|██████████| 47/47 [02:16<00:00,  2.91s/it]\n","100%|██████████| 47/47 [02:25<00:00,  3.09s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 44/100 (Seed: 44)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:34<00:00,  3.29s/it]\n","100%|██████████| 47/47 [02:32<00:00,  3.24s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.03s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 45/100 (Seed: 45)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:20<00:00,  3.00s/it]\n","100%|██████████| 47/47 [02:28<00:00,  3.16s/it]\n","100%|██████████| 47/47 [02:27<00:00,  3.14s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 46/100 (Seed: 46)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:24<00:00,  3.08s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.03s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.04s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 47/100 (Seed: 47)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:23<00:00,  3.06s/it]\n","100%|██████████| 47/47 [02:27<00:00,  3.15s/it]\n","100%|██████████| 47/47 [02:42<00:00,  3.47s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 48/100 (Seed: 48)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:29<00:00,  3.18s/it]\n","100%|██████████| 47/47 [02:09<00:00,  2.76s/it]\n","100%|██████████| 47/47 [02:17<00:00,  2.93s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 49/100 (Seed: 49)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:06<00:00,  2.69s/it]\n","100%|██████████| 47/47 [02:06<00:00,  2.68s/it]\n","100%|██████████| 47/47 [02:07<00:00,  2.71s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 50/100 (Seed: 50)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:11<00:00,  2.81s/it]\n","100%|██████████| 47/47 [02:12<00:00,  2.81s/it]\n","100%|██████████| 47/47 [02:07<00:00,  2.71s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 51/100 (Seed: 51)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:09<00:00,  2.75s/it]\n","100%|██████████| 47/47 [02:07<00:00,  2.71s/it]\n","100%|██████████| 47/47 [02:05<00:00,  2.68s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 52/100 (Seed: 52)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:06<00:00,  2.68s/it]\n","100%|██████████| 47/47 [02:06<00:00,  2.68s/it]\n","100%|██████████| 47/47 [02:07<00:00,  2.72s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 53/100 (Seed: 53)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:05<00:00,  2.67s/it]\n","100%|██████████| 47/47 [02:04<00:00,  2.66s/it]\n","100%|██████████| 47/47 [02:03<00:00,  2.63s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 54/100 (Seed: 54)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:03<00:00,  2.62s/it]\n","100%|██████████| 47/47 [02:08<00:00,  2.73s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.02s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 55/100 (Seed: 55)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:21<00:00,  3.00s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.96s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.96s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 56/100 (Seed: 56)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:21<00:00,  3.01s/it]\n","100%|██████████| 47/47 [02:24<00:00,  3.07s/it]\n","100%|██████████| 47/47 [02:25<00:00,  3.11s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 57/100 (Seed: 57)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:23<00:00,  3.04s/it]\n","100%|██████████| 47/47 [02:21<00:00,  3.02s/it]\n","100%|██████████| 47/47 [02:14<00:00,  2.87s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 58/100 (Seed: 58)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:11<00:00,  2.80s/it]\n","100%|██████████| 47/47 [02:06<00:00,  2.68s/it]\n","100%|██████████| 47/47 [02:21<00:00,  3.00s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 59/100 (Seed: 59)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:15<00:00,  2.89s/it]\n","100%|██████████| 47/47 [02:26<00:00,  3.12s/it]\n","100%|██████████| 47/47 [02:14<00:00,  2.86s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 60/100 (Seed: 60)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:20<00:00,  2.99s/it]\n","100%|██████████| 47/47 [02:25<00:00,  3.09s/it]\n","100%|██████████| 47/47 [02:21<00:00,  3.01s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 61/100 (Seed: 61)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:23<00:00,  3.05s/it]\n","100%|██████████| 47/47 [02:24<00:00,  3.08s/it]\n","100%|██████████| 47/47 [02:21<00:00,  3.00s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 62/100 (Seed: 62)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:21<00:00,  3.00s/it]\n","100%|██████████| 47/47 [02:17<00:00,  2.93s/it]\n","100%|██████████| 47/47 [02:24<00:00,  3.08s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 63/100 (Seed: 63)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:27<00:00,  3.13s/it]\n","100%|██████████| 47/47 [02:26<00:00,  3.12s/it]\n","100%|██████████| 47/47 [02:24<00:00,  3.08s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 64/100 (Seed: 64)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:10<00:00,  2.77s/it]\n","100%|██████████| 47/47 [02:04<00:00,  2.65s/it]\n","100%|██████████| 47/47 [02:04<00:00,  2.64s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 65/100 (Seed: 65)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:07<00:00,  2.70s/it]\n","100%|██████████| 47/47 [02:05<00:00,  2.68s/it]\n","100%|██████████| 47/47 [02:06<00:00,  2.68s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 66/100 (Seed: 66)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:05<00:00,  2.68s/it]\n","100%|██████████| 47/47 [02:05<00:00,  2.67s/it]\n","100%|██████████| 47/47 [02:06<00:00,  2.70s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 67/100 (Seed: 67)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:06<00:00,  2.69s/it]\n","100%|██████████| 47/47 [02:05<00:00,  2.67s/it]\n","100%|██████████| 47/47 [02:05<00:00,  2.67s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 68/100 (Seed: 68)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:05<00:00,  2.66s/it]\n","100%|██████████| 47/47 [02:26<00:00,  3.12s/it]\n","100%|██████████| 47/47 [02:29<00:00,  3.17s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 69/100 (Seed: 69)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:25<00:00,  3.10s/it]\n","100%|██████████| 47/47 [02:17<00:00,  2.92s/it]\n","100%|██████████| 47/47 [02:04<00:00,  2.66s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 70/100 (Seed: 70)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:05<00:00,  2.68s/it]\n","100%|██████████| 47/47 [02:05<00:00,  2.67s/it]\n","100%|██████████| 47/47 [02:07<00:00,  2.71s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 71/100 (Seed: 71)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:05<00:00,  2.67s/it]\n","100%|██████████| 47/47 [02:06<00:00,  2.70s/it]\n","100%|██████████| 47/47 [02:04<00:00,  2.66s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 72/100 (Seed: 72)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:06<00:00,  2.69s/it]\n","100%|██████████| 47/47 [02:07<00:00,  2.72s/it]\n","100%|██████████| 47/47 [02:03<00:00,  2.63s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 73/100 (Seed: 73)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:04<00:00,  2.64s/it]\n","100%|██████████| 47/47 [02:18<00:00,  2.94s/it]\n","100%|██████████| 47/47 [02:23<00:00,  3.06s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 74/100 (Seed: 74)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:22<00:00,  3.03s/it]\n","100%|██████████| 47/47 [02:17<00:00,  2.92s/it]\n","100%|██████████| 47/47 [02:06<00:00,  2.68s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 75/100 (Seed: 75)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:06<00:00,  2.69s/it]\n","100%|██████████| 47/47 [02:04<00:00,  2.66s/it]\n","100%|██████████| 47/47 [02:03<00:00,  2.62s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 76/100 (Seed: 76)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:02<00:00,  2.61s/it]\n","100%|██████████| 47/47 [02:04<00:00,  2.64s/it]\n","100%|██████████| 47/47 [02:07<00:00,  2.70s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 77/100 (Seed: 77)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:15<00:00,  2.89s/it]\n","100%|██████████| 47/47 [02:23<00:00,  3.05s/it]\n","100%|██████████| 47/47 [02:15<00:00,  2.88s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 78/100 (Seed: 78)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:24<00:00,  3.08s/it]\n","100%|██████████| 47/47 [02:27<00:00,  3.14s/it]\n","100%|██████████| 47/47 [02:21<00:00,  3.01s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 79/100 (Seed: 79)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:17<00:00,  2.92s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.97s/it]\n","100%|██████████| 47/47 [02:17<00:00,  2.93s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 80/100 (Seed: 80)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:23<00:00,  3.06s/it]\n","100%|██████████| 47/47 [02:20<00:00,  2.98s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.02s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 81/100 (Seed: 81)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:21<00:00,  3.01s/it]\n","100%|██████████| 47/47 [02:13<00:00,  2.85s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.97s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 82/100 (Seed: 82)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:15<00:00,  2.88s/it]\n","100%|██████████| 47/47 [02:23<00:00,  3.06s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.04s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 83/100 (Seed: 83)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:19<00:00,  2.97s/it]\n","100%|██████████| 47/47 [02:23<00:00,  3.06s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.04s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 84/100 (Seed: 84)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:22<00:00,  3.04s/it]\n","100%|██████████| 47/47 [02:26<00:00,  3.12s/it]\n","100%|██████████| 47/47 [02:27<00:00,  3.14s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 85/100 (Seed: 85)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:27<00:00,  3.14s/it]\n","100%|██████████| 47/47 [02:30<00:00,  3.21s/it]\n","100%|██████████| 47/47 [02:31<00:00,  3.23s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 86/100 (Seed: 86)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:29<00:00,  3.18s/it]\n","100%|██████████| 47/47 [02:29<00:00,  3.18s/it]\n","100%|██████████| 47/47 [02:24<00:00,  3.07s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 87/100 (Seed: 87)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:26<00:00,  3.12s/it]\n","100%|██████████| 47/47 [02:23<00:00,  3.06s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.97s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 88/100 (Seed: 88)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:20<00:00,  2.99s/it]\n","100%|██████████| 47/47 [02:20<00:00,  2.99s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.97s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 89/100 (Seed: 89)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:22<00:00,  3.04s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.97s/it]\n","100%|██████████| 47/47 [02:16<00:00,  2.90s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 90/100 (Seed: 90)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:22<00:00,  3.03s/it]\n","100%|██████████| 47/47 [02:27<00:00,  3.13s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.03s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 91/100 (Seed: 91)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:20<00:00,  2.99s/it]\n","100%|██████████| 47/47 [02:21<00:00,  3.02s/it]\n","100%|██████████| 47/47 [02:25<00:00,  3.10s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 92/100 (Seed: 92)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:13<00:00,  2.84s/it]\n","100%|██████████| 47/47 [02:23<00:00,  3.05s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.97s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 93/100 (Seed: 93)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:19<00:00,  2.96s/it]\n","100%|██████████| 47/47 [02:17<00:00,  2.93s/it]\n","100%|██████████| 47/47 [02:18<00:00,  2.95s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 94/100 (Seed: 94)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:21<00:00,  3.02s/it]\n","100%|██████████| 47/47 [02:19<00:00,  2.98s/it]\n","100%|██████████| 47/47 [02:16<00:00,  2.90s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 95/100 (Seed: 95)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:27<00:00,  3.13s/it]\n","100%|██████████| 47/47 [02:27<00:00,  3.13s/it]\n","100%|██████████| 47/47 [02:20<00:00,  3.00s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 96/100 (Seed: 96)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:26<00:00,  3.11s/it]\n","100%|██████████| 47/47 [02:34<00:00,  3.28s/it]\n","100%|██████████| 47/47 [02:13<00:00,  2.84s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 97/100 (Seed: 97)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:05<00:00,  2.66s/it]\n","100%|██████████| 47/47 [02:04<00:00,  2.66s/it]\n","100%|██████████| 47/47 [02:06<00:00,  2.69s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 98/100 (Seed: 98)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:08<00:00,  2.73s/it]\n","100%|██████████| 47/47 [02:04<00:00,  2.65s/it]\n","100%|██████████| 47/47 [02:29<00:00,  3.17s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 99/100 (Seed: 99)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:36<00:00,  3.33s/it]\n","100%|██████████| 47/47 [02:12<00:00,  2.82s/it]\n","100%|██████████| 47/47 [02:29<00:00,  3.19s/it]"]},{"name":"stdout","output_type":"stream","text":["\n","[Progress] Processing Simulation 100/100 (Seed: 100)\n"]},{"name":"stderr","output_type":"stream","text":["\n","100%|██████████| 47/47 [02:28<00:00,  3.16s/it]\n","100%|██████████| 47/47 [02:22<00:00,  3.02s/it]\n","100%|██████████| 47/47 [02:37<00:00,  3.36s/it]\n"]},{"name":"stdout","output_type":"stream","text":[">>> All simulations completed successfully.\n","\n","============================================================\n","RESULTS SUMMARY: K=100 MONTE CARLO SIMULATIONS\n","============================================================\n","Method: KNN (Optimized Bandwidth)\n","  - Mean MISE: 2.986076\n","  - Std Dev:   2.047365\n","  - Std Error: 0.204737\n","\n","Saved Stage-2 beta estimates to: /content/drive/MyDrive/Colab Notebooks/CTE_Baseline/DML_methods/Empirical Application/Estimates/estimates_KNN_seed1_to_seed100.csv\n","Saved MISE-only table to: /content/drive/MyDrive/Colab Notebooks/CTE_Baseline/DML_methods/Empirical Application/Estimates/MISE_KNN_seed1_to_seed100.csv\n"]}],"source":["# -*- coding: utf-8 -*-\n","\"\"\"\n","Empirical Application: Job Corps Analysis using Double ML for Continuous Treatment (DDMLCT).\n","\n","KNN version (uses Supplement.NN_DDMLCT).\n","\n","GitHub-friendly adjustments:\n","- English comments\n","- No plots\n","- Progress prints cleanly even if tqdm is used internally\n","\n","New: Save outputs to the same RESULTS_DIR format as the LASSO script:\n","  1) estimates_KNN_seed{first}_to_seed{last}.csv  (Stage-2 beta estimates, all seeds + mean/se)\n","  2) MISE_KNN_seed{first}_to_seed{last}.csv       (Stage-2 MISE only, all seeds + mean/se)\n","  3) (optional) estimates_stage1_KNN_seed{first}_to_seed{last}.csv (Stage-1 beta, all seeds + mean/se)\n","\"\"\"\n","\n","import sys\n","import pathlib\n","import logging\n","\n","import Supplement\n","import numpy as np\n","import pandas as pd\n","from sklearn import linear_model\n","\n","# ============================================================\n","# 0) Output Directory Setup (match your LASSO script)\n","# ============================================================\n","try:\n","    from google.colab import drive  # type: ignore\n","    drive.mount(\"/content/drive\")\n","    BASE_DIR = pathlib.Path(\"/content/drive/MyDrive/Colab Notebooks/CTE_Baseline/DML_methods\")\n","except Exception:\n","    BASE_DIR = pathlib.Path(\".\").resolve()\n","\n","# Ensure Supplement import path (same spirit as your other script)\n","sys.path.append(str(BASE_DIR))\n","SUPP_DIR = BASE_DIR / \"Supplement\"\n","if SUPP_DIR.exists():\n","    sys.path.append(str(SUPP_DIR))\n","\n","RESULTS_DIR = BASE_DIR / \"Data_and_Results\" / \"Estimates\"\n","RESULTS_DIR.mkdir(parents=True, exist_ok=True)\n","\n","print(f\"Working Directory: {BASE_DIR}\")\n","print(f\"Results Directory: {RESULTS_DIR}\")\n","\n","# ============================================================\n","# 1) Configuration & Path Setup\n","# ============================================================\n","K_SIM = 100\n","BASE_SEED = 1\n","\n","logging.basicConfig(\n","    level=logging.INFO,\n","    format=\"%(asctime)sZ | %(levelname)s | %(filename)s:%(lineno)d | %(message)s\",\n","    datefmt=\"%Y-%m-%dT%H:%M:%S\",\n",")\n","logger = logging.getLogger(__name__)\n","\n","EMP_DIR = BASE_DIR / \"Data_and_Results\"\n","current_path = pathlib.Path(EMP_DIR)\n","\n","# ============================================================\n","# 2) Helper Functions\n","# ============================================================\n","def gen_semi_y(mu_hat: np.ndarray, g: np.ndarray, rng: np.random.Generator) -> np.ndarray:\n","    n = len(mu_hat)\n","    e = rng.choice([-1.0, 1.0], size=n)\n","    return mu_hat + e * g\n","\n","\n","def mise_against(grid_t, est_beta, h_star_vals) -> float:\n","    return float(np.mean((np.asarray(est_beta) - np.asarray(h_star_vals)) ** 2))\n","\n","\n","def summarize_list(x_list):\n","    arr = np.asarray(x_list, dtype=float)\n","    mean = float(arr.mean()) if len(arr) > 0 else 0.0\n","    std = float(arr.std(ddof=1)) if len(arr) > 1 else 0.0\n","    se = float(std / np.sqrt(len(arr))) if len(arr) > 0 else 0.0\n","    return mean, std, se\n","\n","\n","# ============================================================\n","# 3) Data Loading & Preprocessing\n","# ============================================================\n","data_file = current_path / \"emp_app.csv\"\n","logger.info(f\"Loading data: {data_file}\")\n","data = pd.read_csv(data_file, index_col=0)\n","\n","data = data.sample(frac=1, random_state=20)\n","\n","data = pd.concat(\n","    [\n","        data.select_dtypes(exclude=\"int64\"),\n","        pd.get_dummies(\n","            data.select_dtypes(\"int64\").astype(\"category\"),\n","            drop_first=True,\n","            dtype=float,\n","        ),\n","    ],\n","    axis=1,\n",")\n","\n","X = data.drop([\"d\", \"y\"], axis=1)\n","T = data[\"d\"]\n","Y = data[\"y\"]\n","n_obs = len(Y)\n","\n","semi_file = current_path / \"semi-syn data grf.csv\"\n","logger.info(f\"Loading semi-synthetic components: {semi_file}\")\n","semi_df = pd.read_csv(semi_file, index_col=0)\n","mu_hat = semi_df[\"mu_hat_grf\"].to_numpy()\n","g = semi_df[\"g_grf\"].to_numpy()\n","\n","# ============================================================\n","# 4) Model Definition & Hyperparameters\n","# ============================================================\n","models = {\n","    \"lasso\": [\n","        linear_model.Lasso(alpha=0.00069944, max_iter=10000),\n","        linear_model.Lasso(alpha=0.000160472, max_iter=10000),\n","    ],\n","    \"nn\": [\n","        Supplement.NeuralNet1_emp_app(k=139, lr=0.15, momentum=0.9, epochs=100, weight_decay=0.05),\n","        Supplement.NeuralNet2_emp_app(k=138, lr=0.05, momentum=0.3, epochs=100, weight_decay=0.15),\n","    ],\n","    \"knn\": [\n","        Supplement.NeuralNet1k_emp_app(k=138, lr=0.15, momentum=0.9, epochs=100, weight_decay=0.05),\n","        Supplement.NeuralNet2_emp_app(k=138, lr=0.05, momentum=0.3, epochs=100, weight_decay=0.15),\n","    ],\n","}\n","\n","basis_map = {\"lasso\": True, \"nn\": False, \"knn\": False}\n","\n","t_list = np.arange(160, 2001, 40)\n","h_rule = np.std(T) * 3 * (n_obs ** (-0.2))\n","h_first = 2 * h_rule\n","L = 5\n","ml_list = [\"knn\"]\n","u = 0.5\n","\n","h_star_file = current_path / \"h_star_grf_empapp.csv\"\n","h_df = pd.read_csv(h_star_file)\n","h_star_vals = h_df[\"h_star\"].to_numpy()\n","\n","# Storage\n","first_stage_mise = {ml: [] for ml in ml_list}\n","second_stage_mise = {ml: [] for ml in ml_list}\n","\n","# NEW: store beta estimates too\n","first_stage_beta = {ml: [] for ml in ml_list}   # Stage 1 betas\n","second_stage_beta = {ml: [] for ml in ml_list}  # Stage 2 betas\n","\n","# ============================================================\n","# 5) Simulation Loop\n","# ============================================================\n","seed_list = [BASE_SEED + k for k in range(K_SIM)]\n","print(f\"\\n>>> Starting {K_SIM} Monte Carlo simulations...\")\n","\n","for k, seed_k in enumerate(seed_list):\n","    print(\"\", flush=True)\n","    print(f\"[Progress] Processing Simulation {k + 1}/{K_SIM} (Seed: {seed_k})\", flush=True)\n","\n","    rng_sim = np.random.default_rng(seed_k)\n","    Y_syn = gen_semi_y(mu_hat, g, rng_sim)\n","\n","    perm = rng_sim.permutation(n_obs)\n","    X_k = X.iloc[perm].reset_index(drop=True)\n","    T_k = T.iloc[perm].reset_index(drop=True)\n","    Y_k = Y_syn[perm]\n","\n","    for ml in ml_list:\n","        DDML_Wrapper = Supplement.NN_DDMLCT if ml == \"knn\" else Supplement.DDMLCT\n","\n","        # Stage 1\n","        m1 = DDML_Wrapper(models[ml][0], models[ml][1])\n","        m1.fit(X_k, T_k, Y_k, t_list, L, h=h_first, basis=basis_map[ml], standardize=True)\n","\n","        m2 = DDML_Wrapper(models[ml][0], models[ml][1])\n","        m2.fit(X_k, T_k, Y_k, t_list, L, h=h_first * u, basis=basis_map[ml], standardize=True)\n","\n","        Bt = (m1.beta - m2.beta) / ((m1.h ** 2) * (1 - (u ** 2)))\n","        h_star_ml = np.mean(((m2.Vt / (4 * (Bt ** 2))) ** 0.2) * (m1.n ** -0.2))\n","\n","        # Store Stage-1 outputs\n","        first_stage_mise[ml].append(mise_against(t_list, m1.beta, h_star_vals))\n","        first_stage_beta[ml].append(np.asarray(m1.beta, dtype=float))\n","\n","        # Stage 2\n","        h_second = 0.8 * h_star_ml\n","        m_final = DDML_Wrapper(models[ml][0], models[ml][1])\n","        m_final.fit(X_k, T_k, Y_k, t_list, L, h=h_second, basis=basis_map[ml], standardize=True)\n","\n","        second_stage_mise[ml].append(mise_against(t_list, m_final.beta, h_star_vals))\n","        second_stage_beta[ml].append(np.asarray(m_final.beta, dtype=float))\n","\n","print(\">>> All simulations completed successfully.\\n\")\n","\n","# ============================================================\n","# 6) Results Summary (Stage 2 Focus)\n","# ============================================================\n","print(\"=\" * 60)\n","print(f\"RESULTS SUMMARY: K={K_SIM} MONTE CARLO SIMULATIONS\")\n","print(\"=\" * 60)\n","\n","for ml in ml_list:\n","    mean2, std2, se2 = summarize_list(second_stage_mise[ml])\n","    print(f\"Method: {ml.upper()} (Optimized Bandwidth)\")\n","    print(f\"  - Mean MISE: {mean2:.6f}\")\n","    print(f\"  - Std Dev:   {std2:.6f}\")\n","    print(f\"  - Std Error: {se2:.6f}\\n\")\n","\n","logger.info(\"Summary printing finished.\")\n","\n","# ============================================================\n","# 7) Save beta estimates + MISE in requested filename format\n","# ============================================================\n","first_seed = seed_list[0]\n","last_seed = seed_list[-1]\n","t_cols = [f\"t_{int(t)}\" for t in t_list]\n","\n","for ml in ml_list:\n","    tag = \"KNN\" if ml == \"knn\" else ml.upper()\n","\n","    # ---- Stage 2 beta estimates (MAIN) ----\n","    beta2_mat = np.vstack(second_stage_beta[ml])\n","    df_beta2 = pd.DataFrame(beta2_mat, columns=t_cols)\n","    df_beta2.insert(0, \"seed\", seed_list)\n","\n","    mean_row2 = pd.DataFrame([beta2_mat.mean(axis=0)], columns=t_cols)\n","    mean_row2.insert(0, \"seed\", \"mean\")\n","\n","    se_row2 = pd.DataFrame(\n","        [beta2_mat.std(axis=0, ddof=1) / np.sqrt(len(seed_list))],\n","        columns=t_cols,\n","    )\n","    se_row2.insert(0, \"seed\", \"se\")\n","\n","    df_beta2_final = pd.concat([df_beta2, mean_row2, se_row2], ignore_index=True)\n","\n","    out_beta2 = RESULTS_DIR / f\"estimates_{tag}_seed{first_seed}_to_seed{last_seed}.csv\"\n","    df_beta2_final.to_csv(out_beta2, index=False)\n","    print(f\"Saved Stage-2 beta estimates to: {out_beta2}\")\n","\n","    # ---- Stage 2 MISE only (requested) ----\n","    mise_list = second_stage_mise[ml]\n","    df_mise = pd.DataFrame({\"seed\": seed_list, \"mise\": mise_list})\n","\n","    mise_mean, _, mise_se = summarize_list(mise_list)\n","    df_mise_summary = pd.DataFrame(\n","        [\n","            {\"seed\": \"mean\", \"mise\": mise_mean},\n","            {\"seed\": \"se\", \"mise\": mise_se},\n","        ]\n","    )\n","\n","    df_mise_final = pd.concat([df_mise, df_mise_summary], ignore_index=True)\n","\n","    out_mise = RESULTS_DIR / f\"MISE_{tag}_seed{first_seed}_to_seed{last_seed}.csv\"\n","    df_mise_final.to_csv(out_mise, index=False)\n","    print(f\"Saved MISE-only table to: {out_mise}\")\n","\n","logger.info(\"Execution finished.\")\n"]}],"metadata":{"colab":{"toc_visible":true,"provenance":[],"authorship_tag":"ABX9TyM1xwWUhfv0Li7koRrErhlz"},"kernelspec":{"display_name":"Python 3","name":"python3"},"language_info":{"name":"python"}},"nbformat":4,"nbformat_minor":0}