
#' @param ngroup0 (Input) initial number of pieces in the partition
#' @param rate0 (Input) expansion rate
#' @param data (Input) Data set: first column is the survival time,
#'     second column is the event indicator, covariates should be placed after second column
#' @param ngroup1 (Output) Final number of pieces in the partition
#' @param vquant (Output) The final partition of the piecewise constant hazard function
#'  at the last update.
#' @param vbetacum1 (Output) The cumulative parameter estimates of regression coefficients
#'  under the no bias correction method
#' @param vbetacum3 (Output) The cumulative parameter estimates of regression coefficients
#'  under the bias correction method
#' @param vlambdacum1 (Output) The cumulative parameter estimates of baseline hazards
#'  under the no bias correction method
#' @param vlambdacum3 (Output) The cumulative parameter estimates of baseline hazards
#'  under the bias correction method
#' @param std1 (Output) The cumulative standard error estimates of regression coefficients
#'  under the no bias correction method
#' @param std3 (Output) The cumulative standard error estimates of regression coefficients
#'  under the bias correction method
#' @return Bayesian comparison criteria (DIC and LPML), posterior
#' estimate of coefficients of covariates, treatment effects, variances
#' and correlation matrix of treatment random effects
#' @useDynLib updatesurve, .registration = TRUE
#' @export
updatesurvereal <- function(
                           ngroup0=as.integer(1),
                           rate0=as.double(200),
                           data=as.double(as.matrix(data)),
                           ngroup1=as.integer(1),
                           vquant=as.double(matrix(0, 200, 1)),
                           vbetacum1=as.double(matrix(0, 2, 1)),
                           vbetacum3=as.double(matrix(0, 2, 1)),
                           vlambdacum1=as.double(matrix(0, 200, 1)),
                           vlambdacum3=as.double(matrix(0, 200, 1)),
                           std1=as.double(matrix(0, 2, 1)),
                           std3=as.double(matrix(0, 2, 1))){


  xaux= as.double(as.matrix(data[, 3:4]))
  tfail= as.double(data[, 1])
  icensa= as.integer(data[, 2])

  library.dynam("updatesurvival", package=c("updatesurvival"), lib.loc = .libPaths())
  try(
  fit <- .Fortran("updatesurvereal",
                  ngroup0=as.integer(ngroup0),
                  rate0=as.double(rate0),
                  xaux= as.double(xaux),
                  tfail= as.double(tfail),
                  icensa= as.integer(icensa),
                  ngroup1=as.integer(1),
                  vquant=as.double(vquant),
                  vbetacum1=as.double(vbetacum1),
                  vbetacum3=as.double(vbetacum3),
                  vlambdacum1=as.double(vlambdacum1),
                  vlambdacum3=as.double(vlambdacum3),
                  std1=as.double(std1),
                  std3=as.double(std3),
                  PACKAGE="updatesurvival")
  )
  return(fit)
}





