{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import ray\n",
    "from tqdm import tqdm\n",
    "\n",
    "from utils.ols_utils import construct_interactions, write_train_test, run_rf, plot_err\n",
    "from utils.sc_utils import run_series\n",
    "\n",
    "os.makedirs('data/tmp', exist_ok=True)\n",
    "os.makedirs('data/output', exist_ok=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "# Read in the data"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "### OLS - LaLonde"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "URL transformed to HTTPS due to an HSTS policy\n",
      "--2023-05-21 17:00:25--  https://www.nber.org/~rdehejia/data/nswre74_control.txt\n",
      "Resolving www.nber.org (www.nber.org)... 23.185.0.2, 2620:12a:8001::2, 2620:12a:8000::2\n",
      "Connecting to www.nber.org (www.nber.org)|23.185.0.2|:443... connected.\n",
      "HTTP request sent, awaiting response... 301 Moved Permanently\n",
      "Location: https://users.nber.org/~rdehejia/data/nswre74_control.txt [following]\n",
      "--2023-05-21 17:00:25--  https://users.nber.org/~rdehejia/data/nswre74_control.txt\n",
      "Resolving users.nber.org (users.nber.org)... 198.71.6.22, 198.71.6.39\n",
      "Connecting to users.nber.org (users.nber.org)|198.71.6.22|:443... connected.\n",
      "HTTP request sent, awaiting response... 200 OK\n",
      "Length: 41860 (41K) [text/plain]\n",
      "Saving to: ‘data/nswre74_controls.txt’\n",
      "\n",
      "data/nswre74_contro 100%[===================>]  40.88K  --.-KB/s    in 0.1s    \n",
      "\n",
      "2023-05-21 17:00:25 (404 KB/s) - ‘data/nswre74_controls.txt’ saved [41860/41860]\n",
      "\n",
      "URL transformed to HTTPS due to an HSTS policy\n",
      "--2023-05-21 17:00:26--  https://www.nber.org/~rdehejia/data/cps_controls.txt\n",
      "Resolving www.nber.org (www.nber.org)... 23.185.0.2, 2620:12a:8000::2, 2620:12a:8001::2\n",
      "Connecting to www.nber.org (www.nber.org)|23.185.0.2|:443... connected.\n",
      "HTTP request sent, awaiting response... 301 Moved Permanently\n",
      "Location: https://users.nber.org/~rdehejia/data/cps_controls.txt [following]\n",
      "--2023-05-21 17:00:26--  https://users.nber.org/~rdehejia/data/cps_controls.txt\n",
      "Resolving users.nber.org (users.nber.org)... 198.71.6.22, 198.71.6.39\n",
      "Connecting to users.nber.org (users.nber.org)|198.71.6.22|:443... connected.\n",
      "HTTP request sent, awaiting response... 200 OK\n",
      "Length: 2574712 (2.5M) [text/plain]\n",
      "Saving to: ‘data/cps_controls.txt’\n",
      "\n",
      "data/cps_controls.t 100%[===================>]   2.46M  1.02MB/s    in 2.4s    \n",
      "\n",
      "2023-05-21 17:00:28 (1.02 MB/s) - ‘data/cps_controls.txt’ saved [2574712/2574712]\n",
      "\n"
     ]
    }
   ],
   "source": [
    "!wget -O data/nswre74_controls.txt http://www.nber.org/~rdehejia/data/nswre74_control.txt\n",
    "!wget -O data/cps_controls.txt http://www.nber.org/~rdehejia/data/cps_controls.txt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def read_lalonde(file):\n",
    "    df = pd.read_csv(\n",
    "        file, \n",
    "        sep=' ', \n",
    "        header=None,\n",
    "    ).dropna(how='all', axis=1)\n",
    "\n",
    "    df.columns = ['t', 'age', 'education', 'black', 'hispanic', 'married', 'nodegree', 're74', 're75', 're78']\n",
    "    \n",
    "    for col in df.columns:\n",
    "        if not col.startswith('re'): \n",
    "            df[col] = df[col].astype(int)\n",
    "        \n",
    "    return df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using 69 quantiles to achieve 50 bins for re74\n",
      "Using 70 quantiles to achieve 50 bins for re75\n"
     ]
    }
   ],
   "source": [
    "re74_control = read_lalonde('data/nswre74_controls.txt')\n",
    "cps_control = read_lalonde('data/cps_controls.txt')\n",
    "\n",
    "## convert values to be in 1000s of $\n",
    "for col in ['re74', 're75', 're78']:\n",
    "    for x in [cps_control, re74_control]:\n",
    "        x[col] = x[col] / 1000\n",
    "\n",
    "re74_control['test'] = 1\n",
    "cps_control['test'] = 0\n",
    "\n",
    "lalonde = pd.concat([cps_control, re74_control])\n",
    "\n",
    "# construct the interaction terms\n",
    "lalonde_mat = construct_interactions(lalonde)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "# Train: 3000\n",
      "# Test: 260\n"
     ]
    }
   ],
   "source": [
    "# write out the train/test datasets, using NSW experimental controls as test set\n",
    "\n",
    "# remove all interaction columns that are constant everywhere\n",
    "const_cols = list((lalonde_mat.std()[lalonde_mat.std() == 0]).index)\n",
    "\n",
    "write_train_test(\n",
    "    df=lalonde_mat.drop(columns=const_cols),\n",
    "    benchmark_df=lalonde,\n",
    "    n_train=3000,\n",
    "    noisy=True,\n",
    "    exptest=True,\n",
    "    outname='data/tmp/cps_noisy_3k_exptest_noconst'\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "# Train: 3000\n",
      "# Test: 12992\n"
     ]
    }
   ],
   "source": [
    "# write out the train/test datasets, using CPS non-experimental controls as test set\n",
    "\n",
    "# remove all interaction columns that are constant everywhere\n",
    "lalonde_cps_mat = lalonde_mat.loc[lalonde_mat['test'] == 0].copy()\n",
    "const_cols = list((lalonde_cps_mat.std()[lalonde_cps_mat.std() == 0]).index)\n",
    "\n",
    "write_train_test(\n",
    "    df=lalonde_cps_mat.drop(columns=const_cols),\n",
    "    benchmark_df=lalonde.loc[lalonde['test'] == 0].copy(),\n",
    "    n_train=3000,\n",
    "    noisy=True,\n",
    "    exptest=False,\n",
    "    outname='data/tmp/cps_noisy_3k_noconst'\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "### Synthetic Controls - Smoking"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "smoking = pd.read_csv(\n",
    "    'data/The_Tax_Burden_on_Tobacco__1970-2019.csv'\n",
    ")\n",
    "\n",
    "pc_smoking = smoking.loc[\n",
    "    (smoking['SubMeasureDesc'] == 'Cigarette Consumption (Pack Sales Per Capita)') &\n",
    "    (smoking['Year'] <= 1989)\n",
    "][['LocationAbbr', 'Year', 'Data_Value']].rename({\"LocationAbbr\": \"state\", \"Year\": 'year', \"Data_Value\": 'daily_packs'}, axis=1).sort_values(['year', 'state']).copy()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "# Run the models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'node_ip_address': '171.67.96.198',\n",
       " 'raylet_ip_address': '171.67.96.198',\n",
       " 'redis_address': '171.67.96.198:6379',\n",
       " 'object_store_address': '/tmp/ray/session_2023-05-21_17-02-02_007213_1432992/sockets/plasma_store',\n",
       " 'raylet_socket_name': '/tmp/ray/session_2023-05-21_17-02-02_007213_1432992/sockets/raylet',\n",
       " 'webui_url': None,\n",
       " 'session_dir': '/tmp/ray/session_2023-05-21_17-02-02_007213_1432992',\n",
       " 'metrics_export_port': 43324,\n",
       " 'gcs_address': '171.67.96.198:35889',\n",
       " 'node_id': 'f7b52a05bf1ed4cadafebc3aeb3537f7f528a9ddb04e5dae93eaf872'}"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## initialize ray for parallelization - set num_cpus equal to desired number of cores\n",
    "## following cells take ~20min to run with num_cpus = 48\n",
    "ray.shutdown()\n",
    "ray.init(num_cpus=48)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## OLS - LaLonde"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "## Evaluate on NSW Experimental Controls"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5/5 [19:57<00:00, 239.47s/it]\n"
     ]
    }
   ],
   "source": [
    "n_seeds = 5\n",
    "n_train = 3000\n",
    "\n",
    "\n",
    "train_name = str(int(n_train / 1000)) + 'k_exptest_noconst'\n",
    "rmses = []\n",
    "for seed in tqdm(range(n_seeds)):\n",
    "    test_nest = run_rf(\n",
    "        X_file=f'data/tmp/cps_noisy_{train_name}_features.npz',\n",
    "        y_file=f'data/tmp/cps_noisy_{train_name}_label.npz',\n",
    "        k_step=50,\n",
    "        nest=True,\n",
    "        plot=False,\n",
    "        verbose=False,\n",
    "        seed=seed,\n",
    "        intercept=True,\n",
    "        ret_beta=True\n",
    "    )\n",
    "    beta_norms = [np.linalg.norm(b) for b in test_nest[3]]\n",
    "\n",
    "    rmses.append(pd.DataFrame({\"k\": test_nest[2], \"rmse\": test_nest[0], \"beta_norm\": beta_norms}))\n",
    "\n",
    "avg_rmse_3k_exptest_int = pd.concat(rmses).groupby('k')[['rmse', 'beta_norm']].mean().reset_index().copy()\n",
    "avg_rmse_3k_exptest_int.to_csv(f'data/output/avg_rmse_{train_name}_intercept.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best Metric: 8.173401021177622\n",
      "Mean Guess Metric: 11.712513967063066\n",
      "Normal OLS Metric: 6.086964848784822\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "## plot the RMSE curve\n",
    "fig_3k = plot_err(\n",
    "    errs=avg_rmse_3k_exptest_int['rmse'].values,\n",
    "    dims=avg_rmse_3k_exptest_int['k'].values,\n",
    "    ys=np.load(f'data/tmp/cps_noisy_{train_name}_label.npz'),\n",
    "    benchmark_Xs=np.load(f'data/tmp/cps_noisy_{train_name}_benchmark_features.npz'),\n",
    "    name='nsw_control',\n",
    "    y_bounds=(5,75),\n",
    "    intercept=True\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='k'>"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "## plot the beta norm curve\n",
    "avg_rmse_3k_exptest_int.set_index('k')['beta_norm'].plot(figsize=(9,6), ylim=(0,2000))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "## Evaluate on CPS Non-Experimental Controls"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5/5 [22:29<00:00, 269.99s/it]\n"
     ]
    }
   ],
   "source": [
    "n_seeds = 5\n",
    "n_train = 3000\n",
    "\n",
    "\n",
    "train_name = str(int(n_train / 1000)) + 'k_noconst'\n",
    "rmses = []\n",
    "for seed in tqdm(range(n_seeds)):\n",
    "    test_nest = run_rf(\n",
    "        X_file=f'data/tmp/cps_noisy_{train_name}_features.npz',\n",
    "        y_file=f'data/tmp/cps_noisy_{train_name}_label.npz',\n",
    "        k_step=50,\n",
    "        nest=True,\n",
    "        plot=False,\n",
    "        verbose=False,\n",
    "        seed=seed,\n",
    "        intercept=True,\n",
    "        ret_beta=True\n",
    "    )\n",
    "    beta_norms = [np.linalg.norm(b) for b in test_nest[3]]\n",
    "\n",
    "    rmses.append(pd.DataFrame({\"k\": test_nest[2], \"rmse\": test_nest[0], \"beta_norm\": beta_norms}))\n",
    "\n",
    "avg_rmse_3k_int = pd.concat(rmses).groupby('k')[['rmse', 'beta_norm']].mean().reset_index().copy()\n",
    "avg_rmse_3k_int.to_csv(f'data/output/avg_rmse_{train_name}_intercept.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best Metric: 9.339376379149392\n",
      "Mean Guess Metric: 9.638799727897618\n",
      "Normal OLS Metric: 6.968477423940825\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "## plot the RMSE curve\n",
    "fig_3k = plot_err(\n",
    "    errs=avg_rmse_3k_int['rmse'].values,\n",
    "    dims=avg_rmse_3k_int['k'].values,\n",
    "    ys=np.load(f'data/tmp/cps_noisy_{train_name}_label.npz'),\n",
    "    benchmark_Xs=np.load(f'data/tmp/cps_noisy_{train_name}_benchmark_features.npz'),\n",
    "    name='cps_control',\n",
    "    y_bounds=(5,75),\n",
    "    intercept=True\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5/5 [20:19<00:00, 243.81s/it]\n"
     ]
    }
   ],
   "source": [
    "## get the in-sample rmse as well\n",
    "X_file=np.load(f'data/tmp/cps_noisy_{train_name}_features.npz')\n",
    "y_file=np.load(f'data/tmp/cps_noisy_{train_name}_label.npz')\n",
    "\n",
    "np.savez_compressed(\n",
    "    f'data/tmp/cps_noisy_{train_name}_clone_features.npz',\n",
    "    train=X_file['train'],\n",
    "    test=X_file['train']\n",
    ")\n",
    "np.savez_compressed(\n",
    "    f'data/tmp/cps_noisy_{train_name}_clone_label.npz',\n",
    "    train=y_file['train'],\n",
    "    test=y_file['train']\n",
    ")\n",
    "\n",
    "rmses = []\n",
    "for seed in tqdm(range(n_seeds)):\n",
    "    test_nest = run_rf(\n",
    "        X_file=f'data/tmp/cps_noisy_{train_name}_clone_features.npz',\n",
    "        y_file=f'data/tmp/cps_noisy_{train_name}_clone_label.npz',\n",
    "        name='cps_control',\n",
    "        k_step=50,\n",
    "        nest=True,\n",
    "        plot=False,\n",
    "        verbose=False,\n",
    "        seed=seed,\n",
    "        intercept=True\n",
    "    )\n",
    "\n",
    "    rmses.append(pd.DataFrame({\"k\": test_nest[2], \"rmse\": test_nest[0]}))\n",
    "\n",
    "avg_rmse_3k_int_is = pd.concat(rmses).groupby('k').rmse.mean().reset_index().copy()\n",
    "avg_rmse_3k_int_is.to_csv(f'data/output/avg_rmse_{train_name}_intercept_insample.csv', index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "### Synthetic Control - Smoking"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 20/20 [08:31<00:00, 25.57s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "res20_CA, fig20_CA_avg, fig20_CA_best = run_series(df=pc_smoking, num_states=20, target_state='CA')\n",
    "\n",
    "# get the average in-sample and out-of-sample RMSEs across all combinations\n",
    "stats = res20_CA.groupby('n')[['err_is', 'err_oos']].mean().reset_index()\n",
    "stats.to_csv('data/output/ca_smoking_20_avg.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "ray.shutdown()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "py39",
   "language": "python",
   "name": "py39"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
