{"cells":[{"cell_type":"code","execution_count":1,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":17338,"status":"ok","timestamp":1767753535087,"user":{"displayName":"D K","userId":"02556183042422178006"},"user_tz":-540},"id":"PdT-NG4N5qb5","outputId":"04e960da-3e4a-4fcd-ecb6-dd1eb9810d1c"},"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":2,"metadata":{"executionInfo":{"elapsed":2361,"status":"ok","timestamp":1767753537451,"user":{"displayName":"D K","userId":"02556183042422178006"},"user_tz":-540},"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":"o_B5EEepjKw0"},"outputs":[{"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"]},{"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":["Working Directory: /content/drive/MyDrive/Colab Notebooks/CTE_Baseline/DML_methods\n","Results Directory: /content/drive/MyDrive/Colab Notebooks/CTE_Baseline/DML_methods/Data_and_Results/Estimates\n","\n","[Progress] Processing Simulation 1/100 (Seed: 1)\n"]},{"name":"stderr","output_type":"stream","text":["100%|██████████| 47/47 [01:50\u003c00:00,  2.35s/it]\n","100%|██████████| 47/47 [01:48\u003c00:00,  2.30s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.28s/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 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.29s/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 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.28s/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 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.28s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/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 [01:46\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:50\u003c00:00,  2.35s/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 [01:49\u003c00:00,  2.34s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.28s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/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 [01:45\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/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 [01:42\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/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 [01:42\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.20s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.20s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.26s/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 [01:48\u003c00:00,  2.30s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/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 [01:42\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:42\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.21s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.21s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.26s/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 [01:46\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/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 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.20s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.21s/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 [01:43\u003c00:00,  2.20s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.29s/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 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:48\u003c00:00,  2.31s/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 [01:47\u003c00:00,  2.28s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.29s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:51\u003c00:00,  2.38s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.30s/it]\n","100%|██████████| 47/47 [01:49\u003c00:00,  2.33s/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 [01:46\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/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 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.26s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:46\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.21s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.28s/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 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/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 [01:47\u003c00:00,  2.29s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/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 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:47\u003c00:00,  2.29s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.28s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/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 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.21s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/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 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.21s/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 [01:43\u003c00:00,  2.20s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.28s/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 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.21s/it]\n","100%|██████████| 47/47 [01:42\u003c00:00,  2.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 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/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 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:42\u003c00:00,  2.18s/it]\n","100%|██████████| 47/47 [01:42\u003c00:00,  2.18s/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 [01:44\u003c00:00,  2.21s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.21s/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 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/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 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:49\u003c00:00,  2.33s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/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 [01:42\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.21s/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 [01:50\u003c00:00,  2.35s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:48\u003c00:00,  2.31s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/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 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.21s/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 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/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 [01:41\u003c00:00,  2.16s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.26s/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 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:43\u003c00:00,  2.21s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.21s/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 [01:44\u003c00:00,  2.21s/it]\n","100%|██████████| 47/47 [01:42\u003c00:00,  2.17s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.28s/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 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.20s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/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 [01:46\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.28s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.28s/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 [01:47\u003c00:00,  2.28s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.29s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.29s/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 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/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 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:42\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/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 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.28s/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 [01:47\u003c00:00,  2.29s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.20s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/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 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.19s/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 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.21s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/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 [01:43\u003c00:00,  2.20s/it]\n","100%|██████████| 47/47 [01:41\u003c00:00,  2.17s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/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 [01:47\u003c00:00,  2.29s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.26s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.23s/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 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:42\u003c00:00,  2.18s/it]\n","100%|██████████| 47/47 [01:41\u003c00:00,  2.16s/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 [01:41\u003c00:00,  2.17s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.26s/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 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/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 [01:48\u003c00:00,  2.30s/it]\n","100%|██████████| 47/47 [01:48\u003c00:00,  2.30s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:41\u003c00:00,  2.17s/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 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.21s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:47\u003c00:00,  2.29s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.21s/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 [01:45\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:47\u003c00:00,  2.29s/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 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:42\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:47\u003c00:00,  2.29s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.21s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.21s/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 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/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 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.21s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.20s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.21s/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 [01:43\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:42\u003c00:00,  2.18s/it]\n","100%|██████████| 47/47 [01:41\u003c00:00,  2.15s/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 [01:43\u003c00:00,  2.20s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:42\u003c00:00,  2.18s/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 [01:46\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/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 [01:43\u003c00:00,  2.21s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.20s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.20s/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 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.19s/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 [01:43\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:42\u003c00:00,  2.19s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/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 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.20s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.21s/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 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:48\u003c00:00,  2.32s/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 [01:48\u003c00:00,  2.31s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.27s/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 [01:45\u003c00:00,  2.25s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/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 [01:42\u003c00:00,  2.18s/it]\n","100%|██████████| 47/47 [01:45\u003c00:00,  2.24s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:49\u003c00:00,  2.34s/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 [01:44\u003c00:00,  2.23s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/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 [01:44\u003c00:00,  2.22s/it]\n","100%|██████████| 47/47 [01:46\u003c00:00,  2.26s/it]\n","100%|██████████| 47/47 [01:44\u003c00:00,  2.23s/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 [01:42\u003c00:00,  2.18s/it]\n","100%|██████████| 47/47 [01:43\u003c00:00,  2.20s/it]\n","100%|██████████| 47/47 [01:42\u003c00:00,  2.19s/it]\n"]},{"name":"stdout","output_type":"stream","text":["\n","==================================================\n","RESULTS (NN, K=100) - Second Stage Only\n","==================================================\n","Method: NN\n","  [Stage 2: h = 0.8 * h_star_ml]\n","    Mean MISE : 1.996992\n","    Std MISE  : 1.391640\n","    SE MISE   : 0.139164\n","==================================================\n","\n","Saved Stage-2 beta estimates to: /content/drive/MyDrive/Colab Notebooks/CTE_Baseline/DML_methods/Data_and_Results/Estimates/estimates_NN_seed1_to_seed100.csv\n","Saved MISE-only table to: /content/drive/MyDrive/Colab Notebooks/CTE_Baseline/DML_methods/Data_and_Results/Estimates/MISE_NN_seed1_to_seed100.csv\n"]}],"source":["# -*- coding: utf-8 -*-\n","\"\"\"\n","Empirical Application: Job Corps (DDMLCT) — NN version\n","\n","What this script saves (to RESULTS_DIR):\n","1) estimates_NN_seed{first}_to_seed{last}.csv\n","   - Stage-2 beta(t) estimates for every simulation seed\n","   - plus summary rows: mean, se\n","\n","2) MISE_NN_seed{first}_to_seed{last}.csv\n","   - MISE per seed (Stage-2 only)\n","   - plus summary rows: mean, se\n","\n","(Optional)\n","3) estimates_stage1_NN_seed{first}_to_seed{last}.csv\n","   - Stage-1 beta(t) estimates for every simulation seed\n","   - plus summary rows: mean, se\n","\"\"\"\n","\n","import os\n","import sys\n","import pathlib\n","import logging\n","import numpy as np\n","import pandas as pd\n","\n","# --- Environment Setup (Colab optional) ---\n","try:\n","    from google.colab import drive  # type: ignore\n","    drive.mount(\"/content/drive\")\n","    BASE_DIR = pathlib.Path(\n","        \"/content/drive/MyDrive/Colab Notebooks/CTE_Baseline/DML_methods\"\n","    )\n","except Exception:\n","    BASE_DIR = pathlib.Path(\".\").resolve()\n","\n","# Add working directory and Supplement package to path\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","# Ensure Supplement package is importable\n","try:\n","    import Supplement\n","except ImportError:\n","    # Create __init__.py shim if missing\n","    if SUPP_DIR.exists() and not (SUPP_DIR / \"__init__.py\").exists():\n","        with open(SUPP_DIR / \"__init__.py\", \"w\") as f:\n","            f.write(\"from .estimation import *\\n\")\n","    import Supplement\n","\n","# Logging Setup\n","logging.basicConfig(level=logging.INFO, format=\"%(asctime)s | %(message)s\", datefmt=\"%H:%M:%S\")\n","logger = logging.getLogger(__name__)\n","\n","# Output Directories (same style as your LASSO script)\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) Data Loading \u0026 Helpers\n","# ===========================================================\n","def load_jobcorps_data():\n","    emp_dir = BASE_DIR / \"Data_and_Results\"\n","    data_path = emp_dir / \"emp_app.csv\"\n","    semi_path = emp_dir / \"semi-syn data grf.csv\"\n","    h_star_path = emp_dir / \"h_star_grf_empapp.csv\"\n","\n","    logger.info(\"Loading emp_app.csv...\")\n","    data = pd.read_csv(data_path, index_col=0)\n","\n","    # Consistent shuffling (fixed seed)\n","    data = data.sample(frac=1, random_state=20)\n","\n","    # One-hot encoding (match your baseline)\n","    data = pd.concat(\n","        [\n","            data.select_dtypes(exclude=[\"int64\"]),\n","            pd.get_dummies(\n","                data.select_dtypes(include=[\"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_emp = data[\"y\"]\n","\n","    logger.info(\"Loading semi-synthetic components...\")\n","    semi_df = pd.read_csv(semi_path, index_col=0)\n","    if not np.array_equal(semi_df.index.values, data.index.values):\n","        semi_df = semi_df.loc[data.index]\n","\n","    mu_hat = semi_df[\"mu_hat_grf\"].to_numpy()\n","    g = semi_df[\"g_grf\"].to_numpy()\n","\n","    logger.info(\"Loading h_star ground truth...\")\n","    h_star_df = pd.read_csv(h_star_path)\n","\n","    # The file may contain a t column; keep it if present\n","    if \"t\" in h_star_df.columns:\n","        t_grid = h_star_df[\"t\"].to_numpy()\n","    else:\n","        # Fallback to your original grid if t is not present\n","        t_grid = np.arange(160, 2001, 40)\n","\n","    h_star_vals = h_star_df[\"h_star\"].to_numpy()\n","\n","    return X, T, Y_emp, mu_hat, g, t_grid, h_star_vals\n","\n","\n","def gen_semi_y(mu_hat, g, rng):\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(est_beta, h_star_vals):\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) \u003e 0 else 0.0\n","    std = float(arr.std(ddof=1)) if len(arr) \u003e 1 else 0.0\n","    se = float(std / np.sqrt(len(arr))) if len(arr) \u003e 0 else 0.0\n","    return mean, std, se\n","\n","\n","# ===========================================================\n","# 2) Main Simulation Function (NN)\n","# ===========================================================\n","def run_nn_simulation(K_runs=100, base_seed=1):\n","    # Load data\n","    X, T, _, mu_hat, g, t_list, h_star_vals = load_jobcorps_data()\n","    n_obs = len(T)\n","\n","    # Match your original hyperparams/config\n","    h_rule = np.std(T) * 3 * (n_obs ** (-0.2))\n","    h_first = 2 * h_rule\n","    L, u = 5, 0.5\n","\n","    # NN models (keep exactly as in your NN script)\n","    model_nn1 = Supplement.NeuralNet1_emp_app(\n","        k=139, lr=0.15, momentum=0.9, epochs=100, weight_decay=0.05\n","    )\n","    model_nn2 = Supplement.NeuralNet2_emp_app(\n","        k=138, lr=0.05, momentum=0.3, epochs=100, weight_decay=0.15\n","    )\n","\n","    # Storage\n","    seeds = []\n","    stage1_beta = []\n","    stage2_beta = []\n","    stage2_mise = []\n","\n","    logger.info(f\"Starting {K_runs} simulations (NN)...\")\n","\n","    for k in range(K_runs):\n","        seed = base_seed + k\n","        seeds.append(seed)\n","\n","        # Ensure progress prints cleanly even if tqdm exists inside Supplement\n","        print(\"\", flush=True)\n","        print(f\"[Progress] Processing Simulation {k+1}/{K_runs} (Seed: {seed})\", flush=True)\n","\n","        rng_sim = np.random.default_rng(seed)\n","\n","        # Generate and shuffle (match your original flow)\n","        Y_syn = gen_semi_y(mu_hat, g, rng_sim)\n","        perm = rng_sim.permutation(n_obs)\n","\n","        X_k = X.iloc[perm].reset_index(drop=True)\n","        T_k = T.iloc[perm].reset_index(drop=True)\n","        Y_k = np.asarray(Y_syn[perm], float)\n","\n","        # Stage 1: two bandwidth fits\n","        DDML_Class = Supplement.DDMLCT  # NN uses DDMLCT (not NN_DDMLCT)\n","\n","        m1 = DDML_Class(model_nn1, model_nn2)\n","        m1.fit(X_k, T_k, Y_k, t_list, L, h=h_first, basis=False, standardize=True)\n","\n","        m2 = DDML_Class(model_nn1, model_nn2)\n","        m2.fit(X_k, T_k, Y_k, t_list, L, h=h_first * u, basis=False, standardize=True)\n","\n","        # Bandwidth selection\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","        # Save Stage-1 beta (the one at h_first) if you want it\n","        stage1_beta.append(np.asarray(m1.beta, dtype=float))\n","\n","        # Stage 2: final fit with optimized bandwidth\n","        h_second = 0.8 * h_star_ml\n","        m_final = DDML_Class(model_nn1, model_nn2)\n","        m_final.fit(X_k, T_k, Y_k, t_list, L, h=h_second, basis=False, standardize=True)\n","\n","        beta2 = np.asarray(m_final.beta, dtype=float)\n","        stage2_beta.append(beta2)\n","\n","        mise2 = mise_against(beta2, h_star_vals)\n","        stage2_mise.append(mise2)\n","\n","        if (k + 1) % 10 == 0:\n","            logger.info(f\"Simulation {k+1}/{K_runs} completed.\")\n","\n","    # Print Stage-2 MISE summary (console)\n","    mean2, std2, se2 = summarize_list(stage2_mise)\n","    print(\"\\n\" + \"=\" * 50)\n","    print(f\"RESULTS (NN, K={K_runs}) - Second Stage Only\")\n","    print(\"=\" * 50)\n","    print(\"Method: NN\")\n","    print(\"  [Stage 2: h = 0.8 * h_star_ml]\")\n","    print(f\"    Mean MISE : {mean2:.6f}\")\n","    print(f\"    Std MISE  : {std2:.6f}\")\n","    print(f\"    SE MISE   : {se2:.6f}\")\n","    print(\"=\" * 50 + \"\\n\")\n","\n","    return {\n","        \"t_grid\": np.asarray(t_list),\n","        \"h_star\": np.asarray(h_star_vals),\n","        \"stage1_beta_mat\": np.vstack(stage1_beta),\n","        \"stage2_beta_mat\": np.vstack(stage2_beta),\n","        \"mise_list\": stage2_mise,\n","        \"seeds\": seeds,\n","    }\n","\n","\n","# ===========================================================\n","# 3) Execution + Saving (requested filenames)\n","# ===========================================================\n","K_SIM = 100\n","BASE_SEED = 1\n","\n","results = run_nn_simulation(K_runs=K_SIM, base_seed=BASE_SEED)\n","\n","first_seed = results[\"seeds\"][0]\n","last_seed = results[\"seeds\"][-1]\n","\n","t_cols = [f\"t_{int(t)}\" for t in results[\"t_grid\"]]\n","\n","# ---- Save Stage-2 beta estimates (MAIN requested output) ----\n","df_beta2 = pd.DataFrame(results[\"stage2_beta_mat\"], columns=t_cols)\n","df_beta2.insert(0, \"seed\", results[\"seeds\"])\n","\n","mean_row2 = pd.DataFrame([results[\"stage2_beta_mat\"].mean(axis=0)], columns=t_cols)\n","mean_row2.insert(0, \"seed\", \"mean\")\n","\n","se_row2 = pd.DataFrame(\n","    [results[\"stage2_beta_mat\"].std(axis=0, ddof=1) / np.sqrt(len(results[\"seeds\"]))],\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_NN_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","# ---- Save MISE only ----\n","df_mise = pd.DataFrame({\"seed\": results[\"seeds\"], \"mise\": results[\"mise_list\"]})\n","\n","mise_mean, mise_std, mise_se = summarize_list(results[\"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_NN_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":{"authorship_tag":"ABX9TyMeZ4/QkIJUKtiJFAMU5V2J","name":"","toc_visible":true,"version":""},"kernelspec":{"display_name":"Python 3","name":"python3"},"language_info":{"name":"python"}},"nbformat":4,"nbformat_minor":0}