

process_data <- function(dat, a, m){
 
 dat$A = a 
 dat$AC = a*dat$C
 dat$M = m 
 dat$CM = m*dat$C
 dat$AM = a*m
 dat$ACM = a*m*dat$C
 dat = as.matrix(dat)
 
 return(dat)
}

sample_Y <- function(dat, beta_y0, J){
 Y_sample = list()
 
 idx_y = c(1, match(attributes(beta_y0)$names[-1], colnames(dat)))
 mu_p = as.matrix(dat[, idx_y])%*%beta_y0
 
 Y_samp = list()
 for (i in 1:nrow(dat)){
  Y_samp[[i]] = rnorm(J, mu_p[i], 1)
 }
 return(Y_samp)
}
