Generate_median <- function(N=2000){
  
  require(bindata)
  require(MASS)
  
  w1 <- rbinom(N, 1, prob = 0.3)
  w2 <- rbinom(N, 1, prob = 0.4)
  w3 <- rbinom(N, 1, prob = 0.5)
  w4 <- rbinom(N, 1, prob = 0.6)

  u1 <- rbinom(N, 1, prob = 0.7)
  
  
  ptr <- 0.15*(0.75*w1+0.25*(1-w1)) + 0.15*(0.75*w2+0.25*(1-w2)) + 0.15*(0.75*w3+0.25*(1-w3)) + 0.15*(0.75*w4+0.25*(1-w4)) + 0.4*(0.75*u1+0.25*(1-u1))
  t <- rbinom(N, 1, prob = ptr)
  
  em1 <- rnorm(N,mean=0,sd=1)
  em2 <- rnorm(N,mean=0,sd=1)
  
  cc <- rnorm(N,mean=5,sd=1)
  
  FD1 <- 5*t + cc*(w1+w2+w3+w4) + em1
  FD2 <- 5*t + cc*(w1+w2+w3+w4) + em2
  
  x5 <- rnorm(N, mean = FD1, sd = 0.01)
  x6 <- rnorm(N, mean = FD1, sd = 0.1)
  x7 <- rnorm(N, mean = FD2, sd = 0.01)
  x8 <- rnorm(N, mean = FD2, sd = 0.1)
  
  c <- rnorm(N,mean=1,sd=1)
  ey <- rnorm(N,mean=0,sd=1)
  
  y <- c*(w1+w2+w3+w4) + 10*u1 + FD1 + FD2 + ey
  
  dat<-cbind.data.frame(y,t,w1,w2,w3,w4,x5,x6,x7,x8)
  
  return(dat)
}
