{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "06568c41",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pylab as plt\n",
    "import ot\n",
    "import cvxpy as cp\n",
    "import seaborn as sns\n",
    "\n",
    "# Supplementary Packages\n",
    "import scipy.stats as stats\n",
    "#import scipy.special as sps\n",
    "#import time as t"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "12dfcbf1",
   "metadata": {},
   "source": [
    "# Guide\n",
    "1. Over all time period<br>\n",
    "* Use `twp4sc` to obtain pre-treatment period projection and post-treatment projection.\n",
    "* Use `permutest4sc` to obtain a table of pre-treatment period distances and post-treatment period distances\n",
    "* Use `permutest_by_timeperiod` to obtain table of distances over each time period\n",
    "2. Weights averaged over time period\n",
    "* Use `twp_by_timeperiod` to obtain projection and counterfactual distribution for each period\n",
    "* Use `permutest_by_timeperiod` with `functiontype = 'each'`(default) to obtain table of distances over each time period\n",
    "3. Weights over all time period but permutest by each time period\n",
    "* Use `twp_singleweights` to obtain projection and counterfactual distribution for each period\n",
    "* Use `permutest_by_timeperiod` with `functiontype = 'all'` to obtain table of distances over each time period\n",
    "4. Plotting for by-period permutation tests\n",
    "* Use `plot_byperiod_distances`"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "30b38653",
   "metadata": {},
   "source": [
    "## Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "532c1063",
   "metadata": {},
   "outputs": [],
   "source": [
    "def baryc_proj(source, target, method):\n",
    "    \n",
    "    n1 = source.shape[0]\n",
    "    n2 = target.shape[0]   \n",
    "    p = source.shape[1]\n",
    "    a_ones, b_ones = np.ones((n1,)) / n1, np.ones((n2,)) / n2\n",
    "    \n",
    "    M = ot.dist(source, target)\n",
    "    M = M.astype('float64')\n",
    "    M /= M.max()\n",
    "    \n",
    "    if method == 'emd':\n",
    "        OTplan = ot.emd(a_ones, b_ones, M, numItermax = 1e7)\n",
    "        \n",
    "    elif method == 'entropic':\n",
    "        OTplan = ot.bregman.sinkhorn_stabilized(a_ones, b_ones, M, reg = 5*1e-3)\n",
    "    \n",
    "    # initialization\n",
    "    OTmap = np.empty((0, p))\n",
    "\n",
    "    for i in range(n1):\n",
    "        \n",
    "        # normalization\n",
    "        OTplan[i,:] = OTplan[i,:] / sum(OTplan[i,:])\n",
    "    \n",
    "        # conditional expectation\n",
    "        OTmap = np.vstack([OTmap, (target.T @ OTplan[i,:])])\n",
    "    \n",
    "    OTmap = np.array(OTmap).astype('float32')\n",
    "    \n",
    "    return(OTmap)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "5b12e466",
   "metadata": {},
   "outputs": [],
   "source": [
    "def DSCreplication(target, controls, method = 'emd', projtype = 'wass'):\n",
    "    \n",
    "    n = target.shape[0]\n",
    "    d = target.shape[1]\n",
    "    J = len(controls)\n",
    "    S = np.mean(target)*n*d*J\n",
    "    \n",
    "    \n",
    "    # Barycentric Projection\n",
    "    G_list = []\n",
    "    proj_list = []\n",
    "    for i in range(len(controls)):\n",
    "        temp = baryc_proj(target, controls[i], method)\n",
    "        G_list.append(temp)\n",
    "        proj_list.append(temp - target)\n",
    "    \n",
    "    \n",
    "    # Obtain optimal weights\n",
    "    mylambda = cp.Variable(J)\n",
    "\n",
    "    objective = cp.Minimize(\n",
    "                    cp.sum_squares(\n",
    "                    cp.sum([a*b for a,b in zip(mylambda, proj_list)], axis = 0))/S\n",
    "                    )\n",
    "    constraints = [mylambda >= 0, mylambda <= 1, cp.sum(mylambda) == 1]\n",
    "\n",
    "    prob = cp.Problem(objective, constraints)\n",
    "    prob.solve()\n",
    "    \n",
    "    \n",
    "    weights = mylambda.value\n",
    "    testproj = sum([a*b for a,b in zip(weights, G_list)])\n",
    "    measureweights = [ot.unif(n)]*J\n",
    "    \n",
    "    if projtype == 'eucl':\n",
    "        projection = testproj\n",
    "    elif projtype == 'wass':\n",
    "        projection = ot.lp.free_support_barycenter(G_list, measureweights, X_init = testproj, weights = weights)\n",
    "\n",
    "    \n",
    "    return(weights, projection)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "10cd43b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "# read data\n",
    "# input: Target, pre_controls, post_controls, sample size, option to output weights\n",
    "# output: projection pre-intervention, conterfactual distribution, optionally weights\n",
    "\n",
    "def twp4sc(target, pre_controls, post_controls, samplesize = 'full', weight_out = False):\n",
    "    \n",
    "    if samplesize != 'full':\n",
    "        \n",
    "        # sample target\n",
    "        target = np.array(\n",
    "                    pd.DataFrame(target).sample(samplesize, random_state = 31))\n",
    "        \n",
    "        # sample controls\n",
    "        for i in range(len(pre_controls)):\n",
    "            pre_controls[i] = np.array(\n",
    "                                pd.DataFrame(\n",
    "                                    pre_controls[i]).sample(samplesize, random_state = 31))\n",
    "            \n",
    "        for j in range(len(post_controls)):\n",
    "            post_controls[j] = np.array(\n",
    "                                pd.DataFrame(\n",
    "                                    post_controls[j]).sample(samplesize, random_state = 31))\n",
    "        \n",
    "    # TWP\n",
    "    lambdas, projection = DSCreplication(target, pre_controls)\n",
    "        \n",
    "    # counterfactual distribution\n",
    "    n = post_controls[0].shape[0]\n",
    "    d = post_controls[0].shape[1]\n",
    "    J = len(post_controls)\n",
    "    \n",
    "    measureweights = [ot.unif(n)]*J\n",
    "    x_init = np.random.normal(0., 1., (n, d))\n",
    "        \n",
    "    cntfctl = ot.lp.free_support_barycenter(post_controls, measureweights, X_init = x_init, weights = lambdas)\n",
    "        \n",
    "    if weight_out:\n",
    "        return(lambdas, projection, cntfctl)\n",
    "    else:\n",
    "        return(projection, cntfctl)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d5c62ccf",
   "metadata": {},
   "outputs": [],
   "source": [
    "# input: list of target and controls pre and post intervention\n",
    "# output: lists of distances between actual and replication\n",
    "\n",
    "def permutest4sc(PRE, POST, samplesize = 'full'):\n",
    "    \n",
    "    pre_dists = []\n",
    "    post_dists = []\n",
    "\n",
    "    for i in range(len(PRE)):\n",
    "\n",
    "        pre_projection, post_projection = twp4sc(PRE[i], PRE[:i]+PRE[i+1:], POST[:i]+POST[i+1:], samplesize)\n",
    "\n",
    "        n1 = pre_projection.shape[0]\n",
    "        n2 = post_projection.shape[0]\n",
    "        \n",
    "        # distance to pre\n",
    "        if samplesize != 'full':\n",
    "                current_pre = np.array(\n",
    "                                pd.DataFrame(\n",
    "                                    PRE[i]).sample(samplesize, random_state = 31))\n",
    "        else: current_pre = PRE[i]\n",
    "                \n",
    "        M1 = ot.dist(pre_projection, current_pre)\n",
    "        a_ones, b_ones = np.ones((n1,)) / n1, np.ones((n1,)) / n1\n",
    "        dist2pre = ot.emd2(a_ones, b_ones, M1)\n",
    "        pre_dists.append(dist2pre)\n",
    "\n",
    "        \n",
    "        # distance to post\n",
    "        if samplesize != 'full':\n",
    "                current_post = np.array(\n",
    "                                pd.DataFrame(\n",
    "                                    POST[i]).sample(samplesize, random_state = 31))\n",
    "        else: current_post = POST[i]\n",
    "            \n",
    "        M2 = ot.dist(post_projection, current_post)\n",
    "        a_ones, b_ones = np.ones((n2,)) / n2, np.ones((n2,)) / n2\n",
    "        dist2post = ot.emd2(a_ones, b_ones, M2)\n",
    "        post_dists.append(dist2post)\n",
    "                \n",
    "            \n",
    "    return(pre_dists, post_dists)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bd09bbe3",
   "metadata": {},
   "source": [
    "#### Time Period option"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "8b207dc0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# input: list of target(np.arrays), list of list of controls(arrays), pre and post - each element is one time period\n",
    "\n",
    "def twp_by_timeperiod(targets, pre_controls, post_controls, weighting = 'uniform', samplesize = 100):\n",
    "    \n",
    "    # restructure controls\n",
    "    pre_set = []\n",
    "    for j in range(len(pre_controls[0])):\n",
    "        tmp = [pre_controls[i][j] for i in range(len(pre_controls))]\n",
    "        pre_set.append(tmp)\n",
    "        \n",
    "    post_set = []\n",
    "    for j in range(len(post_controls[0])):\n",
    "        tmp = [post_controls[i][j] for i in range(len(post_controls))]\n",
    "        post_set.append(tmp)\n",
    "        \n",
    "        \n",
    "    # i is time period\n",
    "    lambdas = []\n",
    "    projections = []\n",
    "    for i in range(len(targets)):\n",
    "        \n",
    "        if samplesize != 'full':\n",
    "        \n",
    "        # sample target\n",
    "            target = np.array(\n",
    "                        pd.DataFrame(targets[i]).sample(samplesize, random_state = 31))\n",
    "        \n",
    "        # sample controls\n",
    "            controls = []\n",
    "            for j in range(len(pre_set[i])):\n",
    "                controls.append(np.array(\n",
    "                                        pd.DataFrame(\n",
    "                                            pre_set[i][j]).sample(samplesize, random_state = 31)))\n",
    "        else:\n",
    "            target = targets[i]\n",
    "            controls = controls_temp[i]\n",
    "        \n",
    "        lam, projection = DSCreplication(target, controls)\n",
    "        lambdas.append(lam)\n",
    "        projections.append(projection)\n",
    "    \n",
    "    lambdas = np.array(lambdas)\n",
    "    \n",
    "    if weighting == 'uniform':\n",
    "        opt_lambdas = np.mean(lambdas, axis = 0)\n",
    "    else:\n",
    "        opt_lambdas = [a*b for a,b in zip(weighting, lambdas)]\n",
    "\n",
    "    \n",
    "    \n",
    "    #Post\n",
    "    cntfctl = []\n",
    "    for i in range(len(post_set)):\n",
    "        \n",
    "        if samplesize != 'full':\n",
    "        \n",
    "            # sample controls\n",
    "            sampled_controls = []\n",
    "            for j in range(len(post_set[i])):\n",
    "                sampled_controls.append(np.array(\n",
    "                                        pd.DataFrame(\n",
    "                                            post_set[i][j]).sample(samplesize, random_state = 31)))\n",
    "                \n",
    "        else: sampled_controls = post_set\n",
    "        \n",
    "        n = sampled_controls[0].shape[0]\n",
    "        d = sampled_controls[0].shape[1]\n",
    "        J = len(sampled_controls)\n",
    "\n",
    "        measureweights = [ot.unif(n)]*J\n",
    "        x_init = np.random.normal(0., 1., (n, d))\n",
    "    \n",
    "        cntfctl.append(\n",
    "                ot.lp.free_support_barycenter(sampled_controls, measureweights, \n",
    "                                                  X_init = x_init, weights = opt_lambdas))\n",
    "    \n",
    "    return(opt_lambdas, projections, cntfctl)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "c79b2b60",
   "metadata": {},
   "outputs": [],
   "source": [
    "def permutest_by_timeperiod(PRE, POST, functiontype = 'each', weighting = 'uniform', samplesize = 100):\n",
    "    \n",
    "    \n",
    "    PRE_D = []\n",
    "    POST_D = []\n",
    "    for j in range(len(PRE)): # j is index for each distribution\n",
    "        \n",
    "        if functiontype == 'each' :\n",
    "            weights, pre_p, post_p = twp_by_timeperiod(PRE[j], \n",
    "                                                        PRE[:j]+PRE[j+1:], \n",
    "                                                        POST[:j]+POST[j+1:], \n",
    "                                                        weighting = weighting,\n",
    "                                                        samplesize = samplesize)\n",
    "\n",
    "        elif functiontype == 'all':\n",
    "            weights, pre_p, post_p = twp_singleweights(PRE[j], \n",
    "                                                        PRE[:j]+PRE[j+1:], \n",
    "                                                        POST[:j]+POST[j+1:], samplesize = samplesize)\n",
    "        else:\n",
    "            raise Warning('Unrecognized function type')\n",
    "            \n",
    "            \n",
    "        # distance to pre\n",
    "        pre_dists = []\n",
    "\n",
    "        for k in range(len(PRE[j])): # k is year\n",
    "            \n",
    "            current_pre = np.array(\n",
    "                            pd.DataFrame(PRE[j][k]).sample(samplesize, random_state = 31))\n",
    "            n = current_pre.shape[0]\n",
    "            M = ot.dist(pre_p[k], current_pre)\n",
    "            a_ones, b_ones = np.ones((n,)) / n, np.ones((n,)) / n\n",
    "            dist2pre = ot.emd2(a_ones, b_ones, M)\n",
    "            pre_dists.append(dist2pre)\n",
    "        \n",
    "        \n",
    "        # distance to post\n",
    "        post_dists = []\n",
    "\n",
    "        for l in range(len(POST[j])): # k is year\n",
    "            \n",
    "            current_post = np.array(\n",
    "                            pd.DataFrame(POST[j][l]).sample(samplesize, random_state = 31))\n",
    "            n = current_post.shape[0]\n",
    "            M = ot.dist(post_p[l], current_post)\n",
    "            a_ones, b_ones = np.ones((n,)) / n, np.ones((n,)) / n\n",
    "            dist2post = ot.emd2(a_ones, b_ones, M)\n",
    "            post_dists.append(dist2post)\n",
    "        \n",
    "        PRE_D.append(pre_dists)\n",
    "        POST_D.append(post_dists)\n",
    "            \n",
    "    return(PRE_D, POST_D)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "bb52df89",
   "metadata": {},
   "outputs": [],
   "source": [
    "# plotting function\n",
    "# inputs: 2 outputs of the permutation_by_timeperiod function and vector of time periods\n",
    "# output: plots\n",
    "\n",
    "def plot_byperiod_distances(pre_d, post_d, timeperiods):\n",
    "    \n",
    "    byperiod = pd.concat([pd.DataFrame(pre_d), pd.DataFrame(post_d)], axis = 1)\n",
    "    byperiod.columns = timeperiods\n",
    "    \n",
    "    for i in range(1, len(pre_d)):\n",
    "        plt.plot(byperiod.iloc[i,:], 'bo-')\n",
    "        \n",
    "    #actual target    \n",
    "    plt.plot(byperiod.iloc[0], 'o-', color = 'orange')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "7b00c29a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_pvalue(pre_d, post_d):\n",
    "    \n",
    "    j = len(pre_d)\n",
    "    \n",
    "    byperiod = np.concatenate([pre_d, post_d], axis = 1)\n",
    "    ranktable = (j + 1 - stats.rankdata(byperiod, axis = 0)) / j\n",
    "    \n",
    "    return(ranktable[0,:])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4c081b65",
   "metadata": {},
   "source": [
    "### allperiod weights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f6b8d204",
   "metadata": {},
   "outputs": [],
   "source": [
    "# input: list of target(np.arrays), list of list of controls(arrays), pre and post - each element is one time period\n",
    "# during the first step, we merge all periods into one dataset and sample, and then calculate optimal weights\n",
    "\n",
    "def twp_singleweights(targets, pre_controls, post_controls, samplesize = 100):\n",
    "    \n",
    "    allperiodtarget = np.concatenate(targets)\n",
    "    target = np.array(\n",
    "                    pd.DataFrame(allperiodtarget).sample(samplesize, random_state = 31))\n",
    "    \n",
    "    controls = []\n",
    "    for k in range(len(pre_controls)):\n",
    "        allperiodcontrol = np.concatenate(pre_controls[k])\n",
    "        controls.append(np.array(\n",
    "                            pd.DataFrame(allperiodcontrol).sample(samplesize, random_state = 31)))\n",
    "     \n",
    "    # get weights\n",
    "    opt_lambdas, _ = DSCreplication(target, controls)\n",
    "    \n",
    "    \n",
    "    # restructure controls\n",
    "    pre_set = []\n",
    "    for j in range(len(pre_controls[0])):\n",
    "        tmp = [pre_controls[i][j] for i in range(len(pre_controls))]\n",
    "        pre_set.append(tmp) \n",
    "        \n",
    "    post_set = []\n",
    "    for j in range(len(post_controls[0])):\n",
    "        tmp = [post_controls[i][j] for i in range(len(post_controls))]\n",
    "        post_set.append(tmp)\n",
    "        \n",
    "        \n",
    "    # i is time period\n",
    "    projections = []\n",
    "    for i in range(len(pre_set)):\n",
    "        \n",
    "        if samplesize != 'full':\n",
    "        \n",
    "            # sample controls\n",
    "            sampled_controls = []\n",
    "            for j in range(len(pre_set[i])):\n",
    "                sampled_controls.append(np.array(\n",
    "                                        pd.DataFrame(\n",
    "                                            pre_set[i][j]).sample(samplesize, random_state = 31)))\n",
    "                \n",
    "        else: sampled_controls = pre_set\n",
    "        \n",
    "        n = sampled_controls[0].shape[0]\n",
    "        d = sampled_controls[0].shape[1]\n",
    "        J = len(sampled_controls)\n",
    "\n",
    "        measureweights = [ot.unif(n)]*J\n",
    "        x_init = np.random.normal(0., 1., (n, d))\n",
    "    \n",
    "        projections.append(\n",
    "                ot.lp.free_support_barycenter(sampled_controls, measureweights, \n",
    "                                                  X_init = x_init, weights = opt_lambdas))\n",
    "        \n",
    "    \n",
    "    #Post\n",
    "    cntfctl = []\n",
    "    for i in range(len(post_set)):\n",
    "        \n",
    "        if samplesize != 'full':\n",
    "        \n",
    "            # sample controls\n",
    "            sampled_controls = []\n",
    "            for j in range(len(post_set[i])):\n",
    "                sampled_controls.append(np.array(\n",
    "                                        pd.DataFrame(\n",
    "                                            post_set[i][j]).sample(samplesize, random_state = 31)))\n",
    "                \n",
    "        else: sampled_controls = post_set\n",
    "        \n",
    "        n = sampled_controls[0].shape[0]\n",
    "        d = sampled_controls[0].shape[1]\n",
    "        J = len(sampled_controls)\n",
    "\n",
    "        measureweights = [ot.unif(n)]*J\n",
    "        x_init = np.random.normal(0., 1., (n, d))\n",
    "    \n",
    "        cntfctl.append(\n",
    "                ot.lp.free_support_barycenter(sampled_controls, measureweights, \n",
    "                                                  X_init = x_init, weights = opt_lambdas))\n",
    "    \n",
    "    return(opt_lambdas, projections, cntfctl)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d58fdd2f",
   "metadata": {},
   "source": [
    "## Data-Related functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "2eedd72a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def read_medicaid(file_name, columns, samplesize = 'full'):\n",
    "    \n",
    "    df = pd.read_csv(file_name)[columns]\n",
    "    \n",
    "    if samplesize != 'full':\n",
    "        df = df.sample(samplesize, random_state = 31)\n",
    "    \n",
    "    return(np.array(df))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "0a2986d6",
   "metadata": {},
   "outputs": [],
   "source": [
    "def timeperiod_split(data, start, length):\n",
    "    \n",
    "    df = pd.DataFrame(data)\n",
    "    df.columns = columns2\n",
    "    output = []\n",
    "    for i in range(length):\n",
    "        temp = df[df['YEAR'] == start + i].drop(columns = ['YEAR'])\n",
    "        output.append(np.array(temp))\n",
    "    \n",
    "    return(output)   "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d1ad7cbe",
   "metadata": {},
   "source": [
    "# MEDICAID"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "44203018",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, glob\n",
    "medidata = []\n",
    "\n",
    "columns1 = ['HINSCAID','EMPSTAT','UHRSWORK','INCWAGE']\n",
    "for file in sorted(glob.glob(\"Data/Medicaid_Data/*.csv\")):\n",
    "    medidata.append(read_medicaid(file, columns1))\n",
    "\n",
    "medidata.insert(0, medidata.pop(5))\n",
    "medi_target = medidata[0]\n",
    "medi_controls = medidata[1:]\n",
    "\n",
    "\n",
    "post_medidata = []\n",
    "for file in sorted(glob.glob(\"Data/Medicaid_Data/Counterfactual/*.csv\")):\n",
    "    post_medidata.append(read_medicaid(file, columns1))\n",
    "\n",
    "post_medidata.insert(0, post_medidata.pop(5))\n",
    "post_target = post_medidata[0]\n",
    "post_controls = post_medidata[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "bb40eced",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "weights1, proj1, counf1 = twp4sc(medi_target, medi_controls, post_controls, samplesize = 100, weight_out = True)\n",
    "proj1[:,0:2] = proj1[:,0:2].round(decimals = 0).astype('int32')\n",
    "counf1[:,0:2] = counf1[:,0:2].round(decimals = 0).astype('int32')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "c5acebd2",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         pre      post\n",
      "0   0.362352  0.260019\n",
      "1   0.208028  0.322028\n",
      "2   0.158098  0.365362\n",
      "3   0.075093  0.169004\n",
      "4   0.150374  0.224335\n",
      "5   0.099269  0.408081\n",
      "6   0.080780  0.163581\n",
      "7   0.211087  0.253723\n",
      "8   0.211117  0.286075\n",
      "9   0.101898  0.319003\n",
      "10  0.316187  0.431511\n",
      "11  0.119550  0.272846\n",
      "12  0.116745  0.242503\n"
     ]
    }
   ],
   "source": [
    "pre_d1, post_d1 = permutest4sc(medidata, post_medidata, samplesize = 100)\n",
    "res = pd.concat((pd.DataFrame(pre_d1), pd.DataFrame(post_d1)),axis =1)\n",
    "res.columns = ['pre', 'post']\n",
    "print(res)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "85a4e357",
   "metadata": {},
   "source": [
    "## By_timeperiod"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "d29f9b75",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, glob\n",
    "medidata_yearly = []\n",
    "\n",
    "columns2 = ['YEAR','HINSCAID','EMPSTAT','UHRSWORK','INCWAGE']\n",
    "for file in sorted(glob.glob(\"Data/Medicaid_Data/*.csv\")):\n",
    "    medidata_yearly.append(read_medicaid(file, columns2))\n",
    "\n",
    "medidata_yearly.insert(0, medidata_yearly.pop(5))\n",
    "\n",
    "\n",
    "postmed_yearly = []\n",
    "for file in sorted(glob.glob(\"Data/Medicaid_Data/Counterfactual/*.csv\")):\n",
    "    postmed_yearly.append(read_medicaid(file, columns2))\n",
    "\n",
    "postmed_yearly.insert(0, postmed_yearly.pop(5))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "11a43865",
   "metadata": {},
   "outputs": [],
   "source": [
    "pre_yearly = []\n",
    "for i in range(len(medidata_yearly)):\n",
    "    tmp = timeperiod_split(medidata_yearly[i], 2010, 7)\n",
    "    pre_yearly.append(tmp)\n",
    "\n",
    "preyearly_target = pre_yearly[0]\n",
    "preyearly_controls = pre_yearly[1:]\n",
    "    \n",
    "post_yearly = []\n",
    "for i in range(len(postmed_yearly)):\n",
    "    tmp = timeperiod_split(postmed_yearly[i], 2017, 4)\n",
    "    post_yearly.append(tmp)\n",
    "\n",
    "postyearly_target = post_yearly[0]\n",
    "postyearly_controls = post_yearly[1:]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "de511a2b",
   "metadata": {},
   "source": [
    "### Each"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "77a102d3",
   "metadata": {},
   "outputs": [],
   "source": [
    "weights2, proj2, counf2 = twp_by_timeperiod(preyearly_target, preyearly_controls, \n",
    "                                            postyearly_controls, samplesize = 100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "750493f6",
   "metadata": {},
   "outputs": [],
   "source": [
    "pred, postd = permutest_by_timeperiod(pre_yearly, post_yearly, functiontype = 'each', samplesize = 100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "1955c7f7",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "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": [
    "years = [2010,2011,2012,2013,2014,2015,2016,2017,2018,2019,2020]\n",
    "plot_byperiod_distances(pred, postd, years)\n",
    "plt.savefig('eachyear.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "d8bf850f",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.84615385 0.07692308 0.53846154 1.         1.         0.15384615\n",
      " 1.         0.23076923 0.38461538 0.15384615 0.07692308]\n"
     ]
    }
   ],
   "source": [
    "print(get_pvalue(pred, postd))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "886b99c4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.clf()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bf066fb1",
   "metadata": {},
   "source": [
    "### All"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "9826a812",
   "metadata": {},
   "outputs": [],
   "source": [
    "weights3, proj3, counf3 = twp_singleweights(preyearly_target, preyearly_controls, \n",
    "                                            postyearly_controls, samplesize = 100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "9403e485",
   "metadata": {},
   "outputs": [],
   "source": [
    "pred2,postd2 = permutest_by_timeperiod(pre_yearly, post_yearly, functiontype = 'all', samplesize = 100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "96948974",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "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": [
    "years = [2010,2011,2012,2013,2014,2015,2016,2017,2018,2019,2020]\n",
    "plot_byperiod_distances(pred2, postd2, years)\n",
    "plt.savefig('allyears.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "8f9d08b4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.46153846 0.07692308 0.61538462 0.92307692 0.30769231 0.07692308\n",
      " 0.61538462 0.38461538 0.38461538 0.15384615 0.15384615]\n"
     ]
    }
   ],
   "source": [
    "print(get_pvalue(pred2, postd2))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
