{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import scipy as sci\n",
    "from tqdm import tqdm\n",
    "from torch.nn import Parameter\n",
    "import scipy.io as sio\n",
    "import scipy.stats as ss\n",
    "import itertools\n",
    "from torch import nn\n",
    "import torch.nn.functional as F\n",
    "from sklearn.neighbors import KernelDensity\n",
    "import time\n",
    "import matplotlib as mpl\n",
    "from matplotlib import colors\n",
    "import os\n",
    "\n",
    "plt.rc('text', usetex=True)\n",
    "\n",
    "font = {\n",
    "    'family' : 'serif',\n",
    "    'weight' : 'normal',\n",
    "    'size'   : 16}\n",
    "plt.rc('font', **font)\n",
    "mpl.rcParams['axes.linewidth'] = 2\n",
    "\n",
    "\n",
    "def sigmoid(x):\n",
    "    return 1 / (1 + np.exp(-x))\n",
    "\n",
    "\n",
    "def simulator(alphas,betas,gammas,S=100, T=100, mu=0, sigma=0, seed=-1,is_plot=0,buffer=20):\n",
    "    '''\n",
    "    Generate the time-varying simulated data (Appendix F.4)\n",
    "    Params\n",
    "    *alphas:  list[2d+1], coupling coefficients for Y\n",
    "    *betas: list[2d+2], coupling coefficients for A\n",
    "    *gammas: list[2d+1], coupling coefficients for X (in the code pack we use L instead)\n",
    "    *S: number of individuals\n",
    "    *T: number of time points per individual\n",
    "    *mu, sigma: mean/std of the observational noise for Y\n",
    "    *seed: random seed\n",
    "    *is_plot: if plot simulated data \n",
    "    '''\n",
    "    if seed >=0:\n",
    "        np.random.seed(seed)\n",
    "    d= int((len(betas)-2)/2)\n",
    "    Y = np.zeros([S,T-d+1])\n",
    "    L = np.zeros([S,T])\n",
    "    A = np.zeros([S,T])\n",
    "    f = np.zeros([S,T])\n",
    "    #initial L is uniform\n",
    "    L[:,0] = np.random.uniform(size=S)\n",
    "    f[:,0] = sigmoid(betas[0]+betas[1]*L[:,0])\n",
    "    A[:,0] = np.random.binomial(1,f[:,0])\n",
    "\n",
    "    for t in range(1,d):\n",
    "        L[:,t] = gammas[0]+A[:,:t]@gammas[1:1+t]+L[:,:t]@gammas[1+d:1+d+t]\n",
    "        f[:,t] = sigmoid(betas[0]+A[:,:t]@betas[1:1+t]+L[:,:t+1]@betas[1+d:2+d+t])\n",
    "        A[:,t] = np.random.binomial(1,f[:,t])\n",
    "\n",
    "    for t in range(d,T):\n",
    "        L[:,t] = gammas[0]+A[:,t-d:t]@gammas[1:1+d]+L[:,t-d:t]@gammas[1+d:]\n",
    "        f[:,t] = sigmoid(betas[0]+A[:,t-d:t]@betas[1:1+d]+L[:,t-d:t+1]@betas[1+d:])\n",
    "        A[:,t] = np.random.binomial(1,f[:,t])\n",
    "        Y[:,t-d] = alphas[0] + A[:,t-d:t]@alphas[1:1+d]+ L[:,t-d:t]@alphas[1+d:]\n",
    "    Y[:,-1] = alphas[0] + A[:,T-d:T]@alphas[1:1+d]+ L[:,T-d:T]@alphas[1+d:]\n",
    "    \n",
    "    if sigma>0:\n",
    "        Y=Y+np.random.normal(mu,sigma,Y.shape) \n",
    "\n",
    "    #return by squeezing the time and individual dims\n",
    "    L_,f_,A_ = np.zeros([S,T-d+1,d]),np.zeros([S,T-d+1,d]),np.zeros([S,T-d+1,d])\n",
    "    for kk in range(T-d+1):\n",
    "        L_[:,kk] = L[:,kk:kk+d]\n",
    "        f_[:,kk] = f[:,kk:kk+d]\n",
    "        A_[:,kk] = A[:,kk:kk+d]    \n",
    "    simu_data =  [Y[:,:],L_[:,:],A_[:,:],f_[:,:]]\n",
    "    if is_plot:\n",
    "        plot_simu(simu_data)\n",
    "    \n",
    "    Y,L,A,f = Y[:,buffer:].reshape(-1,order='C'),L_[:,buffer:].reshape(-1,d,order='C'),A_[:,buffer:].reshape(-1,d,order='C'),f_[:,buffer:].reshape(-1,d,order='C')\n",
    "    simu_data = [Y,L,A,f]\n",
    "    return(simu_data)\n",
    "\n",
    "\n",
    "def simu_unconfounded(alphas,betas,gammas,at=None,S=100, T=100, mu=0, sigma=0, seed=-1,is_plot=0):\n",
    "    '''\n",
    "    Generate the counterfactual outcome distribution (Algo 2, Appendix F.4)\n",
    "    Params\n",
    "    *alphas:  list[2d+1], coupling coefficients for Y\n",
    "    *betas: list[2d+2], coupling coefficients for A\n",
    "    *gammas: list[2d+1], coupling coefficients for L (X in the paper)\n",
    "    *S: number of individuals\n",
    "    *T: number of time points per individual\n",
    "    *mu, sigma: mean/std of the observational noise for Y\n",
    "    *seed: random seed\n",
    "    *is_plot: if plot simulated data \n",
    "    '''\n",
    "    if seed >=0:\n",
    "        np.random.seed(seed)\n",
    "    d= int((len(betas)-2)/2)\n",
    "    Y = np.zeros([S,T-d+1])\n",
    "    L = np.zeros([S,T])\n",
    "    f = np.zeros([S,T])\n",
    "    \n",
    "    A = np.zeros([S,T])\n",
    "    #initial L is uniform\n",
    "    L[:,0] = np.random.uniform(size=S)\n",
    "    f[:,0] = sigmoid(betas[0]+betas[1]*L[:,0])\n",
    "    A[:,0] = np.random.binomial(1,f[:,0])\n",
    "\n",
    "    for t in range(1,d):\n",
    "        L[:,t] = gammas[0]+A[:,:t]@gammas[1:1+t]+L[:,:t]@gammas[1+d:1+d+t]\n",
    "        f[:,t] = sigmoid(betas[0]+A[:,:t]@betas[1:1+t]+L[:,:t+1]@betas[1+d:2+d+t])\n",
    "        A[:,t] = np.random.binomial(1,f[:,t])\n",
    "\n",
    "    for t in range(d,T-d):\n",
    "        L[:,t] = gammas[0]+A[:,t-d:t]@gammas[1:1+d]+L[:,t-d:t]@gammas[1+d:]\n",
    "        f[:,t] = sigmoid(betas[0]+A[:,t-d:t]@betas[1:1+d]+L[:,t-d:t+1]@betas[1+d:])\n",
    "        A[:,t] = np.random.binomial(1,f[:,t])\n",
    "        Y[:,t-d] = alphas[0] + A[:,t-d:t]@alphas[1:1+d]+ L[:,t-d:t]@alphas[1+d:]\n",
    "    A[:,T-d:] = at\n",
    "    for t in range(T-d,T):\n",
    "        L[:,t] = gammas[0]+A[:,t-d:t]@gammas[1:1+d]+L[:,t-d:t]@gammas[1+d:]\n",
    "        Y[:,t-d] = alphas[0] + A[:,t-d:t]@alphas[1:1+d]+ L[:,t-d:t]@alphas[1+d:]\n",
    "    Y[:,-1] = alphas[0] + A[:,T-d:T]@alphas[1:1+d]+ L[:,T-d:T]@alphas[1+d:]\n",
    "    \n",
    "    if sigma>0:\n",
    "        Y=Y+np.random.normal(mu,sigma,Y.shape) \n",
    "\n",
    "    return(Y[:,-1])\n",
    "\n",
    "def plot_simu(simu_data):\n",
    "    '''\n",
    "    Plot simulated data\n",
    "    '''\n",
    "    Y,L,A,f = simu_data\n",
    "    d = A.shape[-1]\n",
    "    fig,ax = plt.subplots(1,4, figsize=(12,2.5))\n",
    "    data_to_plot = [Y,L,A,f]\n",
    "    labels = ['Y','X','A','f']\n",
    "    for i in range(4):\n",
    "        if i==0:\n",
    "            ax[i].plot((data_to_plot[i][:3,:30]).T)\n",
    "        else:\n",
    "            ax[i].plot((data_to_plot[i][:3,:30,-1]).T)\n",
    "        ax[i].set_ylabel(labels[i])\n",
    "        ax[i].set_xlabel('Time')\n",
    "        ax[i].spines['right'].set_visible(False)\n",
    "        ax[i].spines['top'].set_visible(False)\n",
    "    plt.subplots_adjust(wspace=0.5)\n",
    "    plt.show()\n",
    "\n",
    "    Y,L,A,f = Y.reshape(-1,order='C'),L.reshape(-1,d,order='C'),A.reshape(-1,d,order='C'),f.reshape(-1,d,order='C')\n",
    "\n",
    "    fig,ax = plt.subplots(1,4, figsize=(12,2.5))\n",
    "    data_to_plot = [Y,L,A,f]\n",
    "    for i in range(4):\n",
    "        ax[i].hist(data_to_plot[i].flatten(),bins=100)\n",
    "        ax[i].set_xlabel(labels[i])\n",
    "        ax[i].set_ylabel('count')\n",
    "        ax[i].spines['right'].set_visible(False)\n",
    "        ax[i].spines['top'].set_visible(False)\n",
    "    plt.subplots_adjust(wspace=0.5)\n",
    "    plt.show()\n",
    "\n",
    "    A_unique = np.unique(A,axis=0)\n",
    "    Y_trues = []     \n",
    "    for a in A_unique:\n",
    "        inds  = np.where(np.all(A==a,axis=1)) \n",
    "        Y_trues.append(Y[inds])\n",
    "\n",
    "    for cnt in range(len(A_unique)):\n",
    "        plt.hist(Y_trues[cnt],alpha = 0.8,bins=50, label='true dist',density=True)\n",
    "\n",
    "        plt.title('A='+str(A_unique[cnt]) + '\\n proportion = %.2f'%(len(Y_trues[cnt])/len(Y)) + '\\n mean = %.2f'%(Y_trues[cnt].mean()))\n",
    "\n",
    "        plt.xlabel('Y')\n",
    "        plt.ylabel('count')\n",
    "\n",
    "        plt.show()\n",
    "\n",
    "def generate_train_test(simu_data,train_size,test_size,seed =-1):\n",
    "    '''\n",
    "    Generate the training and validation data for training CVAE/MSCVAE\n",
    "    For simplicity in this demo, we compute the IPTW using the propensity scores directly from the simulator.\n",
    "    In practice, one can pick a favorite NN model to estimate the propensity scores.\n",
    "    '''\n",
    "    if seed >=0:\n",
    "        np.random.seed(seed)\n",
    "    Y,L,A,f = simu_data\n",
    "    d = A.shape[-1]\n",
    "    if len(Y.shape)>1:\n",
    "        Y,L,A,f = Y.reshape(-1,order='C'),L.reshape(-1,d,order='C'),A.reshape(-1,d,order='C'),f.reshape(-1,d,order='C')\n",
    "    inds = np.random.permutation(range(len(Y)))\n",
    "    Y,L,A,f = Y[inds],L[inds],A[inds],f[inds]\n",
    "\n",
    "    sim_data_y_train=torch.Tensor(A[:train_size])\n",
    "    sim_data_y_test=torch.Tensor(A[train_size:train_size+test_size])\n",
    "\n",
    "    sim_data_x_train=torch.Tensor(Y[:train_size])[:,None]\n",
    "    sim_data_x_test=torch.Tensor(Y[train_size:train_size+test_size])[:,None]\n",
    "\n",
    "    w_train = np.prod(1/(np.multiply(f[:train_size],A[:train_size])+np.multiply(1-f[:train_size],1-A[:train_size])),axis=1)\n",
    "    w_train=clip_w(w_train,0.01,99.99,True)\n",
    "    w_train=torch.Tensor(w_train)\n",
    "    training_set  = [sim_data_y_train,sim_data_y_test,sim_data_x_train,sim_data_x_test,w_train]\n",
    "    return(training_set)\n",
    "\n",
    "class CVAE(nn.Module):\n",
    "    def __init__(self, input_size, labels_length,hidden_size=20, layer_width = 128):\n",
    "        super(CVAE, self).__init__()\n",
    "        self.hidden_size = hidden_size\n",
    "        self.input_size=input_size\n",
    "        self.labels_length=labels_length\n",
    "        input_size_with_label = self.input_size + self.labels_length\n",
    "        self.layer_width=layer_width\n",
    "        \n",
    "        self.fc1 = nn.Linear(input_size_with_label,self.layer_width)\n",
    "        self.fc21 = nn.Linear(self.layer_width, hidden_size)\n",
    "        self.fc22 = nn.Linear(self.layer_width, hidden_size)\n",
    "        self.relu = nn.ReLU()\n",
    "        \n",
    "        self.fc3 = nn.Linear(hidden_size+self.labels_length, self.layer_width)\n",
    "        self.fc4 = nn.Linear(self.layer_width, input_size)\n",
    "    \n",
    "    def encode(self, x, labels):\n",
    "        x = x.view(-1, self.input_size)\n",
    "        x = torch.cat((x, labels), 1)\n",
    "        x = self.relu(self.fc1(x))\n",
    "        return self.fc21(x), self.fc22(x)\n",
    "        \n",
    "    def decode(self, z, labels):\n",
    "        z = torch.cat((z, labels), 1)\n",
    "        z = self.relu(self.fc3(z))\n",
    "        return self.fc4(z)\n",
    "        \n",
    "    def reparameterize(self, mu, logvar):\n",
    "        std = torch.exp(0.5 *logvar)\n",
    "        eps = torch.randn_like(std)\n",
    "        return eps.mul(std).add_(mu)\n",
    "        \n",
    "    def forward(self,x, labels):\n",
    "        mu, logvar = self.encode(x, labels)\n",
    "        z = self.reparameterize(mu, logvar)\n",
    "        x = self.decode(z, labels)\n",
    "        return x, mu, logvar\n",
    "\n",
    "\n",
    "\n",
    "def vae_loss_fn(x, recon_x, mu, logvar,w_train):\n",
    "    # loss function for the CVAE/MSCVAE\n",
    "    if  w_train is None: # for the unweighted loss\n",
    "        BCE = F.mse_loss(recon_x, x, reduction='mean')\n",
    "        KLD = -0.5 * torch.mean(1 + logvar - mu.pow(2) - logvar.exp())\n",
    "        return BCE + KLD\n",
    "    else: # for the weighted loss\n",
    "        BCE = (F.mse_loss(recon_x, x, reduction='none')*w_train[:,None]).mean()\n",
    "        KLD = -0.5 * torch.mean((1 + logvar - mu.pow(2) - logvar.exp())*w_train[:,None])\n",
    "        return BCE + KLD\n",
    "\n",
    "def clip_w(w,a=1,b=99,mean_norm=True):\n",
    "    #clip the IPTW weights to to percentiles within [a,b] and normalize them by means.\n",
    "    if a>0 or b<100:\n",
    "        a,b = np.percentile(w.flatten(),[a,b])\n",
    "        w = np.clip(w,a,b)\n",
    "    if mean_norm:\n",
    "        w=w/w.mean()\n",
    "    return(w)\n",
    "\n",
    "def train(training_set, hidden_size=10,layer_width=128,epochs=60,batch_size = 256,is_msm=0,learning_rate = 0.001,seed = -1):\n",
    "    '''\n",
    "    Train the CVAE/MSCVAE\n",
    "    Params\n",
    "    *training_set:  set of training and testing data\n",
    "    *hidden_size: hidden size (latent dim) for the autoencoder\n",
    "    *layer_width: width of the hidden layer\n",
    "    *epochs: number of training epochs\n",
    "    *batch_size: training batch size\n",
    "    *is_msm: =0 for CVAE, =1 for MSCVAE\n",
    "    *learning_rate: training learning rate\n",
    "    *seed : random seed\n",
    "    '''\n",
    "    if seed >=0:\n",
    "        np.random.seed(seed)\n",
    "    sim_data_y_train,sim_data_y_test,sim_data_x_train,sim_data_x_test,w_train = training_set \n",
    "    if is_msm:\n",
    "        plt.hist(w_train.detach().numpy(),bins=100, density=True)\n",
    "        plt.xlabel('IPTW')\n",
    "        plt.ylabel('count')\n",
    "        plt.title('IPTW distribution')\n",
    "        plt.show()\n",
    "    \n",
    "    input_size = sim_data_x_train.shape[-1]\n",
    "    labels_length = sim_data_y_train.shape[-1]\n",
    "    \n",
    "    DEVICE = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "    print('Using device:', DEVICE)\n",
    "    \n",
    "    cvae = CVAE(input_size,labels_length,hidden_size,layer_width).to(DEVICE)\n",
    "    validation_losses = []\n",
    "    train_losses = []\n",
    "    optim = torch.optim.Adam(cvae.parameters(), lr=learning_rate)\n",
    "    scheduler = torch.optim.lr_scheduler.StepLR(optim, step_size=int(epochs/3), gamma=0.5)\n",
    "    n_batch = int(len(sim_data_x_train)/batch_size)\n",
    "    with tqdm(desc=\"epoch\", total=epochs) as pbar_outer:  \n",
    "        for i in range(epochs):\n",
    "            for batch in range(n_batch):\n",
    "                optim.zero_grad()\n",
    "                train_x = sim_data_x_train[batch*batch_size:(batch+1)*batch_size]\n",
    "                train_y = sim_data_y_train[batch*batch_size:(batch+1)*batch_size]\n",
    "                x,mu,logvar = cvae(train_x,train_y)\n",
    "                if is_msm:\n",
    "                    loss = vae_loss_fn(train_x, x, mu, logvar,w_train[batch*batch_size:(batch+1)*batch_size])\n",
    "                else:\n",
    "                    loss = vae_loss_fn(train_x, x, mu, logvar,None)\n",
    "                if i%50 ==0:\n",
    "                    train_losses.append(loss.detach().numpy())\n",
    "                    x_test,mu_test,logvar_test = cvae(sim_data_x_test,sim_data_y_test)\n",
    "                    validation_losses.append(vae_loss_fn(sim_data_x_test, x_test, mu_test, logvar_test,None).detach().numpy())\n",
    "                        \n",
    "                loss.backward()\n",
    "                optim.step()\n",
    "            scheduler.step()\n",
    "            pbar_outer.update(1)\n",
    "    val_err = np.mean(validation_losses[-10:])\n",
    "    print('validation err: ' + str(val_err))\n",
    "    return(cvae,train_losses,validation_losses)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "def draw_samples(simu_settings,cvae,cvae_w,training_set):\n",
    "    '''\n",
    "    Obtain samples from the trained CVAE/MSCVAE\n",
    "    Params\n",
    "    *simu_settings:  simulation parameters\n",
    "    *cvae: trained CVAE\n",
    "    *cvae_w: trained MSCVAE\n",
    "    *training_set: set of training and testing data\n",
    "    '''\n",
    "    d,ycoeff,acoeff,lcoeff,mu,sigma,_,_,_ = simu_settings\n",
    "    n_reap=10000\n",
    "    S_causal=n_reap\n",
    "    T_causal=100\n",
    "    Y_trues_simu = []\n",
    "    cvae_sample = [] \n",
    "    cvae_w_sample = []  \n",
    "\n",
    "    \n",
    "    Y_train = np.squeeze(training_set[2].numpy())\n",
    "    w_train = np.squeeze(training_set[-1].numpy())\n",
    "    A_train = training_set[0].numpy()\n",
    "    hidden_size = cvae.hidden_size\n",
    "    A_unique = list(itertools.product([0, 1], repeat=d))\n",
    "    \n",
    "    for a in A_unique:\n",
    "        if d == 1:\n",
    "            inds  = np.where(A_train==a)[0]#for d=1\n",
    "        else:\n",
    "            inds  = np.where(np.all(A_train==a,axis=1))#for d>1\n",
    "             \n",
    "        tmp = cvae.decode(torch.Tensor(np.random.randn(n_reap, hidden_size)),torch.Tensor(a).repeat(n_reap,1))\n",
    "        cvae_sample.append(tmp.detach().numpy()) \n",
    "        \n",
    "        tmp = cvae_w.decode(torch.Tensor(np.random.randn(n_reap, hidden_size)),torch.Tensor(a).repeat(n_reap,1))\n",
    "        cvae_w_sample.append(tmp.detach().numpy())\n",
    "        \n",
    "        Y_trues_simu.append(simu_unconfounded(ycoeff,acoeff,lcoeff,a,S_causal, T_causal, mu, sigma, seed=-1, is_plot=1))\n",
    "    return(Y_trues_simu,cvae_sample,cvae_w_sample)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "def plot_compute(d,Y_trues_simu,cvae_sample,cvae_w_sample,figname):\n",
    "    '''\n",
    "    Visualize and return simulation results\n",
    "    Params\n",
    "    *d:  length of history dependence\n",
    "    *Y_trues_simu: counterfactual outcome distribution\n",
    "    *cvae_sample/cvae_w_sample: outcome samples from the trained CVAE/MSCVAE\n",
    "    *figname: name for saving figures\n",
    "    '''\n",
    "    print('d=%d'%(d))\n",
    "    if d ==1:\n",
    "        fig, axs = plt.subplots(2,1,figsize=(1.7,3.5))\n",
    "        nrow=2\n",
    "        ncol=1\n",
    "        \n",
    "    elif d == 2:  \n",
    "        fig, axs = plt.subplots(2,2,figsize=(3.5,3.5))\n",
    "        nrow=2\n",
    "        ncol=2\n",
    "        \n",
    "    elif d == 3:  \n",
    "        fig, axs = plt.subplots(2,4,figsize=(6.5,3.5))\n",
    "        nrow=2\n",
    "        ncol=4\n",
    "        \n",
    "    elif d == 4:  \n",
    "        fig, axs = plt.subplots(4,4,figsize=(6.5,6))\n",
    "        nrow=4\n",
    "        ncol=4\n",
    "    elif d ==5:\n",
    "        fig, axs = plt.subplots(4,8,figsize=(10,6))\n",
    "        nrow=4\n",
    "        ncol=8\n",
    "    dmax = 0\n",
    "    cnt=0\n",
    "    md_cvae = []\n",
    "    wd_cvae = []\n",
    "    tv_cvae = []\n",
    "    md_mscvae = []\n",
    "    wd_mscvae = []\n",
    "    tv_mscvae = []\n",
    "\n",
    "    A_unique = list(itertools.product([0, 1], repeat=d))\n",
    "\n",
    "    for i in range(nrow):\n",
    "        for j in range(ncol):\n",
    "\n",
    "            if d == 1:\n",
    "                axs[cnt].spines['right'].set_visible(False)\n",
    "                axs[cnt].spines['top'].set_visible(False)\n",
    "                axs[cnt].tick_params(left = False, right = False , labelleft = False)\n",
    "\n",
    "            else:\n",
    "                axs[i,j].spines['right'].set_visible(False)\n",
    "                axs[i,j].spines['top'].set_visible(False)\n",
    "                axs[i,j].tick_params(left = False, right = False , labelleft = False)\n",
    "\n",
    "            hists = np.histogram(Y_trues_simu[cnt],density=True,bins=100)\n",
    "            (dens_true, cutoffs) = hists[0],hists[1]\n",
    "            if d==1:\n",
    "                axs[cnt].plot((cutoffs[1:]+cutoffs[:-1])/2,dens_true,label=r'\\texttt{True}',color='k',linewidth=2,alpha=1)\n",
    "            else:\n",
    "                axs[i,j].plot((cutoffs[1:]+cutoffs[:-1])/2,dens_true,label=r'\\texttt{True}',color='k',linewidth=2,alpha=1)\n",
    "            dmax=max(dmax,np.max(dens_true))\n",
    "\n",
    "            if d==1:\n",
    "                hists = axs[cnt].hist(cvae_sample[cnt],density=True,bins=100,label=r'\\texttt{CVAE}',color='grey',alpha=0.7)\n",
    "            else:\n",
    "                hists = axs[i,j].hist(cvae_sample[cnt],density=True,bins=100,label=r'\\texttt{CVAE}',color='grey',alpha=0.7)\n",
    "            (dens, cutoffs) = hists[0],hists[1]\n",
    "            dmax=max(dmax,np.max(dens))\n",
    "            tv_cvae.append(np.abs(dens_true-dens).mean())\n",
    "\n",
    "            if d==1:\n",
    "                hists = axs[cnt].hist(cvae_w_sample[cnt],density=True,bins=100,label=r'\\texttt{MSCVAE}',color='orangered',alpha=0.7)\n",
    "            else:   \n",
    "                hists = axs[i,j].hist(cvae_w_sample[cnt],density=True,bins=100,label=r'\\texttt{MSCVAE}',color='orangered',alpha=0.7)\n",
    "            (dens, cutoffs) = hists[0],hists[1]\n",
    "            dmax=max(dmax,np.max(dens))\n",
    "            tv_mscvae.append(np.abs(dens_true-dens).mean())\n",
    "\n",
    "\n",
    "            if d==1:\n",
    "                axs[cnt].set_title(r'$\\overline{a}=$('+','.join([str(int(a)) for a in str(A_unique[cnt]) if a.isdigit()])+')')\n",
    "                axs[cnt].set_ylim([0,dmax])\n",
    "            else:  \n",
    "                axs[i,j].set_title(r'$\\overline{a}=$('+','.join([str(int(a)) for a in str(A_unique[cnt]) if a.isdigit()])+')')\n",
    "                axs[i,j].set_ylim([0,dmax])\n",
    "\n",
    "            if j>0:\n",
    "                axs[i,j].spines['left'].set_visible(False)\n",
    "\n",
    "            if d==1:\n",
    "                axs[cnt].tick_params( axis='x', which='both',  bottom=False, top=False,labelbottom=False)\n",
    "            else:\n",
    "                axs[i,j].tick_params( axis='x', which='both',  bottom=False, top=False,labelbottom=False)\n",
    "\n",
    "\n",
    "            md_cvae.append(np.abs(np.mean(Y_trues_simu[cnt])-np.mean(cvae_sample[cnt][:,0])))\n",
    "            wd_cvae.append(ss.wasserstein_distance(Y_trues_simu[cnt],cvae_sample[cnt][:,0]))\n",
    "            md_mscvae.append(np.abs(np.mean(Y_trues_simu[cnt])-np.mean(cvae_w_sample[cnt][:,0])))\n",
    "            wd_mscvae.append(ss.wasserstein_distance(Y_trues_simu[cnt],cvae_w_sample[cnt][:,0]))\n",
    "           \n",
    "            cnt+=1\n",
    "\n",
    "    order = [0,1,2]\n",
    "    if d == 1:\n",
    "        handles, labels = axs[0].get_legend_handles_labels()\n",
    "        fig.legend([handles[i] for i in order], [labels[i] for i in order],ncol=1,bbox_to_anchor=(-0.2,0.7))\n",
    "        fig.text(-0.08, 0.5, r'$f_{\\overline{a}}$', ha='center')\n",
    "    elif d==3:\n",
    "        fig.text(-0.015, 0.5, r'$f_{\\overline{a}}$', ha='center')\n",
    "    else:\n",
    "        fig.text(-0.013, 0.5, r'$f_{\\overline{a}}$', ha='center')\n",
    "    fig.text(0.5, -0.03, r'$Y(\\overline{a})$', ha='center')\n",
    "    fig.tight_layout()\n",
    "    plt.show()\n",
    "    print(figname)\n",
    "    print('CVAE   mean: %.3f, wasserstein: %.3f'%(np.mean(md_cvae),np.mean(wd_cvae)))    \n",
    "    print('MSCVAE   mean: %.3f, wasserstein: %.3f'%(np.mean(md_mscvae),np.mean(wd_mscvae)))\n",
    "    \n",
    "    results = {'md_cvae':np.mean(md_cvae), 'wd_cvae':np.mean(wd_cvae) ,'md_mscvae':np.mean(md_mscvae),\n",
    "               'wd_mscvae':np.mean(wd_mscvae), 'tv_cvae':np.mean(tv_cvae),'tv_mscvae':np.mean(tv_mscvae)}\n",
    "    fig.savefig(figname + '.pdf',bbox_inches='tight')   \n",
    "    return(results)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Simulation setting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "d=1 #length of history dependence\n",
    "train_size=30000 #training data size. We recommend train_size = 50000*d or even more for optimal results\n",
    "latent_dim=5 #hidden size (latent dim) for CVAE/MSCVAE\n",
    "epoch=100 #training epochs for CVAE/MSCVAE\n",
    "\n",
    "'''\n",
    "Recommended simulation coefficients for different d\n",
    "'''\n",
    "\n",
    "\n",
    "if d==1:\n",
    "    ycoeff = [-3,2,-1] # Y\n",
    "    acoeff = [-0.5,0.5,-0.5,0.5] # A\n",
    "    xcoeff = [0,1,-1] # X\n",
    "elif d==3:\n",
    "    ycoeff=[-1] + [3,6,12] + [0.5,1,2]# Y\n",
    "    acoeff= [-0.5] + [0.5,-0.5,0.5] + [-0.5,0.5,-0.5,0.5]# A\n",
    "    xcoeff= [-1] + [0.5,1,1.5] + [-0.5,-1,-1.5]# X\n",
    "else:\n",
    "    ycoeff=[-1] + [0.5,1,3,6,12] + [0.05,0.1, 0.5,1,2]# Y\n",
    "    acoeff= [-0.5] + [0.5,-0.5,0.5,-0.5,0.5] + [-0.5,0.5,-0.5,0.5,-0.5,0.5]# A\n",
    "    xcoeff= [-1] + [0.05,0.1, 0.5,1,1.5] + [-0.05,-0.1, -0.5,-1,-1.5]  # X\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Generate simulated data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x180 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x180 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\n",
    "S=10000\n",
    "buffer=20\n",
    "T=100+buffer\n",
    "mu=0\n",
    "sigma=0.01\n",
    "seed=1\n",
    "simu_data = simulator(ycoeff,acoeff,xcoeff,S, T, mu, sigma, seed=seed, is_plot=1)\n",
    "simu_settings = [d,ycoeff,acoeff,xcoeff,mu,sigma,S,T,buffer]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Train CVAE/MSCVAE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using device: cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "epoch: 100%|██████████████████████████████████| 100/100 [00:25<00:00,  3.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "validation err: 0.2592595\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using device: cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "epoch: 100%|██████████████████████████████████| 100/100 [00:26<00:00,  3.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "validation err: 0.26811606\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "test_size = 1000 # Validation data size (only for training purpose)\n",
    "layer_width=1000 # CVAE/MSCVAE layer width\n",
    "batch_size=256 # Training batch size\n",
    "input_size=1 #input size to the autoencoders (=1 for 1-d outcome vars)\n",
    "if train_size < batch_size:\n",
    "    batch_size = train_size\n",
    "learning_rate=0.001 # Training learning rate\n",
    "training_set = generate_train_test(simu_data,train_size,test_size,seed)\n",
    "\n",
    "#filename for saving figures\n",
    "figname =  'synthetic_d%d_train%d_latent%d_epoch%d'%(d, train_size, latent_dim, epoch)\n",
    "\n",
    "#If the trained model exists, load models, otherwise, start training.\n",
    "\n",
    "#CVAE\n",
    "if os.path.exists('cvae_'+figname+'.pt'):\n",
    "    print('cvae exists, loading')\n",
    "    cvae = CVAE(input_size,d,latent_dim,layer_width) \n",
    "    cvae.load_state_dict(torch.load('cvae_'+figname+'.pt'))\n",
    "else:\n",
    "    cvae,train_losses,validation_losses = train(training_set, hidden_size=latent_dim,layer_width=layer_width,epochs=epoch,batch_size=batch_size,is_msm=0,learning_rate=learning_rate)\n",
    "    plt.plot(np.log(train_losses))\n",
    "    plt.ylabel('training loss')\n",
    "    plt.show()\n",
    "    torch.save(cvae.state_dict(), 'cvae_'+figname+'.pt')\n",
    "\n",
    "    \n",
    "#MSCVAE\n",
    "if os.path.exists('cvae_w_'+figname+'.pt'):\n",
    "    print('cvae_w exists, loading')\n",
    "    cvae_w = CVAE(input_size,d,latent_dim,layer_width)\n",
    "    cvae_w.load_state_dict(torch.load('cvae_w_'+figname+'.pt'))\n",
    "else:\n",
    "    cvae_w,train_losses_w,validation_losses_w = train(training_set, hidden_size=latent_dim,layer_width=layer_width,epochs=epoch,batch_size=batch_size,is_msm=1,learning_rate=learning_rate)\n",
    "    plt.plot(np.log(train_losses_w))\n",
    "    plt.ylabel('training loss')\n",
    "    plt.show()\n",
    "    torch.save(cvae_w.state_dict(), 'cvae_w_'+figname+'.pt')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Obtain counterfactual and learned samples for the outcome"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Draw the samples\n",
    "Y_trues_simu,cvae_sample,cvae_w_sample = draw_samples(simu_settings,cvae,cvae_w,training_set)\n",
    "\n",
    "# Save the samples\n",
    "sio.savemat(figname+'_data.mat', mdict={'Y_trues_simu':Y_trues_simu,'cvae_sample':cvae_sample,'cvae_w_sample':cvae_w_sample})"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Visualize learned distributions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "d=1\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 122.4x252 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "synthetic_d1_train30000_latent5_epoch100\n",
      "CVAE   mean: 0.251, wasserstein: 0.254\n",
      "MSCVAE   mean: 0.008, wasserstein: 0.075\n"
     ]
    }
   ],
   "source": [
    "# plot and print results\n",
    "results = plot_compute(d,Y_trues_simu,cvae_sample,cvae_w_sample,figname)"
   ]
  }
 ],
 "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
