{"cells":[{"cell_type":"code","execution_count":null,"metadata":{"colab":{"background_save":true,"base_uri":"https://localhost:8080/"},"id":"lzE-yQcEM_ad"},"outputs":[{"name":"stdout","output_type":"stream","text":["Mounted at /content/drive\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 [00:19\u003c00:00,  2.39it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.61it/s]\n","100%|██████████| 47/47 [00:23\u003c00:00,  1.99it/s]"]},{"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 [00:18\u003c00:00,  2.57it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.55it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.10it/s]"]},{"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 [00:19\u003c00:00,  2.36it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.45it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.35it/s]"]},{"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 [00:17\u003c00:00,  2.76it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.52it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.44it/s]"]},{"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 [00:15\u003c00:00,  2.97it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.45it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.47it/s]"]},{"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 [00:17\u003c00:00,  2.64it/s]\n","100%|██████████| 47/47 [00:17\u003c00:00,  2.61it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.43it/s]"]},{"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 [00:16\u003c00:00,  2.78it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.55it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.54it/s]"]},{"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 [00:18\u003c00:00,  2.61it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.52it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.37it/s]"]},{"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 [00:18\u003c00:00,  2.60it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.42it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.16it/s]"]},{"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 [00:17\u003c00:00,  2.70it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.24it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.10it/s]"]},{"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 [00:18\u003c00:00,  2.58it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.49it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.47it/s]"]},{"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 [00:21\u003c00:00,  2.19it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.49it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.38it/s]"]},{"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 [00:18\u003c00:00,  2.59it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.53it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.38it/s]"]},{"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 [00:18\u003c00:00,  2.50it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.26it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.08it/s]"]},{"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 [00:17\u003c00:00,  2.74it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.40it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.11it/s]"]},{"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 [00:18\u003c00:00,  2.54it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.22it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.09it/s]"]},{"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 [00:18\u003c00:00,  2.47it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.30it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.11it/s]"]},{"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 [00:19\u003c00:00,  2.45it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.41it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.31it/s]"]},{"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 [00:19\u003c00:00,  2.45it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.30it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.07it/s]"]},{"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 [00:21\u003c00:00,  2.14it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.13it/s]\n","100%|██████████| 47/47 [00:23\u003c00:00,  1.97it/s]"]},{"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 [00:18\u003c00:00,  2.57it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.24it/s]\n","100%|██████████| 47/47 [00:25\u003c00:00,  1.85it/s]"]},{"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 [00:20\u003c00:00,  2.25it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.22it/s]\n","100%|██████████| 47/47 [00:25\u003c00:00,  1.86it/s]"]},{"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 [00:18\u003c00:00,  2.51it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.45it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.51it/s]"]},{"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 [00:20\u003c00:00,  2.27it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.29it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.39it/s]"]},{"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 [00:18\u003c00:00,  2.54it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.56it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.21it/s]"]},{"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 [00:18\u003c00:00,  2.51it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.52it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.32it/s]"]},{"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 [00:19\u003c00:00,  2.39it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.39it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.22it/s]"]},{"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 [00:19\u003c00:00,  2.39it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.28it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.09it/s]"]},{"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 [00:18\u003c00:00,  2.51it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.48it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.16it/s]"]},{"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 [00:17\u003c00:00,  2.75it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.47it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.15it/s]"]},{"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 [00:20\u003c00:00,  2.24it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.56it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.33it/s]"]},{"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 [00:18\u003c00:00,  2.56it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.26it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.12it/s]"]},{"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 [00:18\u003c00:00,  2.58it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.29it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.22it/s]"]},{"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 [00:17\u003c00:00,  2.63it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.23it/s]\n","100%|██████████| 47/47 [00:23\u003c00:00,  2.00it/s]"]},{"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 [00:19\u003c00:00,  2.36it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.05it/s]\n","100%|██████████| 47/47 [00:24\u003c00:00,  1.92it/s]"]},{"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 [00:19\u003c00:00,  2.36it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.13it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.33it/s]"]},{"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 [00:19\u003c00:00,  2.43it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.21it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.16it/s]"]},{"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 [00:19\u003c00:00,  2.42it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.25it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.14it/s]"]},{"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 [00:18\u003c00:00,  2.59it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.36it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.12it/s]"]},{"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 [00:18\u003c00:00,  2.49it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.16it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.14it/s]"]},{"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 [00:17\u003c00:00,  2.70it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.18it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.17it/s]"]},{"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 [00:18\u003c00:00,  2.57it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.34it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.20it/s]"]},{"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 [00:16\u003c00:00,  2.77it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.44it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.40it/s]"]},{"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 [00:18\u003c00:00,  2.51it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.39it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.22it/s]"]},{"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 [00:17\u003c00:00,  2.69it/s]\n","100%|██████████| 47/47 [00:17\u003c00:00,  2.67it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.32it/s]"]},{"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 [00:20\u003c00:00,  2.28it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.48it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.26it/s]"]},{"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 [00:18\u003c00:00,  2.59it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.48it/s]\n","100%|██████████| 47/47 [00:23\u003c00:00,  2.04it/s]"]},{"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 [00:18\u003c00:00,  2.55it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.19it/s]\n","100%|██████████| 47/47 [00:23\u003c00:00,  2.02it/s]"]},{"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 [00:18\u003c00:00,  2.56it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.61it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.21it/s]"]},{"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 [00:17\u003c00:00,  2.64it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.42it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.32it/s]"]},{"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 [00:18\u003c00:00,  2.48it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.41it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.05it/s]"]},{"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 [00:17\u003c00:00,  2.71it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.55it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.29it/s]"]},{"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 [00:19\u003c00:00,  2.45it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.28it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.25it/s]"]},{"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 [00:18\u003c00:00,  2.51it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.26it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.10it/s]"]},{"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 [00:16\u003c00:00,  2.79it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.42it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.33it/s]"]},{"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 [00:17\u003c00:00,  2.68it/s]\n","100%|██████████| 47/47 [00:17\u003c00:00,  2.64it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.18it/s]"]},{"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 [00:18\u003c00:00,  2.49it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.54it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.40it/s]"]},{"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 [00:18\u003c00:00,  2.49it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.29it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.19it/s]"]},{"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 [00:17\u003c00:00,  2.69it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.39it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.23it/s]"]},{"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 [00:18\u003c00:00,  2.50it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.50it/s]\n","100%|██████████| 47/47 [00:23\u003c00:00,  1.98it/s]"]},{"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 [00:18\u003c00:00,  2.60it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.37it/s]\n","100%|██████████| 47/47 [00:23\u003c00:00,  2.02it/s]"]},{"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 [00:19\u003c00:00,  2.43it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.42it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.19it/s]"]},{"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 [00:18\u003c00:00,  2.54it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.54it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.27it/s]"]},{"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 [00:19\u003c00:00,  2.43it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.50it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.17it/s]"]},{"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 [00:18\u003c00:00,  2.48it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.52it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.14it/s]"]},{"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 [00:19\u003c00:00,  2.35it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.57it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.23it/s]"]},{"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 [00:18\u003c00:00,  2.54it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.45it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.21it/s]"]},{"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 [00:18\u003c00:00,  2.59it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.53it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.27it/s]"]},{"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 [00:22\u003c00:00,  2.12it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.56it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.24it/s]"]},{"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 [00:16\u003c00:00,  2.77it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.34it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.14it/s]"]},{"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 [00:17\u003c00:00,  2.63it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.44it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.31it/s]"]},{"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 [00:20\u003c00:00,  2.34it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.29it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.38it/s]"]},{"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 [00:18\u003c00:00,  2.56it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.42it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.31it/s]"]},{"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 [00:18\u003c00:00,  2.52it/s]\n","100%|██████████| 47/47 [00:17\u003c00:00,  2.65it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.26it/s]"]},{"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 [00:17\u003c00:00,  2.66it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.48it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.07it/s]"]},{"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 [00:18\u003c00:00,  2.50it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.39it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.13it/s]"]},{"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 [00:18\u003c00:00,  2.60it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.26it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.08it/s]"]},{"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 [00:20\u003c00:00,  2.33it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.34it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.12it/s]"]},{"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 [00:19\u003c00:00,  2.41it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.37it/s]\n","100%|██████████| 47/47 [00:23\u003c00:00,  2.03it/s]"]},{"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 [00:20\u003c00:00,  2.35it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.08it/s]\n","100%|██████████| 47/47 [00:25\u003c00:00,  1.85it/s]"]},{"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 [00:19\u003c00:00,  2.39it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.23it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.07it/s]"]},{"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 [00:19\u003c00:00,  2.42it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.33it/s]\n","100%|██████████| 47/47 [00:23\u003c00:00,  1.97it/s]"]},{"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 [00:22\u003c00:00,  2.13it/s]\n","100%|██████████| 47/47 [00:24\u003c00:00,  1.93it/s]\n","100%|██████████| 47/47 [00:26\u003c00:00,  1.75it/s]"]},{"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 [00:19\u003c00:00,  2.35it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.24it/s]\n","100%|██████████| 47/47 [00:24\u003c00:00,  1.89it/s]"]},{"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 [00:22\u003c00:00,  2.06it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.18it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.08it/s]"]},{"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 [00:18\u003c00:00,  2.56it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.37it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.24it/s]"]},{"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 [00:21\u003c00:00,  2.20it/s]\n","100%|██████████| 47/47 [00:23\u003c00:00,  2.02it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.33it/s]"]},{"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 [00:18\u003c00:00,  2.55it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.48it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.06it/s]"]},{"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 [00:19\u003c00:00,  2.46it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.21it/s]\n","100%|██████████| 47/47 [00:24\u003c00:00,  1.90it/s]"]},{"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 [00:20\u003c00:00,  2.26it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.15it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.08it/s]"]},{"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 [00:20\u003c00:00,  2.33it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.29it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.06it/s]"]},{"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 [00:18\u003c00:00,  2.51it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.34it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.09it/s]"]},{"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 [00:19\u003c00:00,  2.37it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.37it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.12it/s]"]},{"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 [00:20\u003c00:00,  2.34it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.26it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.24it/s]"]},{"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 [00:19\u003c00:00,  2.46it/s]\n","100%|██████████| 47/47 [00:21\u003c00:00,  2.17it/s]\n","100%|██████████| 47/47 [00:23\u003c00:00,  2.01it/s]"]},{"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 [00:18\u003c00:00,  2.61it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.42it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.41it/s]"]},{"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 [00:21\u003c00:00,  2.22it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.07it/s]\n","100%|██████████| 47/47 [00:22\u003c00:00,  2.05it/s]"]},{"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 [00:18\u003c00:00,  2.54it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.35it/s]\n","100%|██████████| 47/47 [00:23\u003c00:00,  2.04it/s]"]},{"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 [00:22\u003c00:00,  2.11it/s]\n","100%|██████████| 47/47 [00:18\u003c00:00,  2.51it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.33it/s]"]},{"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 [00:17\u003c00:00,  2.68it/s]\n","100%|██████████| 47/47 [00:19\u003c00:00,  2.37it/s]\n","100%|██████████| 47/47 [00:20\u003c00:00,  2.26it/s]\n"]},{"name":"stdout","output_type":"stream","text":["\n","==================================================\n","RESULTS (LASSO, K=100) - Second Stage Only\n","==================================================\n","Method: LASSO\n","  [Stage 2: h = 0.8 * h_star_ml]\n","    Mean MISE : 2.873244\n","    Std MISE  : 2.391056\n","    SE MISE   : 0.239106\n","==================================================\n","\n","Saved Stage-2 beta estimates to: /content/drive/MyDrive/Colab Notebooks/CTE_Baseline/DML_methods/Data_and_Results/Estimates/estimates_LASSO_seed1_to_seed100.csv\n","Saved MISE-only table to: /content/drive/MyDrive/Colab Notebooks/CTE_Baseline/DML_methods/Data_and_Results/Estimates/MISE_LASSO_seed1_to_seed100.csv\n"]}],"source":["import os\n","import sys\n","import pathlib\n","import logging\n","import numpy as np\n","import pandas as pd\n","from sklearn.base import BaseEstimator, RegressorMixin\n","from sklearn.linear_model import Lasso\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\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) Custom Lasso Wrapper (Mimic normalize=True)\n","# ===========================================================\n","class LassoWithL2Normalize(BaseEstimator, RegressorMixin):\n","    \"\"\"\n","    Approximates Lasso(normalize=True) behavior:\n","      - Centers X and y\n","      - Scales features by L2 norm\n","      - Fits Lasso without intercept\n","    \"\"\"\n","    def __init__(self, alpha=1.0, max_iter=10000, tol=1e-4, random_state=None):\n","        self.alpha = alpha\n","        self.max_iter = max_iter\n","        self.tol = tol\n","        self.random_state = random_state\n","\n","    def fit(self, X, y):\n","        X = np.asarray(X, float)\n","        y = np.asarray(y, float)\n","\n","        self.X_mean_ = X.mean(axis=0)\n","        self.y_mean_ = y.mean()\n","        X_centered = X - self.X_mean_\n","        y_centered = y - self.y_mean_\n","\n","        self.X_scale_ = np.linalg.norm(X_centered, axis=0)\n","        self.X_scale_[self.X_scale_ == 0] = 1.0\n","        X_norm = X_centered / self.X_scale_\n","\n","        self.model_ = Lasso(\n","            alpha=self.alpha,\n","            max_iter=self.max_iter,\n","            tol=self.tol,\n","            fit_intercept=False,\n","            random_state=self.random_state,\n","        )\n","        self.model_.fit(X_norm, y_centered)\n","        return self\n","\n","    def predict(self, X):\n","        X = np.asarray(X, float)\n","        X_norm = (X - self.X_mean_) / self.X_scale_\n","        return self.model_.predict(X_norm) + self.y_mean_\n","\n","\n","# ===========================================================\n","# 2) Data Loading \u0026 Generation 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\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","    t_grid = h_star_df[\"t\"].to_numpy()\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_mise(mise_list):\n","    arr = np.asarray(mise_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","# 3) Main Simulation Function\n","# ===========================================================\n","def run_lasso_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","    # Configuration\n","    h_rule = np.std(T) * 3 * (len(T) ** (-0.2))\n","    h_first = 2 * h_rule\n","    L, u = 5, 0.5\n","\n","    # Lasso models (keep identical to preserve the same MISE)\n","    model_lasso1 = LassoWithL2Normalize(alpha=0.00069944, max_iter=10000, tol=0.0001)\n","    model_lasso2 = LassoWithL2Normalize(alpha=0.000160472, max_iter=10000, tol=0.0001)\n","    models = [model_lasso1, model_lasso2]\n","\n","    # Storage (Stage 2 only)\n","    second_stage_mise = []\n","    second_stage_beta = []\n","    seeds = []\n","\n","    logger.info(f\"Starting {K_runs} simulations (LASSO)...\")\n","\n","    for k in range(K_runs):\n","        seed = base_seed + k\n","        seeds.append(seed)\n","\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\n","        Y_syn = gen_semi_y(mu_hat, g, rng_sim)\n","        perm = rng_sim.permutation(len(T))\n","        X_k = np.asarray(X.iloc[perm], float)\n","        T_k = np.asarray(T.iloc[perm], float)\n","        Y_k = np.asarray(Y_syn[perm], float)\n","\n","        # Stage 1\n","        model1 = Supplement.DDMLCT(models[0], models[1])\n","        model1.fit(X_k, T_k, Y_k, t_list, L, h=h_first, basis=True, standardize=True)\n","\n","        model2 = Supplement.DDMLCT(models[0], models[1])\n","        model2.fit(X_k, T_k, Y_k, t_list, L, h=h_first * u, basis=True, standardize=True)\n","\n","        # Bandwidth selection\n","        Bt = (model1.beta - model2.beta) / ((model1.h**2) * (1 - (u**2)))\n","        h_star_ml = np.mean(((model2.Vt / (4 * (Bt**2))) ** 0.2) * (model1.n**-0.2))\n","\n","        # Stage 2 (target)\n","        h_second = 0.8 * h_star_ml\n","        model_final = Supplement.DDMLCT(models[0], models[1])\n","        model_final.fit(X_k, T_k, Y_k, t_list, L, h=h_second, basis=True, standardize=True)\n","\n","        # Metrics\n","        mise2 = mise_against(model_final.beta, h_star_vals)\n","        second_stage_mise.append(mise2)\n","        second_stage_beta.append(np.asarray(model_final.beta, dtype=float))\n","\n","        if (k + 1) % 10 == 0:\n","            logger.info(f\"Simulation {k+1}/{K_runs} completed.\")\n","\n","    # Summary output (ONLY Second Stage)\n","    mean2, std2, se2 = summarize_mise(second_stage_mise)\n","\n","    print(\"\\n\" + \"=\" * 50)\n","    print(f\"RESULTS (LASSO, K={K_runs}) - Second Stage Only\")\n","    print(\"=\" * 50)\n","    print(\"Method: LASSO\")\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\": t_list,\n","        \"h_star\": h_star_vals,\n","        \"beta_mat\": np.vstack(second_stage_beta),\n","        \"mise_list\": second_stage_mise,\n","        \"seeds\": seeds,\n","    }\n","\n","\n","# ===========================================================\n","# 4) Execution Block + Save (requested format)\n","# ===========================================================\n","K_RUNS = 100\n","BASE_SEED = 1\n","\n","results = run_lasso_simulation(K_runs=K_RUNS, base_seed=BASE_SEED)\n","\n","first_seed = results[\"seeds\"][0]\n","last_seed = results[\"seeds\"][-1]\n","\n","# ---- Save Stage-2 beta estimates (all seeds + mean/se) ----\n","t_cols = [f\"t_{int(t)}\" for t in results[\"t_grid\"]]\n","df_beta = pd.DataFrame(results[\"beta_mat\"], columns=t_cols)\n","df_beta.insert(0, \"seed\", results[\"seeds\"])\n","\n","mean_row = pd.DataFrame([results[\"beta_mat\"].mean(axis=0)], columns=t_cols)\n","mean_row.insert(0, \"seed\", \"mean\")\n","\n","se_row = pd.DataFrame(\n","    [results[\"beta_mat\"].std(axis=0, ddof=1) / np.sqrt(len(results[\"seeds\"]))],\n","    columns=t_cols,\n",")\n","se_row.insert(0, \"seed\", \"se\")\n","\n","df_beta_final = pd.concat([df_beta, mean_row, se_row], ignore_index=True)\n","\n","out_beta = RESULTS_DIR / f\"estimates_LASSO_seed{first_seed}_to_seed{last_seed}.csv\"\n","df_beta_final.to_csv(out_beta, index=False)\n","print(f\"Saved Stage-2 beta estimates to: {out_beta}\")\n","\n","# ---- Save Stage-2 MISE only (all seeds + mean/se) ----\n","df_mise = pd.DataFrame({\"seed\": results[\"seeds\"], \"mise\": results[\"mise_list\"]})\n","\n","mise_mean, _, mise_se = summarize_mise(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_LASSO_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":"ABX9TyMzeydjU4NofNK3J7Mqe2b+","name":"","toc_visible":true,"version":""},"kernelspec":{"display_name":"Python 3","name":"python3"},"language_info":{"name":"python"}},"nbformat":4,"nbformat_minor":0}