https://github.com/cran/coin
Tip revision: 324e18edadb75a3d23c8cc045d639f1c306bf7ff authored by Torsten Hothorn on 25 July 2005, 00:00:00 UTC
version 0.2-14
version 0.2-14
Tip revision: 324e18e
Methods.R
### generic method for asymptotic null distributions
setGeneric("AsymptNullDistribution", function(object, ...)
standardGeneric("AsymptNullDistribution"))
### method for max-type test statistics
setMethod(f = "AsymptNullDistribution",
signature = "ScalarIndependenceTestStatistic",
definition = function(object, ...) {
RET <- new("AsymptNullDistribution")
RET@p <- function(q) pnorm(q)
RET@q <- function(p) qnorm(p)
RET@d <- function(x) dnorm(x)
RET@pvalue <- function(q) {
switch(object@alternative,
"less" = pnorm(q),
"greater" = 1 - pnorm(q),
"two.sided" = 2 * min(pnorm(q), 1 - pnorm(q))
)
}
RET@support <- function(p = 1e-5) c(RET@q(p), RET@q(1 - p))
RET@name <- "normal distribution"
return(RET)
}
)
### method for max-type test statistics
setMethod(f = "AsymptNullDistribution",
signature = "MaxTypeIndependenceTestStatistic",
definition = function(object, ...) {
corr <- cov2cor(covariance(object))
pq <- length(expectation(object))
RET <- new("AsymptNullDistribution")
RET@p <- function(q) {
if (length(corr) > 1)
p <- pmvnorm(lower = -abs(q), upper = abs(q),
mean = rep(0, pq),
corr = corr, ...)
else
p <- pmvnorm(lower = -abs(q), upper = abs(q),
mean = rep(0, pq),
sigma = 1, ...)
error <- attr(p, "error")
attr(p, "error") <- NULL
attr(p, "conf.int") <- c(max(0, p - error), min(p + error, 1))
class(p) <- "MCp"
p
}
RET@q <- function(p) {
if (length(corr) > 1)
q <- qmvnorm(p, mean = rep(0, pq),
corr = corr, tail = "both.tails", ...)$quantile
else
q <- qmvnorm(p, mean = rep(0, pq),
sigma = 1, tail = "both.tails", ...)$quantile
attributes(q) <- NULL
q
}
RET@d <- function(x) dmvnorm(x)
RET@pvalue <- function(q) {
p <- 1 - RET@p(q)
attr(p, "conf.int") <- 1 - attr(p, "conf.int")[c(2,1)]
class(p) <- "MCp"
p
}
RET@support <- RET@support <- function(p = 1e-5)
c(RET@q(p), RET@q(1 - p))
RET@name <- "multivariate normal distribution"
RET@parameters <- list(corr = corr)
return(RET)
}
)
### method for quad-type test statistics
setMethod(f = "AsymptNullDistribution",
signature = "QuadTypeIndependenceTestStatistic",
definition = function(object, ...) {
RET <- new("AsymptNullDistribution")
RET@p <- function(q) pchisq(q, df = object@df)
RET@q <- function(p) qchisq(p, df = object@df)
RET@d <- function(d) dchisq(d, df = object@df)
RET@pvalue <- function(q) 1 - RET@p(q)
RET@support <- function(p = 1e-5) c(RET@q(p), RET@q(1 - p))
RET@name <- "chisq distribution"
RET@parameters <- list(df = object@df)
return(RET)
}
)
### generic method for exact null distributions
setGeneric("ExactNullDistribution", function(object, ...)
standardGeneric("ExactNullDistribution"))
setMethod(f = "ExactNullDistribution",
signature = "ScalarIndependenceTestStatistic",
definition = function(object, algorithm = c("shift", "split-up"),
...) {
if (is_2sample(object)) {
if (algorithm == "shift")
return(SR_shift_2sample(object, ...))
if (algorithm == "split-up")
return(vdW_split_up_2sample(object))
}
error(sQuote("object"), " is not a two sample problem")
}
)
### generic method for approximate null distributions
setGeneric("ApproxNullDistribution", function(object, ...)
standardGeneric("ApproxNullDistribution"))
setMethod(f = "ApproxNullDistribution",
signature = "ScalarIndependenceTestStatistic",
definition = function(object, B = 1000, ...) {
if (!(max(abs(object@weights - 1.0)) < sqrt(.Machine$double.eps)))
stop("cannot approximate distribution with non-unity weights")
pls <- .Call("R_MonteCarloIndependenceTest", object@xtrans,
object@ytrans, as.integer(object@block), as.integer(B),
PACKAGE = "coin")
### <FIXME> can transform p, q, x instead of those </FIXME>
pls <- sort(round((unlist(pls) - expectation(object)) /
sqrt(variance(object)), 10))
RET <- new("ApproxNullDistribution")
RET@p <- function(q) {
p <- mean(pls <= round(q, 10))
attr(p, "conf.int") <- binom.test(round(p * B), B,
conf.level = 0.99)$conf.int
class(p) <- "MCp"
p
}
RET@q <- function(p) pls[length(pls) * p]
RET@d <- function(x) length(pls == x)
RET@pvalue <- function(q) {
p <- switch(object@alternative,
"less" = mean(pls <= round(q, 10)),
"greater" = mean(pls >= round(q, 10)),
"two.sided" = {
q <- round(q, 10)
if (q == 0) 1
mean(pls <= ifelse(q > 0, -q, q)) +
mean(pls >= ifelse(q >= 0, q, -q))
}
)
attr(p, "conf.int") <- binom.test(round(p * B), B,
conf.level = 0.99)$conf.int
class(p) <- "MCp"
p
}
RET@support <- function(p = 1e-5) unique(pls)
return(RET)
}
)
setMethod(f = "ApproxNullDistribution",
signature = "MaxTypeIndependenceTestStatistic",
definition = function(object, B = 1000, ...) {
if (!(max(abs(object@weights - 1.0)) < sqrt(.Machine$double.eps)))
stop("cannot approximate distribution with non-unity weights")
pls <- .Call("R_MonteCarloIndependenceTest", object@xtrans,
object@ytrans, as.integer(object@block), as.integer(B),
PACKAGE = "coin")
if (object@has_scores) {
S <- object@scores
pls <- lapply(pls, function(x) S %*% x)
}
dcov <- sqrt(variance(object))
expect <- expectation(object)
pls <- lapply(pls, function(x)
max(abs(x - expect) / dcov)
)
pls <- sort(round(unlist(pls), 10))
RET <- new("ApproxNullDistribution")
RET@p <- function(q) {
p <- mean(pls <= round(q, 10))
attr(p, "conf.int") <- binom.test(round(p * B), B,
conf.level = 0.99)$conf.int
class(p) <- "MCp"
p
}
RET@q <- function(p) pls[length(pls) * p]
RET@d <- function(x) length(pls == x)
RET@pvalue <- function(q) {
p <- mean(pls >= round(q, 10))
attr(p, "conf.int") <- binom.test(round(p * B), B,
conf.level = 0.99)$conf.int
class(p) <- "MCp"
p
}
RET@support <- function(p = 1e-5) unique(pls)
RET@name = "MonteCarlo distribution"
return(RET)
}
)
setMethod(f = "ApproxNullDistribution",
signature = "QuadTypeIndependenceTestStatistic",
definition = function(object, B = 1000, ...) {
if (!(max(abs(object@weights - 1.0)) < sqrt(.Machine$double.eps)))
stop("cannot approximate distribution with non-unity weights")
pls <- .Call("R_MonteCarloIndependenceTest", object@xtrans,
object@ytrans, as.integer(object@block), as.integer(B),
PACKAGE = "coin")
if (object@has_scores) {
S <- object@scores
pls <- lapply(pls, function(x) S %*% x)
}
dcov <- object@covarianceplus
expect <- expectation(object)
pls <- lapply(pls, function(x) {
a <- x - expect
drop(a %*% dcov %*% a)
}
)
pls <- sort(round(unlist(pls), 10))
RET <- new("ApproxNullDistribution")
RET@p <- function(q) {
p <- mean(pls <= round(q, 10))
attr(p, "conf.int") <- binom.test(round(p * B), B,
conf.level = 0.99)$conf.int
class(p) <- "MCp"
p
}
RET@q <- function(p) pls[length(pls) * p]
RET@d <- function(x) length(pls == x)
RET@pvalue <- function(q) {
p <- mean(pls >= round(q, 10))
attr(p, "conf.int") <- binom.test(round(p * B), B,
conf.level = 0.99)$conf.int
class(p) <- "MCp"
p
}
RET@support <- function(p = 1e-5) unique(pls)
RET@name = "MonteCarlo distribution"
return(RET)
}
)
confint.ScalarIndependenceTestConfint <- function(object, parm, level = 0.95,
...) {
if ("level" %in% names(match.call()))
x <- object@confint(level)
else
x <- object@confint(object@conf.level)
class(x) <- "ci"
return(x)
}