Nothing
aov.sufficient <- function(...)
.Defunct("aovSufficient", package="HH")
aovSufficient <-
function(formula, data = NULL, projections = FALSE, qr = TRUE,
contrasts = NULL,
weights=data$n, sd=data$s, ...) {
## data$weights <- weights ## this works when, as in the pulmonary example, the weights are
## named 'n', but has the risk of overwriting a variable named weights in some other example.
environment(formula) <- environment() ## this seems to be the right way to get the local
## 'weights' variable recognized down the line by model.frame.default.
result <- aov(formula=formula, data=data, weights=weights, x=TRUE)
result$df.residual <- sum(weights-1)
Sq.res <- (weights-1)*sd^2
result$residuals[] <- sqrt(sum(Sq.res)/sum(weights))
result
}
## summary.lm does not give standard errors and t-tests for results
## calculated by aovSufficient. We need vcovSufficient in R.
## It gives the same answer as the generic vcov when the generic vcov works.
vcov.sufficient <- function(...)
.Defunct("vcovSufficient", package="HH")
vcovSufficient <- function(object, ...) {
x <- object["x"][[1]] ## prevents partial matching with "xlevels" in R.
## S-Plus doesn't have an "xlevels" component.
if (length(x)==0) {
x <- try(update(object, x=TRUE)$x, silent=TRUE)
if ("try-error" %in% class(x))
stop("Please recompute the 'lm' object with 'x=TRUE'.")
}
xwx <-
if (is.null(object$weights))
crossprod(x)
else
crossprod(x, object$weights * x)
solve(xwx)*anova(object)$`Mean Sq`[2]
}
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.