1 |
x |
|
y |
|
crit |
|
flag |
|
plotit |
|
sm |
|
op |
|
xlab |
|
ylab |
|
pr |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 | ##---- Should be DIRECTLY executable !! ----
##-- ==> Define data, use random,
##-- or do help(data=index) for the standard data sets.
## The function is currently defined as
function (x, y, crit = 1.36 * sqrt((length(x) + length(y))/(length(x) *
length(y))), flag = FALSE, plotit = TRUE, sm = TRUE, op = 1,
xlab = "First Group", ylab = "Delta", pr = TRUE)
{
x <- x[!is.na(x)]
y <- y[!is.na(y)]
plotit <- as.logical(plotit)
flag <- as.logical(flag)
pc <- NA
if (flag) {
if (pr)
print("Computing the exact value of the probability coverage")
pc <- 1 - kssig(length(x), length(y), crit)
chk = sum(duplicated(x, y))
if (chk > 0)
pc = 1 - kstiesig(x, y, crit)
}
xsort <- sort(x)
ysort <- c(NA, sort(y))
l <- 0
u <- 0
ysort[length(y) + 1 + 1] <- NA
for (ivec in 1:length(x)) {
isub <- max(0, ceiling(length(y) * (ivec/length(x) -
crit)))
l[ivec] <- ysort[isub + 1] - xsort[ivec]
isub <- min(length(y) + 1, floor(length(y) * (ivec/length(x) +
crit)) + 1)
u[ivec] <- ysort[isub + 1] - xsort[ivec]
}
num <- length(l[l > 0 & !is.na(l)]) + length(u[u < 0 & !is.na(u)])
qhat <- c(1:length(x))/length(x)
m <- matrix(c(qhat, l, u), length(x), 3)
dimnames(m) <- list(NULL, c("qhat", "lower", "upper"))
if (plotit) {
xsort <- sort(x)
ysort <- sort(y)
del <- 0
for (i in 1:length(x)) {
ival <- round(length(y) * i/length(x))
if (ival <= 0)
ival <- 1
if (ival > length(y))
ival <- length(y)
del[i] <- ysort[ival] - xsort[i]
}
xaxis <- c(xsort, xsort)
yaxis <- c(m[, 1], m[, 2])
allx <- c(xsort, xsort, xsort)
ally <- c(del, m[, 2], m[, 3])
temp2 <- m[, 2]
temp2 <- temp2[!is.na(temp2)]
plot(allx, ally, type = "n", ylab = ylab, xlab = xlab)
ik <- rep(F, length(xsort))
if (sm) {
if (op == 1) {
ik <- duplicated(xsort)
del <- lowess(xsort, del)$y
}
if (op != 1)
del <- runmean(xsort, del, pyhat = TRUE)
}
lines(xsort[!ik], del[!ik])
lines(xsort, m[, 2], lty = 2)
lines(xsort, m[, 3], lty = 2)
temp <- summary(x)
text(temp[3], min(temp2), "+")
text(temp[2], min(temp2), "o")
text(temp[5], min(temp2), "o")
}
list(m = m, crit = crit, numsig = num, pc = pc)
}
|
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.