Nothing
#' Exponential Regression for Duration Dependent Variables
#'@param formula a symbolic representation of the model to be
#' estimated, in the form \code{y ~ x1 + x2}, where \code{y} is the
#' dependent variable and \code{x1} and \code{x2} are the explanatory
#' variables, and \code{y}, \code{x1}, and \code{x2} are contained in the
#' same dataset. (You may include more than two explanatory variables,
#' of course.) The \code{+} symbol means ``inclusion'' not
#' ``addition.'' You may also include interaction terms and main
#' effects in the form \code{x1*x2} without computing them in prior
#' steps; \code{I(x1*x2)} to include only the interaction term and
#' exclude the main effects; and quadratic terms in the form
#' \code{I(x1^2)}.
#' @param model the name of a statistical model to estimate.
#' For a list of supported models and their documentation see:
#' \url{http://docs.zeligproject.org/articles/}.
#' @param data the name of a data frame containing the variables
#' referenced in the formula or a list of multiply imputed data frames
#' each having the same variable names and row numbers (created by
#' \code{Amelia} or \code{\link{to_zelig_mi}}).
#' @param ... additional arguments passed to \code{zelig},
#' relevant for the model to be estimated.
#' @param by a factor variable contained in \code{data}. If supplied,
#' \code{zelig} will subset
#' the data frame based on the levels in the \code{by} variable, and
#' estimate a model for each subset. This can save a considerable amount of
#' effort. For example, to run the same model on all fifty states, you could
#' use: \code{z.out <- zelig(y ~ x1 + x2, data = mydata, model = 'ls',
#' by = 'state')} You may also use \code{by} to run models using MatchIt
#' subclasses.
#' @param cite If is set to 'TRUE' (default), the model citation will be printed
#' to the console.
#'
#' @details
#' Additional parameters avaialable to this model include:
#' \itemize{
#' \item \code{weights}: vector of weight values or a name of a variable in the dataset
#' by which to weight the model. For more information see:
#' \url{http://docs.zeligproject.org/articles/weights.html}.
#' \item \code{bootstrap}: logical or numeric. If \code{FALSE} don't use bootstraps to
#' robustly estimate uncertainty around model parameters due to sampling error.
#' If an integer is supplied, the number of boostraps to run.
#' For more information see:
#' \url{http://docs.zeligproject.org/articles/bootstraps.html}.
#' }
#' @return Depending on the class of model selected, \code{zelig} will return
#' an object with elements including \code{coefficients}, \code{residuals},
#' and \code{formula} which may be summarized using
#' \code{summary(z.out)} or individually extracted using, for example,
#' \code{coef(z.out)}. See
#' \url{http://docs.zeligproject.org/articles/getters.html} for a list of
#' functions to extract model components. You can also extract whole fitted
#' model objects using \code{\link{from_zelig_model}}.
#' @param robust defaults to FALSE. If TRUE, zelig() computes robust standard errors based on sandwich estimators and the options selected in cluster.
#' @param if robust = TRUE, you may select a variable to define groups of correlated observations. Let x3 be a variable that consists of either discrete numeric values, character strings, or factors that define strata. Then
#' z.out <- zelig(y ~ x1 + x2, robust = TRUE, cluster = "x3",model = "exp", data = mydata)
#' means that the observations can be correlated within the strata defined by the variable x3, and that robust standard errors should be calculated according to those clusters. If robust = TRUE but cluster is not specified, zelig() assumes that each observation falls into its own cluster.
#'
#' @examples
#' library(Zelig)
#' data(coalition)
#' library(survival)
#' z.out <- zelig(Surv(duration, ciep12) ~ fract + numst2, model = "exp",
#' data = coalition)
#' summary(z.out)
#'
#' @seealso Vignette: \url{http://docs.zeligproject.org/articles/zelig_exp.html}
#' @import methods
#' @export Zelig-exp
#' @exportClass Zelig-exp
#'
#' @include model-zelig.R
zexp <- setRefClass("Zelig-exp",
contains = "Zelig",
fields = list(simalpha = "list",
linkinv = "function"))
zexp$methods(
initialize = function() {
callSuper()
.self$name <- "exp"
.self$authors <- "Olivia Lau, Kosuke Imai, Gary King"
.self$packageauthors <- "Terry M. Therneau, and Thomas Lumley"
.self$year <- 2011
.self$description <- "Exponential Regression for Duration Dependent Variables"
.self$fn <- quote(survival::survreg)
.self$linkinv <- survreg.distributions[["exponential"]]$itrans
# JSON
.self$outcome <- "continous"
.self$wrapper <- "exp"
.self$acceptweights <- TRUE
}
)
zexp$methods(
zelig = function(formula, ..., robust = FALSE, cluster = NULL, data,
weights = NULL, by = NULL, bootstrap = FALSE) {
localFormula <- formula # avoids CRAN warning about deep assignment from formula existing separately as argument and field
.self$zelig.call <- match.call(expand.dots = TRUE)
.self$model.call <- .self$zelig.call
if (!(is.null(cluster) || robust))
stop("If cluster is specified, then `robust` must be TRUE")
# Add cluster term
if (robust || !is.null(cluster))
localFormula <- cluster.formula(localFormula, cluster)
.self$model.call$dist <- "exponential"
.self$model.call$model <- FALSE
callSuper(formula = localFormula, data = data, ..., robust = robust,
cluster = cluster, weights = weights, by = by, bootstrap = bootstrap)
rse <- lapply(.self$zelig.out$z.out, (function(x) vcovHC(x, type = "HC0")))
.self$test.statistics <- list(robust.se = rse)
}
)
zexp$methods(
qi = function(simparam, mm) {
eta <- simparam %*% t(mm)
ev <- as.matrix(apply(eta, 2, linkinv))
pv <- as.matrix(rexp(length(ev), rate = 1 / ev))
return(list(ev = ev, pv = pv))
}
)
zexp$methods(
mcfun = function(x, b0=0, b1=1, alpha=1, sim=TRUE){
.self$mcformula <- as.Formula("Surv(y.sim, event) ~ x.sim")
lambda <-exp(b0 + b1 * x)
event <- rep(1, length(x))
y.sim <- rexp(n=length(x), rate=lambda)
y.hat <- 1/lambda
if(sim){
mydata <- data.frame(y.sim=y.sim, event=event, x.sim=x)
return(mydata)
}else{
mydata <- data.frame(y.hat=y.hat, event=event, x.seq=x)
return(mydata)
}
}
)
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.