R/gof_calc.R

Defines functions gof_zpois gof_znb gof_pois gof_ordi gof_nb gof_bin

#' @keywords internal
gof_bin <- function(B, bimodel = NULL, seed=NULL) {
  if (!is.null(seed)) set.seed(seed)
  if( is.null(bimodel)) stop("model object is not given.")
  y <- bimodel$model[, 1]
  n <- length(y)
  p1f <- bimodel$fitted.values
  dfx <- model.matrix(bimodel)
  fam <- bimodel$family
  como <- combn(n,2)
  ind1 <- como[1,]
  ind2 <- como[2,]


  ## F(Y), F(Y-1), P(Y)

  Fy <- ifelse(y==1,1,1-p1f)
  Fy1 <-  ifelse(y==0,0,1-p1f)
  dy <- ifelse(y==1,p1f,1-p1f)

  ## The test statistic is calculated by parts

  int1new <- sum(1/3*(Fy^4+Fy1^4-Fy^3*Fy1-Fy*Fy1^3-2*Fy^3-Fy1^3+3*Fy^2*Fy1+Fy^2-2*Fy*Fy1+Fy1^2)/dy^2)


  Fy1new <- sort(Fy1)
  Fynew <- Fy[sort(Fy1,index=TRUE)$ix]
  dynew <- dy[sort(Fy1,index=TRUE)$ix]




  ###no overlap
  group1 <- which(Fy1new[ind2]>Fynew[ind1])
  ## overlap, and keep order. k=ind1,k'=ind2,m=ind2,m'=ind1
  group2 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]>Fynew[ind1])
  ## overlap, and switch order for on right side. k=ind1,k'=ind2,m=ind1,m'=ind2
  group3 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]<=Fynew[ind1])
  group4 <- which(Fy1new[ind2]<=Fynew[ind1])

  ind2new1 <- sum(((Fynew^3-Fy1new^3)/6/dynew)[ind1[group1]])

  ind2new2 <- sum(((Fynew^3-Fy1new^3-3*Fynew^2+3*Fy1new^2+2*Fynew-2*Fy1new)/dynew/6)[ind2[group1]])


  indnew3p1 <- sum((-Fy1new[ind1[group4]]^3-2*Fy1new[ind2[group4]]^3*(1-dynew[ind1[group4]])+3*Fy1new[ind1[group4]]*Fy1new[ind2[group4]]^2)/6/dynew[ind1[group4]])



  indnew3p2 <- sum((1-dynew[ind1[group2]])*(1-dynew[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^3-Fy1new[ind2[group2]]^3)/3) +
    sum((1-dynew[ind1[group3]])*(1-dynew[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^3-Fy1new[ind2[group3]]^3)/3) -
    sum(((1-dynew[ind1[group2]])*(Fy1new[ind2[group2]])+(1-dynew[ind2[group2]])*(Fy1new[ind1[group2]]))/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^2-Fy1new[ind2[group2]]^2)/2) -
    sum(((1-dynew[ind1[group3]])*(Fy1new[ind2[group3]])+(1-dynew[ind2[group3]])*(Fy1new[ind1[group3]]))/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^2-Fy1new[ind2[group3]]^2)/2) +
    sum((Fy1new[ind1[group2]])*(Fy1new[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]-Fy1new[ind2[group2]])) +
    sum((Fy1new[ind1[group3]])*(Fy1new[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]-Fy1new[ind2[group3]]))

  indnew3p3 <- sum(1/6/dynew[ind2[group2]]*(Fynew[ind2[group2]]^3+2*Fynew[ind1[group2]]^3-2*Fynew[ind1[group2]]^3*Fynew[ind2[group2]]+
                                              2*Fynew[ind1[group2]]^3*Fy1new[ind2[group2]]-
                                              3*Fynew[ind1[group2]]^2-3*Fynew[ind2[group2]]^2+3*Fynew[ind1[group2]]^2*Fynew[ind2[group2]]-
                                              6*Fynew[ind1[group2]]^2*Fy1new[ind2[group2]]+6*Fynew[ind1[group2]]*Fy1new[ind2[group2]]+
                                              2*Fynew[ind2[group2]]-2*Fy1new[ind2[group2]]))+
    sum(1/6/dynew[ind1[group3]]*(Fynew[ind1[group3]]^3+2*Fynew[ind2[group3]]^3-2*Fynew[ind2[group3]]^3*Fynew[ind1[group3]]+
                                   2*Fynew[ind2[group3]]^3*Fy1new[ind1[group3]]-
                                   3*Fynew[ind2[group3]]^2-3*Fynew[ind1[group3]]^2+3*Fynew[ind2[group3]]^2*Fynew[ind1[group3]]-
                                   6*Fynew[ind2[group3]]^2*Fy1new[ind1[group3]]+6*Fynew[ind2[group3]]*Fy1new[ind1[group3]]+
                                   2*Fynew[ind1[group3]]-2*Fy1new[ind1[group3]]))



  ## Test statistic
  disnull <- int1new+2*(ind2new1+ind2new2+indnew3p1+indnew3p2+indnew3p3)

  ## Bootstrap
  disin <- rep(0,B)

  for(repin in 1:B){

    yr <- rbinom(n,size=1,p1f)
    #####!!!changes made
    #####!!!
    dfr <- data.frame(yr=yr,dfx[,-1])

    #fit marginal model
    bimodelr <- glm(yr~.,family=fam,data=dfr)
    p1fr <- bimodelr$fitted.values
    #####!!!
    #####!!!




    Fyr <- ifelse(yr==1,1,1-p1fr)
    Fy1r <-  ifelse(yr==0,0,1-p1fr)
    dyr <- ifelse(yr==1,p1fr,1-p1fr)

    int1newr <- sum(1/3*(Fyr^4+Fy1r^4-Fyr^3*Fy1r-Fyr*Fy1r^3-2*Fyr^3-Fy1r^3+3*Fyr^2*Fy1r+Fyr^2-2*Fyr*Fy1r+Fy1r^2)/dyr^2)



    Fy1new <- sort(Fy1r)
    Fynew <- Fyr[sort(Fy1r,index=TRUE)$ix]
    dynew <- dyr[sort(Fy1r,index=TRUE)$ix]



    group1 <- which(Fy1new[ind2]>Fynew[ind1])
    ## overlap, and keep order. k=ind1,k'=ind2,m=ind2,m'=ind1
    group2 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]>Fynew[ind1])
    ## overlap, and switch order for on right side. k=ind1,k'=ind2,m=ind1,m'=ind2
    group3 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]<=Fynew[ind1])
    group4 <- which(Fy1new[ind2]<=Fynew[ind1])

    ind2new1r <- sum(((Fynew^3-Fy1new^3)/6/dynew)[ind1[group1]])

    ind2new2r <- sum(((Fynew^3-Fy1new^3-3*Fynew^2+3*Fy1new^2+2*Fynew-2*Fy1new)/dynew/6)[ind2[group1]])


    indnew3p1r <- sum((-Fy1new[ind1[group4]]^3-2*Fy1new[ind2[group4]]^3*(1-dynew[ind1[group4]])+3*Fy1new[ind1[group4]]*Fy1new[ind2[group4]]^2)/6/dynew[ind1[group4]])



    indnew3p2r <- sum((1-dynew[ind1[group2]])*(1-dynew[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^3-Fy1new[ind2[group2]]^3)/3) +
      sum((1-dynew[ind1[group3]])*(1-dynew[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^3-Fy1new[ind2[group3]]^3)/3) -
      sum(((1-dynew[ind1[group2]])*(Fy1new[ind2[group2]])+(1-dynew[ind2[group2]])*(Fy1new[ind1[group2]]))/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^2-Fy1new[ind2[group2]]^2)/2) -
      sum(((1-dynew[ind1[group3]])*(Fy1new[ind2[group3]])+(1-dynew[ind2[group3]])*(Fy1new[ind1[group3]]))/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^2-Fy1new[ind2[group3]]^2)/2) +
      sum((Fy1new[ind1[group2]])*(Fy1new[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]-Fy1new[ind2[group2]])) +
      sum((Fy1new[ind1[group3]])*(Fy1new[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]-Fy1new[ind2[group3]]))

    indnew3p3r <- sum(1/6/dynew[ind2[group2]]*(Fynew[ind2[group2]]^3+2*Fynew[ind1[group2]]^3-2*Fynew[ind1[group2]]^3*Fynew[ind2[group2]]+
                                                 2*Fynew[ind1[group2]]^3*Fy1new[ind2[group2]]-
                                                 3*Fynew[ind1[group2]]^2-3*Fynew[ind2[group2]]^2+3*Fynew[ind1[group2]]^2*Fynew[ind2[group2]]-
                                                 6*Fynew[ind1[group2]]^2*Fy1new[ind2[group2]]+6*Fynew[ind1[group2]]*Fy1new[ind2[group2]]+
                                                 2*Fynew[ind2[group2]]-2*Fy1new[ind2[group2]]))+
      sum(1/6/dynew[ind1[group3]]*(Fynew[ind1[group3]]^3+2*Fynew[ind2[group3]]^3-2*Fynew[ind2[group3]]^3*Fynew[ind1[group3]]+
                                     2*Fynew[ind2[group3]]^3*Fy1new[ind1[group3]]-
                                     3*Fynew[ind2[group3]]^2-3*Fynew[ind1[group3]]^2+3*Fynew[ind2[group3]]^2*Fynew[ind1[group3]]-
                                     6*Fynew[ind2[group3]]^2*Fy1new[ind1[group3]]+6*Fynew[ind2[group3]]*Fy1new[ind1[group3]]+
                                     2*Fynew[ind1[group3]]-2*Fy1new[ind1[group3]]))



    disin[repin] <-int1newr+2*(ind2new1r+ind2new2r+indnew3p1r+indnew3p2r+indnew3p3r)

  }
  pvalue <- length(which(disin>disnull))/B
  return(list(test_stat = disnull, p_value = pvalue))
}

#' @importFrom utils combn
#' @importFrom MASS rnegbin
#' @importFrom MASS glm.nb
#' @keywords internal
gof_nb <- function(B,nbmodel=NULL, seed = NULL) {
  if (!is.null(seed)) set.seed(seed)
  if(is.null(nbmodel)) stop("model object is not given.")
  y <- nbmodel$model[, 1]
  n <- length(y)
  lambda1f <- nbmodel$fitted.values
  size1f <- summary(nbmodel)$theta
  dfx <- model.matrix(nbmodel)
  lin <- nbmodel$family$link

  como <- combn(n,2)
  ind1 <- como[1,]
  ind2 <- como[2,]

  Fy <- pnbinom(y,mu=lambda1f,size=size1f)
  Fy1 <-  pnbinom(y-1,mu=lambda1f,size=size1f)
  dy <-  dnbinom(y,mu=lambda1f,size=size1f)

  int1new <- sum(1/3*(Fy^4+Fy1^4-Fy^3*Fy1-Fy*Fy1^3-2*Fy^3-Fy1^3+3*Fy^2*Fy1+Fy^2-2*Fy*Fy1+Fy1^2)/dy^2)


  Fy1new <- sort(Fy1)
  Fynew <- Fy[sort(Fy1,index=TRUE)$ix]
  dynew <- dy[sort(Fy1,index=TRUE)$ix]



  ###no overlap
  group1 <- which(Fy1new[ind2]>Fynew[ind1])
  ## overlap, and keep order. k=ind1,k'=ind2,m=ind2,m'=ind1
  group2 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]>Fynew[ind1])
  ## overlap, and switch order for on right side. k=ind1,k'=ind2,m=ind1,m'=ind2
  group3 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]<=Fynew[ind1])
  group4 <- which(Fy1new[ind2]<=Fynew[ind1])

  ind2new1 <- sum(((Fynew^3-Fy1new^3)/6/dynew)[ind1[group1]])

  ind2new2 <- sum(((Fynew^3-Fy1new^3-3*Fynew^2+3*Fy1new^2+2*Fynew-2*Fy1new)/dynew/6)[ind2[group1]])


  indnew3p1 <- sum((-Fy1new[ind1[group4]]^3-2*Fy1new[ind2[group4]]^3*(1-dynew[ind1[group4]])+3*Fy1new[ind1[group4]]*Fy1new[ind2[group4]]^2)/6/dynew[ind1[group4]])



  indnew3p2 <- sum((1-dynew[ind1[group2]])*(1-dynew[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^3-Fy1new[ind2[group2]]^3)/3) +
    sum((1-dynew[ind1[group3]])*(1-dynew[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^3-Fy1new[ind2[group3]]^3)/3) -
    sum(((1-dynew[ind1[group2]])*(Fy1new[ind2[group2]])+(1-dynew[ind2[group2]])*(Fy1new[ind1[group2]]))/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^2-Fy1new[ind2[group2]]^2)/2) -
    sum(((1-dynew[ind1[group3]])*(Fy1new[ind2[group3]])+(1-dynew[ind2[group3]])*(Fy1new[ind1[group3]]))/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^2-Fy1new[ind2[group3]]^2)/2) +
    sum((Fy1new[ind1[group2]])*(Fy1new[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]-Fy1new[ind2[group2]])) +
    sum((Fy1new[ind1[group3]])*(Fy1new[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]-Fy1new[ind2[group3]]))

  indnew3p3 <- sum(1/6/dynew[ind2[group2]]*(Fynew[ind2[group2]]^3+2*Fynew[ind1[group2]]^3-2*Fynew[ind1[group2]]^3*Fynew[ind2[group2]]+
                                              2*Fynew[ind1[group2]]^3*Fy1new[ind2[group2]]-
                                              3*Fynew[ind1[group2]]^2-3*Fynew[ind2[group2]]^2+3*Fynew[ind1[group2]]^2*Fynew[ind2[group2]]-
                                              6*Fynew[ind1[group2]]^2*Fy1new[ind2[group2]]+6*Fynew[ind1[group2]]*Fy1new[ind2[group2]]+
                                              2*Fynew[ind2[group2]]-2*Fy1new[ind2[group2]]))+
    sum(1/6/dynew[ind1[group3]]*(Fynew[ind1[group3]]^3+2*Fynew[ind2[group3]]^3-2*Fynew[ind2[group3]]^3*Fynew[ind1[group3]]+
                                   2*Fynew[ind2[group3]]^3*Fy1new[ind1[group3]]-
                                   3*Fynew[ind2[group3]]^2-3*Fynew[ind1[group3]]^2+3*Fynew[ind2[group3]]^2*Fynew[ind1[group3]]-
                                   6*Fynew[ind2[group3]]^2*Fy1new[ind1[group3]]+6*Fynew[ind2[group3]]*Fy1new[ind1[group3]]+
                                   2*Fynew[ind1[group3]]-2*Fy1new[ind1[group3]]))


  ## Test statistic
  disnull <- int1new+2*(ind2new1+ind2new2+indnew3p1+indnew3p2+indnew3p3)


  ## Bootstrap
  disin <- rep(0,B)
  for(repin in 1:B){
    yr <- rnegbin(n, mu=lambda1f, theta=size1f)
    dfr <- data.frame(yr=yr,dfx[,-1])
    if (lin == "log") {
      model1r <- MASS::glm.nb(yr ~ ., data = dfr, link = log)
    } else if (lin == "identity") {
      model1r <- MASS::glm.nb(yr ~ ., data = dfr, link = identity)
    } else if (lin == "sqrt") {
      model1r <- MASS::glm.nb(yr ~ ., data = dfr, link = sqrt)
    } else {
      stop("Unsupported nb link: ", lin)
    }
    lambda1fr <- model1r$fitted.values
    size1fr <- summary(model1r)$theta

    Fyr <- pnbinom(yr,mu=lambda1fr,size=size1fr)
    Fy1r <-  pnbinom(yr-1,mu=lambda1fr,size=size1fr)
    dyr <-  dnbinom(yr,mu=lambda1fr,size=size1fr)

    int1newr <- sum(1/3*(Fyr^4+Fy1r^4-Fyr^3*Fy1r-Fyr*Fy1r^3-2*Fyr^3-Fy1r^3+3*Fyr^2*Fy1r+Fyr^2-2*Fyr*Fy1r+Fy1r^2)/dyr^2)



    Fy1new <- sort(Fy1r)
    Fynew <- Fyr[sort(Fy1r,index=TRUE)$ix]
    dynew <- dyr[sort(Fy1r,index=TRUE)$ix]



    ###no overlap
    group1 <- which(Fy1new[ind2]>Fynew[ind1])
    ## overlap, and keep order. k=ind1,k'=ind2,m=ind2,m'=ind1
    group2 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]>Fynew[ind1])
    ## overlap, and switch order for on right side. k=ind1,k'=ind2,m=ind1,m'=ind2
    group3 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]<=Fynew[ind1])
    group4 <- which(Fy1new[ind2]<=Fynew[ind1])

    ind2new1r <- sum(((Fynew^3-Fy1new^3)/6/dynew)[ind1[group1]])

    ind2new2r <- sum(((Fynew^3-Fy1new^3-3*Fynew^2+3*Fy1new^2+2*Fynew-2*Fy1new)/dynew/6)[ind2[group1]])


    indnew3p1r <- sum((-Fy1new[ind1[group4]]^3-2*Fy1new[ind2[group4]]^3*(1-dynew[ind1[group4]])+3*Fy1new[ind1[group4]]*Fy1new[ind2[group4]]^2)/6/dynew[ind1[group4]])



    indnew3p2r <- sum((1-dynew[ind1[group2]])*(1-dynew[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^3-Fy1new[ind2[group2]]^3)/3) +
      sum((1-dynew[ind1[group3]])*(1-dynew[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^3-Fy1new[ind2[group3]]^3)/3) -
      sum(((1-dynew[ind1[group2]])*(Fy1new[ind2[group2]])+(1-dynew[ind2[group2]])*(Fy1new[ind1[group2]]))/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^2-Fy1new[ind2[group2]]^2)/2) -
      sum(((1-dynew[ind1[group3]])*(Fy1new[ind2[group3]])+(1-dynew[ind2[group3]])*(Fy1new[ind1[group3]]))/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^2-Fy1new[ind2[group3]]^2)/2) +
      sum((Fy1new[ind1[group2]])*(Fy1new[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]-Fy1new[ind2[group2]])) +
      sum((Fy1new[ind1[group3]])*(Fy1new[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]-Fy1new[ind2[group3]]))

    indnew3p3r <- sum(1/6/dynew[ind2[group2]]*(Fynew[ind2[group2]]^3+2*Fynew[ind1[group2]]^3-2*Fynew[ind1[group2]]^3*Fynew[ind2[group2]]+
                                                 2*Fynew[ind1[group2]]^3*Fy1new[ind2[group2]]-
                                                 3*Fynew[ind1[group2]]^2-3*Fynew[ind2[group2]]^2+3*Fynew[ind1[group2]]^2*Fynew[ind2[group2]]-
                                                 6*Fynew[ind1[group2]]^2*Fy1new[ind2[group2]]+6*Fynew[ind1[group2]]*Fy1new[ind2[group2]]+
                                                 2*Fynew[ind2[group2]]-2*Fy1new[ind2[group2]]))+
      sum(1/6/dynew[ind1[group3]]*(Fynew[ind1[group3]]^3+2*Fynew[ind2[group3]]^3-2*Fynew[ind2[group3]]^3*Fynew[ind1[group3]]+
                                     2*Fynew[ind2[group3]]^3*Fy1new[ind1[group3]]-
                                     3*Fynew[ind2[group3]]^2-3*Fynew[ind1[group3]]^2+3*Fynew[ind2[group3]]^2*Fynew[ind1[group3]]-
                                     6*Fynew[ind2[group3]]^2*Fy1new[ind1[group3]]+6*Fynew[ind2[group3]]*Fy1new[ind1[group3]]+
                                     2*Fynew[ind1[group3]]-2*Fy1new[ind1[group3]]))

    disin[repin] <- int1newr+2*(ind2new1r+ind2new2r+indnew3p1r+indnew3p2r+indnew3p3r)

  }

  ##p-value
  pvalue <- length(which(disin>disnull))/B
  return(list(test_stat = disnull, p_value = pvalue))
}

#' @keywords internal
#' @importFrom MASS polr
gof_ordi <- function(B, multimodel=NULL, seed=NULL){
  genemult <- function(p){
    rmultinom(1,size=1,prob=p)
  }
  if (!is.null(seed)) set.seed(seed)
  if( is.null(multimodel )) stop("model object is not given.")

  y <- multimodel$model[, 1]
  n <- length(y)
  fitprob <- multimodel$fitted.values
  k <- length(multimodel$lev)
  ### Convert the levels to 1:k
  out <- as.numeric(factor(multimodel$model[,1],ordered = TRUE))
  dfx <- model.matrix(multimodel)
  met <- multimodel$method

  ### Cumulative probabilities
  q <- t(apply(fitprob,1, cumsum))
  ## F(Y), F(Y-1), P(Y)
  Fy <- q[cbind(1:n,out)]
  out1 <- ifelse(out==1,1,out-1)
  Fy1 <-  ifelse(out==1,0,q[cbind(1:n,out1)])
  dy <-  Fy-Fy1

  como <- combn(n,2)
  ind1 <- como[1,]
  ind2 <- como[2,]

  ## The test statistic is calculated by parts
  int1new <- sum(1/3*(Fy^4+Fy1^4-Fy^3*Fy1-Fy*Fy1^3-2*Fy^3-Fy1^3+3*Fy^2*Fy1+Fy^2-2*Fy*Fy1+Fy1^2)/dy^2)
  Fy1new <- sort(Fy1)
  Fynew <- Fy[sort(Fy1,index=TRUE)$ix]
  dynew <- dy[sort(Fy1,index=TRUE)$ix]

  ###no overlap
  group1 <- which(Fy1new[ind2]>Fynew[ind1])
  ## overlap, and keep order. k=ind1,k'=ind2,m=ind2,m'=ind1
  group2 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]>Fynew[ind1])
  ## overlap, and switch order for on right side. k=ind1,k'=ind2,m=ind1,m'=ind2
  group3 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]<=Fynew[ind1])
  group4 <- which(Fy1new[ind2]<=Fynew[ind1])

  ind2new1 <- sum(((Fynew^3-Fy1new^3)/6/dynew)[ind1[group1]])

  ind2new2 <- sum(((Fynew^3-Fy1new^3-3*Fynew^2+3*Fy1new^2+2*Fynew-2*Fy1new)/dynew/6)[ind2[group1]])


  indnew3p1 <- sum((-Fy1new[ind1[group4]]^3-2*Fy1new[ind2[group4]]^3*(1-dynew[ind1[group4]])+3*Fy1new[ind1[group4]]*Fy1new[ind2[group4]]^2)/6/dynew[ind1[group4]])



  indnew3p2 <- sum((1-dynew[ind1[group2]])*(1-dynew[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^3-Fy1new[ind2[group2]]^3)/3) +
    sum((1-dynew[ind1[group3]])*(1-dynew[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^3-Fy1new[ind2[group3]]^3)/3) -
    sum(((1-dynew[ind1[group2]])*(Fy1new[ind2[group2]])+(1-dynew[ind2[group2]])*(Fy1new[ind1[group2]]))/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^2-Fy1new[ind2[group2]]^2)/2) -
    sum(((1-dynew[ind1[group3]])*(Fy1new[ind2[group3]])+(1-dynew[ind2[group3]])*(Fy1new[ind1[group3]]))/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^2-Fy1new[ind2[group3]]^2)/2) +
    sum((Fy1new[ind1[group2]])*(Fy1new[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]-Fy1new[ind2[group2]])) +
    sum((Fy1new[ind1[group3]])*(Fy1new[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]-Fy1new[ind2[group3]]))

  indnew3p3 <- sum(1/6/dynew[ind2[group2]]*(Fynew[ind2[group2]]^3+2*Fynew[ind1[group2]]^3-2*Fynew[ind1[group2]]^3*Fynew[ind2[group2]]+
                                              2*Fynew[ind1[group2]]^3*Fy1new[ind2[group2]]-
                                              3*Fynew[ind1[group2]]^2-3*Fynew[ind2[group2]]^2+3*Fynew[ind1[group2]]^2*Fynew[ind2[group2]]-
                                              6*Fynew[ind1[group2]]^2*Fy1new[ind2[group2]]+6*Fynew[ind1[group2]]*Fy1new[ind2[group2]]+
                                              2*Fynew[ind2[group2]]-2*Fy1new[ind2[group2]]))+
    sum(1/6/dynew[ind1[group3]]*(Fynew[ind1[group3]]^3+2*Fynew[ind2[group3]]^3-2*Fynew[ind2[group3]]^3*Fynew[ind1[group3]]+
                                   2*Fynew[ind2[group3]]^3*Fy1new[ind1[group3]]-
                                   3*Fynew[ind2[group3]]^2-3*Fynew[ind1[group3]]^2+3*Fynew[ind2[group3]]^2*Fynew[ind1[group3]]-
                                   6*Fynew[ind2[group3]]^2*Fy1new[ind1[group3]]+6*Fynew[ind2[group3]]*Fy1new[ind1[group3]]+
                                   2*Fynew[ind1[group3]]-2*Fy1new[ind1[group3]]))



  ## Test statistic
  disnull <- int1new+2*(ind2new1+ind2new2+indnew3p1+indnew3p2+indnew3p3)

  ## Bootstrap
  disin <- rep(0,B)

  for(repin in 1:B){
    testr <- apply(fitprob,1,genemult)
    yr <- apply(testr,2,which.max)
    dfr <- data.frame(yr=yr,dfx[,-1])
    multimodelr <- polr(as.factor(yr)~.,method=met,data=dfr)
    fitprobr <- multimodelr$fitted.values
    outr <- as.numeric(factor(multimodelr$model[,1],ordered = TRUE))

    ### Cumulative probabilities
    qr <- t(apply(fitprobr,1, cumsum))



    ## F(Y), F(Y-1), P(Y)
    Fyr <- qr[cbind(1:n,outr)]
    out1r <- ifelse(outr==1,1,outr-1)
    Fy1r <-  ifelse(outr==1,0,qr[cbind(1:n,out1r)])
    dyr <-  Fyr-Fy1r


    int1newr <- sum(1/3*(Fyr^4+Fy1r^4-Fyr^3*Fy1r-Fyr*Fy1r^3-2*Fyr^3-Fy1r^3+3*Fyr^2*Fy1r+Fyr^2-2*Fyr*Fy1r+Fy1r^2)/dyr^2)



    Fy1new <- sort(Fy1r)
    Fynew <- Fyr[sort(Fy1r,index=TRUE)$ix]
    dynew <- dyr[sort(Fy1r,index=TRUE)$ix]



    group1 <- which(Fy1new[ind2]>Fynew[ind1])
    ## overlap, and keep order. k=ind1,k'=ind2,m=ind2,m'=ind1
    group2 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]>Fynew[ind1])
    ## overlap, and switch order for on right side. k=ind1,k'=ind2,m=ind1,m'=ind2
    group3 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]<=Fynew[ind1])
    group4 <- which(Fy1new[ind2]<=Fynew[ind1])

    ind2new1r <- sum(((Fynew^3-Fy1new^3)/6/dynew)[ind1[group1]])

    ind2new2r <- sum(((Fynew^3-Fy1new^3-3*Fynew^2+3*Fy1new^2+2*Fynew-2*Fy1new)/dynew/6)[ind2[group1]])


    indnew3p1r <- sum((-Fy1new[ind1[group4]]^3-2*Fy1new[ind2[group4]]^3*(1-dynew[ind1[group4]])+3*Fy1new[ind1[group4]]*Fy1new[ind2[group4]]^2)/6/dynew[ind1[group4]])



    indnew3p2r <- sum((1-dynew[ind1[group2]])*(1-dynew[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^3-Fy1new[ind2[group2]]^3)/3) +
      sum((1-dynew[ind1[group3]])*(1-dynew[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^3-Fy1new[ind2[group3]]^3)/3) -
      sum(((1-dynew[ind1[group2]])*(Fy1new[ind2[group2]])+(1-dynew[ind2[group2]])*(Fy1new[ind1[group2]]))/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^2-Fy1new[ind2[group2]]^2)/2) -
      sum(((1-dynew[ind1[group3]])*(Fy1new[ind2[group3]])+(1-dynew[ind2[group3]])*(Fy1new[ind1[group3]]))/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^2-Fy1new[ind2[group3]]^2)/2) +
      sum((Fy1new[ind1[group2]])*(Fy1new[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]-Fy1new[ind2[group2]])) +
      sum((Fy1new[ind1[group3]])*(Fy1new[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]-Fy1new[ind2[group3]]))

    indnew3p3r <- sum(1/6/dynew[ind2[group2]]*(Fynew[ind2[group2]]^3+2*Fynew[ind1[group2]]^3-2*Fynew[ind1[group2]]^3*Fynew[ind2[group2]]+
                                                 2*Fynew[ind1[group2]]^3*Fy1new[ind2[group2]]-
                                                 3*Fynew[ind1[group2]]^2-3*Fynew[ind2[group2]]^2+3*Fynew[ind1[group2]]^2*Fynew[ind2[group2]]-
                                                 6*Fynew[ind1[group2]]^2*Fy1new[ind2[group2]]+6*Fynew[ind1[group2]]*Fy1new[ind2[group2]]+
                                                 2*Fynew[ind2[group2]]-2*Fy1new[ind2[group2]]))+
      sum(1/6/dynew[ind1[group3]]*(Fynew[ind1[group3]]^3+2*Fynew[ind2[group3]]^3-2*Fynew[ind2[group3]]^3*Fynew[ind1[group3]]+
                                     2*Fynew[ind2[group3]]^3*Fy1new[ind1[group3]]-
                                     3*Fynew[ind2[group3]]^2-3*Fynew[ind1[group3]]^2+3*Fynew[ind2[group3]]^2*Fynew[ind1[group3]]-
                                     6*Fynew[ind2[group3]]^2*Fy1new[ind1[group3]]+6*Fynew[ind2[group3]]*Fy1new[ind1[group3]]+
                                     2*Fynew[ind1[group3]]-2*Fy1new[ind1[group3]]))



    disin[repin] <-int1newr+2*(ind2new1r+ind2new2r+indnew3p1r+indnew3p2r+indnew3p3r)

  }

  pvalue <- length(which(disin>disnull))/B
  return(list(test_stat = disnull, p_value = pvalue))
}

#' @importFrom utils combn
#' @keywords internal
gof_pois <- function(B, poismodel = NULL, seed = NULL) {
  if (!is.null(seed)) set.seed(seed)
  if(is.null(poismodel)) stop("model object is not given.")
  y <- poismodel$model[, 1]
  n <- length(y)
  lambda1f <- poismodel$fitted.values
  dfx <- model.matrix(poismodel)
  fam <- poismodel$family

  como <- combn(n,2)
  ind1 <- como[1,]
  ind2 <- como[2,]


  ## F(Y), F(Y-1), P(Y)
  Fy <- ppois(y,lambda1f)
  Fy1 <- ppois(y-1,lambda1f)
  dy <- dpois(y,lambda1f)


  ## The test statistic is calculated by parts
  int1new <- sum(1/3*(Fy^4+Fy1^4-Fy^3*Fy1-Fy*Fy1^3-2*Fy^3-Fy1^3+3*Fy^2*Fy1+Fy^2-2*Fy*Fy1+Fy1^2)/dy^2)


  Fy1new <- sort(Fy1)
  Fynew <- Fy[sort(Fy1,index=TRUE)$ix]
  dynew <- dy[sort(Fy1,index=TRUE)$ix]



  ###no overlap
  group1 <- which(Fy1new[ind2]>Fynew[ind1])
  ## overlap, and keep order. k=ind1,k'=ind2,m=ind2,m'=ind1
  group2 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]>Fynew[ind1])
  ## overlap, and switch order for on right side. k=ind1,k'=ind2,m=ind1,m'=ind2
  group3 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]<=Fynew[ind1])
  group4 <- which(Fy1new[ind2]<=Fynew[ind1])


  ind2new1 <- sum(((Fynew^3-Fy1new^3)/6/dynew)[ind1[group1]])

  ind2new2 <- sum(((Fynew^3-Fy1new^3-3*Fynew^2+3*Fy1new^2+2*Fynew-2*Fy1new)/dynew/6)[ind2[group1]])


  indnew3p1 <- sum((-Fy1new[ind1[group4]]^3-2*Fy1new[ind2[group4]]^3*(1-dynew[ind1[group4]])+3*Fy1new[ind1[group4]]*Fy1new[ind2[group4]]^2)/6/dynew[ind1[group4]])



  indnew3p2 <- sum((1-dynew[ind1[group2]])*(1-dynew[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^3-Fy1new[ind2[group2]]^3)/3) +
    sum((1-dynew[ind1[group3]])*(1-dynew[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^3-Fy1new[ind2[group3]]^3)/3) -
    sum(((1-dynew[ind1[group2]])*(Fy1new[ind2[group2]])+(1-dynew[ind2[group2]])*(Fy1new[ind1[group2]]))/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^2-Fy1new[ind2[group2]]^2)/2) -
    sum(((1-dynew[ind1[group3]])*(Fy1new[ind2[group3]])+(1-dynew[ind2[group3]])*(Fy1new[ind1[group3]]))/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^2-Fy1new[ind2[group3]]^2)/2) +
    sum((Fy1new[ind1[group2]])*(Fy1new[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]-Fy1new[ind2[group2]])) +
    sum((Fy1new[ind1[group3]])*(Fy1new[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]-Fy1new[ind2[group3]]))

  indnew3p3 <- sum(1/6/dynew[ind2[group2]]*(Fynew[ind2[group2]]^3+2*Fynew[ind1[group2]]^3-2*Fynew[ind1[group2]]^3*Fynew[ind2[group2]]+
                                              2*Fynew[ind1[group2]]^3*Fy1new[ind2[group2]]-
                                              3*Fynew[ind1[group2]]^2-3*Fynew[ind2[group2]]^2+3*Fynew[ind1[group2]]^2*Fynew[ind2[group2]]-
                                              6*Fynew[ind1[group2]]^2*Fy1new[ind2[group2]]+6*Fynew[ind1[group2]]*Fy1new[ind2[group2]]+
                                              2*Fynew[ind2[group2]]-2*Fy1new[ind2[group2]]))+
    sum(1/6/dynew[ind1[group3]]*(Fynew[ind1[group3]]^3+2*Fynew[ind2[group3]]^3-2*Fynew[ind2[group3]]^3*Fynew[ind1[group3]]+
                                   2*Fynew[ind2[group3]]^3*Fy1new[ind1[group3]]-
                                   3*Fynew[ind2[group3]]^2-3*Fynew[ind1[group3]]^2+3*Fynew[ind2[group3]]^2*Fynew[ind1[group3]]-
                                   6*Fynew[ind2[group3]]^2*Fy1new[ind1[group3]]+6*Fynew[ind2[group3]]*Fy1new[ind1[group3]]+
                                   2*Fynew[ind1[group3]]-2*Fy1new[ind1[group3]]))



  ## Test statistic
  disnull <- int1new+2*(ind2new1+ind2new2+indnew3p1+indnew3p2+indnew3p3)
  ## Bootstrap
  disin <- rep(0,B)

  for(repin in 1:B){

    yr <- rpois(n, lambda1f)
    #####!!!changes made
    #####!!!
    dfr <- data.frame(yr=yr,dfx[,-1])
    #fit marginal model
    poismodelr <- glm(yr~.,family=fam,data=dfr)
    lambda1fr <- poismodelr$fitted.values
    #####!!!changes made
    #####


    Fyr <- ppois(yr,lambda1fr)
    Fy1r <- ppois(yr-1,lambda1fr)
    dyr <- dpois(yr,lambda1fr)


    int1newr <- sum(1/3*(Fyr^4+Fy1r^4-Fyr^3*Fy1r-Fyr*Fy1r^3-2*Fyr^3-Fy1r^3+3*Fyr^2*Fy1r+Fyr^2-2*Fyr*Fy1r+Fy1r^2)/dyr^2)




    Fy1new <- sort(Fy1r)
    Fynew <- Fyr[sort(Fy1r,index=TRUE)$ix]
    dynew <- dyr[sort(Fy1r,index=TRUE)$ix]



    ###no overlap
    group1 <- which(Fy1new[ind2]>Fynew[ind1])
    ## overlap, and keep order. k=ind1,k'=ind2,m=ind2,m'=ind1
    group2 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]>Fynew[ind1])
    ## overlap, and switch order for on right side. k=ind1,k'=ind2,m=ind1,m'=ind2
    group3 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]<=Fynew[ind1])
    group4 <- which(Fy1new[ind2]<=Fynew[ind1])

    ind2new1r <- sum(((Fynew^3-Fy1new^3)/6/dynew)[ind1[group1]])

    ind2new2r <- sum(((Fynew^3-Fy1new^3-3*Fynew^2+3*Fy1new^2+2*Fynew-2*Fy1new)/dynew/6)[ind2[group1]])


    indnew3p1r <- sum((-Fy1new[ind1[group4]]^3-2*Fy1new[ind2[group4]]^3*(1-dynew[ind1[group4]])+3*Fy1new[ind1[group4]]*Fy1new[ind2[group4]]^2)/6/dynew[ind1[group4]])



    indnew3p2r <- sum((1-dynew[ind1[group2]])*(1-dynew[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^3-Fy1new[ind2[group2]]^3)/3) +
      sum((1-dynew[ind1[group3]])*(1-dynew[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^3-Fy1new[ind2[group3]]^3)/3) -
      sum(((1-dynew[ind1[group2]])*(Fy1new[ind2[group2]])+(1-dynew[ind2[group2]])*(Fy1new[ind1[group2]]))/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^2-Fy1new[ind2[group2]]^2)/2) -
      sum(((1-dynew[ind1[group3]])*(Fy1new[ind2[group3]])+(1-dynew[ind2[group3]])*(Fy1new[ind1[group3]]))/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^2-Fy1new[ind2[group3]]^2)/2) +
      sum((Fy1new[ind1[group2]])*(Fy1new[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]-Fy1new[ind2[group2]])) +
      sum((Fy1new[ind1[group3]])*(Fy1new[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]-Fy1new[ind2[group3]]))

    indnew3p3r <- sum(1/6/dynew[ind2[group2]]*(Fynew[ind2[group2]]^3+2*Fynew[ind1[group2]]^3-2*Fynew[ind1[group2]]^3*Fynew[ind2[group2]]+
                                                 2*Fynew[ind1[group2]]^3*Fy1new[ind2[group2]]-
                                                 3*Fynew[ind1[group2]]^2-3*Fynew[ind2[group2]]^2+3*Fynew[ind1[group2]]^2*Fynew[ind2[group2]]-
                                                 6*Fynew[ind1[group2]]^2*Fy1new[ind2[group2]]+6*Fynew[ind1[group2]]*Fy1new[ind2[group2]]+
                                                 2*Fynew[ind2[group2]]-2*Fy1new[ind2[group2]]))+
      sum(1/6/dynew[ind1[group3]]*(Fynew[ind1[group3]]^3+2*Fynew[ind2[group3]]^3-2*Fynew[ind2[group3]]^3*Fynew[ind1[group3]]+
                                     2*Fynew[ind2[group3]]^3*Fy1new[ind1[group3]]-
                                     3*Fynew[ind2[group3]]^2-3*Fynew[ind1[group3]]^2+3*Fynew[ind2[group3]]^2*Fynew[ind1[group3]]-
                                     6*Fynew[ind2[group3]]^2*Fy1new[ind1[group3]]+6*Fynew[ind2[group3]]*Fy1new[ind1[group3]]+
                                     2*Fynew[ind1[group3]]-2*Fy1new[ind1[group3]]))



    disin[repin] <-int1newr+2*(ind2new1r+ind2new2r+indnew3p1r+indnew3p2r+indnew3p3r)

  }

  ##p-value
  pvalue <- length(which(disin>disnull))/B

  return(list(test_stat = disnull, p_value = pvalue))
}

#' @importFrom utils combn
#' @importFrom pscl zeroinfl
#' @importFrom MASS rnegbin
#' @keywords internal
gof_znb <- function(B, model1 =NULL, seed = NULL) {
  if (!is.null(seed)) set.seed(seed)
  if(is.null(model1)) stop("model object is not given.")
  y <- model1$model[, 1]
  n <- length(y)
  lambda1f <- predict(model1,type="count")
  pzero <- predict(model1,type="zero")
  size1f <- model1$theta
  df <- model1$model
  dis <- model1$dist
  lin <- model1$link
  formula1 <- model1$formula
  #####!!!
  #####!!!

  como <- combn(n,2)
  ind1 <- como[1,]
  ind2 <- como[2,]

  ## F(Y), F(Y-1), P(Y)

  Fy <- pzero + (1 - pzero) * pnbinom(y,mu=lambda1f,size=size1f)
  Fy1 <-  ifelse(y==0,0,(pzero + (1 - pzero) * pnbinom(y-1,mu=lambda1f,size=size1f)))
  dy <-  Fy-Fy1


  int1new <- sum(1/3*(Fy^4+Fy1^4-Fy^3*Fy1-Fy*Fy1^3-2*Fy^3-Fy1^3+3*Fy^2*Fy1+Fy^2-2*Fy*Fy1+Fy1^2)/dy^2)


  Fy1new <- sort(Fy1)
  Fynew <- Fy[sort(Fy1,index=TRUE)$ix]
  dynew <- dy[sort(Fy1,index=TRUE)$ix]




  ###no overlap
  group1 <- which(Fy1new[ind2]>Fynew[ind1])
  ## overlap, and keep order. k=ind1,k'=ind2,m=ind2,m'=ind1
  group2 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]>Fynew[ind1])
  ## overlap, and switch order for on right side. k=ind1,k'=ind2,m=ind1,m'=ind2
  group3 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]<=Fynew[ind1])
  group4 <- which(Fy1new[ind2]<=Fynew[ind1])

  ind2new1 <- sum(((Fynew^3-Fy1new^3)/6/dynew)[ind1[group1]])

  ind2new2 <- sum(((Fynew^3-Fy1new^3-3*Fynew^2+3*Fy1new^2+2*Fynew-2*Fy1new)/dynew/6)[ind2[group1]])


  indnew3p1 <- sum((-Fy1new[ind1[group4]]^3-2*Fy1new[ind2[group4]]^3*(1-dynew[ind1[group4]])+3*Fy1new[ind1[group4]]*Fy1new[ind2[group4]]^2)/6/dynew[ind1[group4]])



  indnew3p2 <- sum((1-dynew[ind1[group2]])*(1-dynew[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^3-Fy1new[ind2[group2]]^3)/3) +
    sum((1-dynew[ind1[group3]])*(1-dynew[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^3-Fy1new[ind2[group3]]^3)/3) -
    sum(((1-dynew[ind1[group2]])*(Fy1new[ind2[group2]])+(1-dynew[ind2[group2]])*(Fy1new[ind1[group2]]))/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^2-Fy1new[ind2[group2]]^2)/2) -
    sum(((1-dynew[ind1[group3]])*(Fy1new[ind2[group3]])+(1-dynew[ind2[group3]])*(Fy1new[ind1[group3]]))/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^2-Fy1new[ind2[group3]]^2)/2) +
    sum((Fy1new[ind1[group2]])*(Fy1new[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]-Fy1new[ind2[group2]])) +
    sum((Fy1new[ind1[group3]])*(Fy1new[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]-Fy1new[ind2[group3]]))

  indnew3p3 <- sum(1/6/dynew[ind2[group2]]*(Fynew[ind2[group2]]^3+2*Fynew[ind1[group2]]^3-2*Fynew[ind1[group2]]^3*Fynew[ind2[group2]]+
                                              2*Fynew[ind1[group2]]^3*Fy1new[ind2[group2]]-
                                              3*Fynew[ind1[group2]]^2-3*Fynew[ind2[group2]]^2+3*Fynew[ind1[group2]]^2*Fynew[ind2[group2]]-
                                              6*Fynew[ind1[group2]]^2*Fy1new[ind2[group2]]+6*Fynew[ind1[group2]]*Fy1new[ind2[group2]]+
                                              2*Fynew[ind2[group2]]-2*Fy1new[ind2[group2]]))+
    sum(1/6/dynew[ind1[group3]]*(Fynew[ind1[group3]]^3+2*Fynew[ind2[group3]]^3-2*Fynew[ind2[group3]]^3*Fynew[ind1[group3]]+
                                   2*Fynew[ind2[group3]]^3*Fy1new[ind1[group3]]-
                                   3*Fynew[ind2[group3]]^2-3*Fynew[ind1[group3]]^2+3*Fynew[ind2[group3]]^2*Fynew[ind1[group3]]-
                                   6*Fynew[ind2[group3]]^2*Fy1new[ind1[group3]]+6*Fynew[ind2[group3]]*Fy1new[ind1[group3]]+
                                   2*Fynew[ind1[group3]]-2*Fy1new[ind1[group3]]))



  disnull <- int1new+2*(ind2new1+ind2new2+indnew3p1+indnew3p2+indnew3p3)
  disin <- rep(0,B)

  for(repin in 1:B){
    y0r <- rbinom(n, size = 1, prob = 1 - pzero)
    y1r <- rnegbin(n, mu=lambda1f, theta=size1f)

    yr <- ifelse(y0r == 0, 0, y1r)

    #####!!!changes made
    #####!!!

    dfr <- df
    dfr[,1] <- yr
    #fit marginal model
    model1r <- zeroinfl(formula1, dist = dis, link = lin,data=dfr)

    lambda1fr <- predict(model1r,type="count")
    pzeror <- predict(model1r,type="zero")

    size1fr <- model1r$theta
    #####!!!
    #####!!!

    Fyr <- (pzeror + (1 - pzeror) *  pnbinom(yr,mu=lambda1fr,size=size1fr))
    Fy1r <-  ifelse(yr==0,0,(pzeror + (1 - pzeror) * pnbinom(yr-1,mu=lambda1fr,size=size1fr)))
    dyr <-  Fyr-Fy1r


    int1newr <- sum(1/3*(Fyr^4+Fy1r^4-Fyr^3*Fy1r-Fyr*Fy1r^3-2*Fyr^3-Fy1r^3+3*Fyr^2*Fy1r+Fyr^2-2*Fyr*Fy1r+Fy1r^2)/dyr^2)



    Fy1new <- sort(Fy1r)
    Fynew <- Fyr[sort(Fy1r,index=TRUE)$ix]
    dynew <- dyr[sort(Fy1r,index=TRUE)$ix]



    group1 <- which(Fy1new[ind2]>Fynew[ind1])
    ## overlap, and keep order. k=ind1,k'=ind2,m=ind2,m'=ind1
    group2 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]>Fynew[ind1])
    ## overlap, and switch order for on right side. k=ind1,k'=ind2,m=ind1,m'=ind2
    group3 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]<=Fynew[ind1])
    group4 <- which(Fy1new[ind2]<=Fynew[ind1])

    ind2new1r <- sum(((Fynew^3-Fy1new^3)/6/dynew)[ind1[group1]])

    ind2new2r <- sum(((Fynew^3-Fy1new^3-3*Fynew^2+3*Fy1new^2+2*Fynew-2*Fy1new)/dynew/6)[ind2[group1]])


    indnew3p1r <- sum((-Fy1new[ind1[group4]]^3-2*Fy1new[ind2[group4]]^3*(1-dynew[ind1[group4]])+3*Fy1new[ind1[group4]]*Fy1new[ind2[group4]]^2)/6/dynew[ind1[group4]])



    indnew3p2r <- sum((1-dynew[ind1[group2]])*(1-dynew[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^3-Fy1new[ind2[group2]]^3)/3) +
      sum((1-dynew[ind1[group3]])*(1-dynew[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^3-Fy1new[ind2[group3]]^3)/3) -
      sum(((1-dynew[ind1[group2]])*(Fy1new[ind2[group2]])+(1-dynew[ind2[group2]])*(Fy1new[ind1[group2]]))/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^2-Fy1new[ind2[group2]]^2)/2) -
      sum(((1-dynew[ind1[group3]])*(Fy1new[ind2[group3]])+(1-dynew[ind2[group3]])*(Fy1new[ind1[group3]]))/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^2-Fy1new[ind2[group3]]^2)/2) +
      sum((Fy1new[ind1[group2]])*(Fy1new[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]-Fy1new[ind2[group2]])) +
      sum((Fy1new[ind1[group3]])*(Fy1new[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]-Fy1new[ind2[group3]]))

    indnew3p3r <- sum(1/6/dynew[ind2[group2]]*(Fynew[ind2[group2]]^3+2*Fynew[ind1[group2]]^3-2*Fynew[ind1[group2]]^3*Fynew[ind2[group2]]+
                                                 2*Fynew[ind1[group2]]^3*Fy1new[ind2[group2]]-
                                                 3*Fynew[ind1[group2]]^2-3*Fynew[ind2[group2]]^2+3*Fynew[ind1[group2]]^2*Fynew[ind2[group2]]-
                                                 6*Fynew[ind1[group2]]^2*Fy1new[ind2[group2]]+6*Fynew[ind1[group2]]*Fy1new[ind2[group2]]+
                                                 2*Fynew[ind2[group2]]-2*Fy1new[ind2[group2]]))+
      sum(1/6/dynew[ind1[group3]]*(Fynew[ind1[group3]]^3+2*Fynew[ind2[group3]]^3-2*Fynew[ind2[group3]]^3*Fynew[ind1[group3]]+
                                     2*Fynew[ind2[group3]]^3*Fy1new[ind1[group3]]-
                                     3*Fynew[ind2[group3]]^2-3*Fynew[ind1[group3]]^2+3*Fynew[ind2[group3]]^2*Fynew[ind1[group3]]-
                                     6*Fynew[ind2[group3]]^2*Fy1new[ind1[group3]]+6*Fynew[ind2[group3]]*Fy1new[ind1[group3]]+
                                     2*Fynew[ind1[group3]]-2*Fy1new[ind1[group3]]))



    disin[repin] <-int1newr+2*(ind2new1r+ind2new2r+indnew3p1r+indnew3p2r+indnew3p3r)


  }
  pvalue <- length(which(disin>disnull))/B

  return(list(test_stat = disnull, p_value = pvalue))
}

#' @importFrom utils combn
#' @importFrom pscl zeroinfl
#' @keywords internal
gof_zpois <- function(B, model1=NULL, seed = NULL) {
  if (!is.null(seed)) set.seed(seed)
  if(is.null(model1)) stop("model object is not given.")

  y <- model1$model[, 1]
  n <- length(y)
  meanpoisson <- predict(model1,type="count")
  pzero <- predict(model1,type="zero")
  df <- model1$model
  dis <- model1$dist
  lin <- model1$link
  formula1 <- model1$formula
  #####!!!
  #####!!!


  como <- combn(n,2)
  ind1 <- como[1,]
  ind2 <- como[2,]


  ## F(Y), F(Y-1), P(Y)

  Fy <- (pzero + (1 - pzero) * (ppois(y, lambda = meanpoisson)))
  Fy1 <-  ifelse(y==0,0,(pzero + (1 - pzero) * (ppois(y-1, lambda = meanpoisson))))
  dy <-  Fy-Fy1


  int1new <- sum(1/3*(Fy^4+Fy1^4-Fy^3*Fy1-Fy*Fy1^3-2*Fy^3-Fy1^3+3*Fy^2*Fy1+Fy^2-2*Fy*Fy1+Fy1^2)/dy^2)


  Fy1new <- sort(Fy1)
  Fynew <- Fy[sort(Fy1,index=TRUE)$ix]
  dynew <- dy[sort(Fy1,index=TRUE)$ix]




  ###no overlap
  group1 <- which(Fy1new[ind2]>Fynew[ind1])
  ## overlap, and keep order. k=ind1,k'=ind2,m=ind2,m'=ind1
  group2 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]>Fynew[ind1])
  ## overlap, and switch order for on right side. k=ind1,k'=ind2,m=ind1,m'=ind2
  group3 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]<=Fynew[ind1])
  group4 <- which(Fy1new[ind2]<=Fynew[ind1])

  ind2new1 <- sum(((Fynew^3-Fy1new^3)/6/dynew)[ind1[group1]])

  ind2new2 <- sum(((Fynew^3-Fy1new^3-3*Fynew^2+3*Fy1new^2+2*Fynew-2*Fy1new)/dynew/6)[ind2[group1]])


  indnew3p1 <- sum((-Fy1new[ind1[group4]]^3-2*Fy1new[ind2[group4]]^3*(1-dynew[ind1[group4]])+3*Fy1new[ind1[group4]]*Fy1new[ind2[group4]]^2)/6/dynew[ind1[group4]])



  indnew3p2 <- sum((1-dynew[ind1[group2]])*(1-dynew[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^3-Fy1new[ind2[group2]]^3)/3) +
    sum((1-dynew[ind1[group3]])*(1-dynew[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^3-Fy1new[ind2[group3]]^3)/3) -
    sum(((1-dynew[ind1[group2]])*(Fy1new[ind2[group2]])+(1-dynew[ind2[group2]])*(Fy1new[ind1[group2]]))/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^2-Fy1new[ind2[group2]]^2)/2) -
    sum(((1-dynew[ind1[group3]])*(Fy1new[ind2[group3]])+(1-dynew[ind2[group3]])*(Fy1new[ind1[group3]]))/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^2-Fy1new[ind2[group3]]^2)/2) +
    sum((Fy1new[ind1[group2]])*(Fy1new[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]-Fy1new[ind2[group2]])) +
    sum((Fy1new[ind1[group3]])*(Fy1new[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]-Fy1new[ind2[group3]]))

  indnew3p3 <- sum(1/6/dynew[ind2[group2]]*(Fynew[ind2[group2]]^3+2*Fynew[ind1[group2]]^3-2*Fynew[ind1[group2]]^3*Fynew[ind2[group2]]+
                                              2*Fynew[ind1[group2]]^3*Fy1new[ind2[group2]]-
                                              3*Fynew[ind1[group2]]^2-3*Fynew[ind2[group2]]^2+3*Fynew[ind1[group2]]^2*Fynew[ind2[group2]]-
                                              6*Fynew[ind1[group2]]^2*Fy1new[ind2[group2]]+6*Fynew[ind1[group2]]*Fy1new[ind2[group2]]+
                                              2*Fynew[ind2[group2]]-2*Fy1new[ind2[group2]]))+
    sum(1/6/dynew[ind1[group3]]*(Fynew[ind1[group3]]^3+2*Fynew[ind2[group3]]^3-2*Fynew[ind2[group3]]^3*Fynew[ind1[group3]]+
                                   2*Fynew[ind2[group3]]^3*Fy1new[ind1[group3]]-
                                   3*Fynew[ind2[group3]]^2-3*Fynew[ind1[group3]]^2+3*Fynew[ind2[group3]]^2*Fynew[ind1[group3]]-
                                   6*Fynew[ind2[group3]]^2*Fy1new[ind1[group3]]+6*Fynew[ind2[group3]]*Fy1new[ind1[group3]]+
                                   2*Fynew[ind1[group3]]-2*Fy1new[ind1[group3]]))



  disnull <- int1new+2*(ind2new1+ind2new2+indnew3p1+indnew3p2+indnew3p3)
  disin <- rep(0,B)

  for(repin in 1:B){

    y0r <- rbinom(n, size = 1, prob = 1 - pzero)
    y1r <- rpois(n, meanpoisson)

    yr <- ifelse(y0r == 0, 0, y1r)
    #####!!!changes made
    #####!!!

    dfr <- df
    dfr[,1] <- yr
    #fit marginal model
    model1r <- zeroinfl(formula1, dist = dis, link = lin,data=dfr)

    meanpoissonr <- predict(model1r,type="count")
    pzeror <- predict(model1r,type="zero")

    size1fr <- model1r$theta
    #####!!!
    #####!!!

    Fyr <- (pzeror + (1 - pzeror) * (ppois(yr, lambda = meanpoissonr)))
    Fy1r <-  ifelse(yr==0,0,(pzeror + (1 - pzeror) * (ppois(yr-1, lambda = meanpoissonr))))
    dyr <-  Fyr-Fy1r


    int1newr <- sum(1/3*(Fyr^4+Fy1r^4-Fyr^3*Fy1r-Fyr*Fy1r^3-2*Fyr^3-Fy1r^3+3*Fyr^2*Fy1r+Fyr^2-2*Fyr*Fy1r+Fy1r^2)/dyr^2)



    Fy1new <- sort(Fy1r)
    Fynew <- Fyr[sort(Fy1r,index=TRUE)$ix]
    dynew <- dyr[sort(Fy1r,index=TRUE)$ix]



    group1 <- which(Fy1new[ind2]>Fynew[ind1])
    ## overlap, and keep order. k=ind1,k'=ind2,m=ind2,m'=ind1
    group2 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]>Fynew[ind1])
    ## overlap, and switch order for on right side. k=ind1,k'=ind2,m=ind1,m'=ind2
    group3 <- which(Fy1new[ind2]<=Fynew[ind1]&Fynew[ind2]<=Fynew[ind1])
    group4 <- which(Fy1new[ind2]<=Fynew[ind1])

    ind2new1r <- sum(((Fynew^3-Fy1new^3)/6/dynew)[ind1[group1]])

    ind2new2r <- sum(((Fynew^3-Fy1new^3-3*Fynew^2+3*Fy1new^2+2*Fynew-2*Fy1new)/dynew/6)[ind2[group1]])


    indnew3p1r <- sum((-Fy1new[ind1[group4]]^3-2*Fy1new[ind2[group4]]^3*(1-dynew[ind1[group4]])+3*Fy1new[ind1[group4]]*Fy1new[ind2[group4]]^2)/6/dynew[ind1[group4]])



    indnew3p2r <- sum((1-dynew[ind1[group2]])*(1-dynew[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^3-Fy1new[ind2[group2]]^3)/3) +
      sum((1-dynew[ind1[group3]])*(1-dynew[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^3-Fy1new[ind2[group3]]^3)/3) -
      sum(((1-dynew[ind1[group2]])*(Fy1new[ind2[group2]])+(1-dynew[ind2[group2]])*(Fy1new[ind1[group2]]))/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]^2-Fy1new[ind2[group2]]^2)/2) -
      sum(((1-dynew[ind1[group3]])*(Fy1new[ind2[group3]])+(1-dynew[ind2[group3]])*(Fy1new[ind1[group3]]))/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]^2-Fy1new[ind2[group3]]^2)/2) +
      sum((Fy1new[ind1[group2]])*(Fy1new[ind2[group2]])/dynew[ind1[group2]]/dynew[ind2[group2]]*(Fynew[ind1[group2]]-Fy1new[ind2[group2]])) +
      sum((Fy1new[ind1[group3]])*(Fy1new[ind2[group3]])/dynew[ind1[group3]]/dynew[ind2[group3]]*(Fynew[ind2[group3]]-Fy1new[ind2[group3]]))

    indnew3p3r <- sum(1/6/dynew[ind2[group2]]*(Fynew[ind2[group2]]^3+2*Fynew[ind1[group2]]^3-2*Fynew[ind1[group2]]^3*Fynew[ind2[group2]]+
                                                 2*Fynew[ind1[group2]]^3*Fy1new[ind2[group2]]-
                                                 3*Fynew[ind1[group2]]^2-3*Fynew[ind2[group2]]^2+3*Fynew[ind1[group2]]^2*Fynew[ind2[group2]]-
                                                 6*Fynew[ind1[group2]]^2*Fy1new[ind2[group2]]+6*Fynew[ind1[group2]]*Fy1new[ind2[group2]]+
                                                 2*Fynew[ind2[group2]]-2*Fy1new[ind2[group2]]))+
      sum(1/6/dynew[ind1[group3]]*(Fynew[ind1[group3]]^3+2*Fynew[ind2[group3]]^3-2*Fynew[ind2[group3]]^3*Fynew[ind1[group3]]+
                                     2*Fynew[ind2[group3]]^3*Fy1new[ind1[group3]]-
                                     3*Fynew[ind2[group3]]^2-3*Fynew[ind1[group3]]^2+3*Fynew[ind2[group3]]^2*Fynew[ind1[group3]]-
                                     6*Fynew[ind2[group3]]^2*Fy1new[ind1[group3]]+6*Fynew[ind2[group3]]*Fy1new[ind1[group3]]+
                                     2*Fynew[ind1[group3]]-2*Fy1new[ind1[group3]]))



    disin[repin] <-int1newr+2*(ind2new1r+ind2new2r+indnew3p1r+indnew3p2r+indnew3p3r)


  }
  ##p-value
  pvalue <- length(which(disin>disnull))/B


  return(list(test_stat = disnull, p_value = pvalue))
}

Try the assessor package in your browser

Any scripts or data that you put into this service are public.

assessor documentation built on March 23, 2026, 1:06 a.m.