Title: | Exact Distributions for Rank and Permutation Tests |
---|---|
Description: | Computes exact conditional p-values and quantiles using an implementation of the Shift-Algorithm by Streitberg & Roehmel. |
Authors: | Torsten Hothorn [aut, cre], Kurt Hornik [aut] |
Maintainer: | Torsten Hothorn <[email protected]> |
License: | GPL (>= 2) |
Version: | 0.8-35 |
Built: | 2025-01-03 07:12:11 UTC |
Source: | CRAN |
Performs the Ansari-Bradley two-sample test for a difference in scale parameters for possibly tied observations.
## Default S3 method: ansari.exact(x, y, alternative = c("two.sided", "less", "greater"), exact = NULL, conf.int = FALSE, conf.level = 0.95, ...) ## S3 method for class 'formula' ansari.exact(formula, data, subset, na.action, ...)
## Default S3 method: ansari.exact(x, y, alternative = c("two.sided", "less", "greater"), exact = NULL, conf.int = FALSE, conf.level = 0.95, ...) ## S3 method for class 'formula' ansari.exact(formula, data, subset, na.action, ...)
x |
numeric vector of data values. |
y |
numeric vector of data values. |
alternative |
indicates the alternative hypothesis and must be
one of |
exact |
a logical indicating whether an exact p-value should be computed. |
conf.int |
a logical,indicating whether a confidence interval should be computed. |
conf.level |
confidence level of the interval. |
formula |
a formula of the form |
data |
an optional data frame containing the variables in the model formula. |
subset |
an optional vector specifying a subset of observations to be used. |
na.action |
a function which indicates what should happen when
the data contain |
... |
further arguments to be passed to or from methods. |
Suppose that x
and y
are independent samples from
distributions with densities and
,
respectively, where
is an unknown nuisance parameter and
, the ratio of scales, is the parameter of interest. The
Ansari-Bradley test is used for testing the null that
equals
1, the two-sided alternative being that
(the
distributions differ only in variance), and the one-sided alternatives
being
(the distribution underlying
x
has a larger
variance, "greater"
) or (
"less"
).
By default (if exact
is not specified), an exact p-value is
computed if both samples contain less than 50 finite values.
Otherwise, a normal approximation is used.
Optionally, a nonparametric confidence interval and an estimator for
are computed. If exact p-values are available, an exact
confidence interval is obtained by the algorithm described in Bauer
(1972), and the Hodges-Lehmann estimator is employed. Otherwise, the
returned confidence interval and point estimate are based on normal
approximations.
A list with class "htest"
containing the following components:
statistic |
the value of the Ansari-Bradley test statistic. |
p.value |
the p-value of the test. |
null.value |
the ratio of scales |
alternative |
a character string describing the alternative hypothesis. |
method |
the string |
data.name |
a character string giving the names of the data. |
conf.int |
a confidence interval for the scale parameter.
(Only present if argument |
estimate |
an estimate of the ratio of scales.
(Only present if argument |
To compare results of the Ansari-Bradley test to those of the F test
to compare two variances (under the assumption of normality), observe
that is the ratio of scales and hence
is the ratio
of variances (provided they exist), whereas for the F test the ratio
of variances itself is the parameter of interest. In particular,
confidence intervals are for
in the Ansari-Bradley test but
for
in the F test.
Myles Hollander & Douglas A. Wolfe (1973), Nonparametric statistical inference. New York: John Wiley & Sons. Pages 83–92.
David F. Bauer (1972), Constructing confidence sets using rank statistics. Journal of the American Statistical Association 67, 687–690.
fligner.test
for a rank-based (nonparametric)
-sample test for homogeneity of variances;
mood.test
for another rank-based two-sample test for a
difference in scale parameters;
var.test
and bartlett.test
for parametric
tests for the homogeneity in variance.
## Hollander & Wolfe (1973, p. 86f): ## Serum iron determination using Hyland control sera ramsay <- c(111, 107, 100, 99, 102, 106, 109, 108, 104, 99, 101, 96, 97, 102, 107, 113, 116, 113, 110, 98) jung.parekh <- c(107, 108, 106, 98, 105, 103, 110, 105, 104, 100, 96, 108, 103, 104, 114, 114, 113, 108, 106, 99) ansari.test(ramsay, jung.parekh) ansari.exact(ramsay, jung.parekh) ansari.exact(rnorm(20), rnorm(20, 0, 2), conf.int = TRUE)
## Hollander & Wolfe (1973, p. 86f): ## Serum iron determination using Hyland control sera ramsay <- c(111, 107, 100, 99, 102, 106, 109, 108, 104, 99, 101, 96, 97, 102, 107, 113, 116, 113, 110, 98) jung.parekh <- c(107, 108, 106, 98, 105, 103, 110, 105, 104, 100, 96, 108, 103, 104, 114, 114, 113, 108, 106, 99) ansari.test(ramsay, jung.parekh) ansari.exact(ramsay, jung.parekh) ansari.exact(rnorm(20), rnorm(20, 0, 2), conf.int = TRUE)
ASAT-Values for a new compound and a control group of 34 female Wistar rats.
data(ASAT)
data(ASAT)
A data frame with 34 observations on the following 2 variables.
the ASAT-values (a liver enzyme)
a factor with levels Compound
and Control
.
The aim of this toxicological study is the proof of safety for the new compound. The data are originally given in Hothorn (1992) and reproduced in Hauschke et al. (1999).
Ludwig A. Hothorn (1992), Biometrische Analyse toxikologischer Untersuchungen. In: J. Adams (ed.): Statistisches Know how in der medizinischen Forschung. Ullstein-Mosby, Berlin, 475–590.
Dieter Hauschke, Meinhard Kieser & Ludwig A. Hothorn (1999), Proof of safety in toxicology based on the ratio of two means for normally distributed data. Biometrical Journal, 41(3), 295–304.
Rafael Pfl\"uger & Torsten Hothorn (2002), Assessing Equivalence Tests with Respect to their Expected $p$-Value. Biometrical Journal, 44(8), 1002–1027.
set.seed(29) data(ASAT) # does not really look symmetric plot(asat ~ group, data=ASAT) # proof-of-safety based on ration of medians pos <- wilcox.exact(I(log(asat)) ~ group, data = ASAT, alternative = "less", conf.int=TRUE) # one-sided confidence set. Safety cannot be concluded since the effect of # the compound exceeds 20% of the control median exp(pos$conf.int)
set.seed(29) data(ASAT) # does not really look symmetric plot(asat ~ group, data=ASAT) # proof-of-safety based on ration of medians pos <- wilcox.exact(I(log(asat)) ~ group, data = ASAT, alternative = "less", conf.int=TRUE) # one-sided confidence set. Safety cannot be concluded since the effect of # the compound exceeds 20% of the control median exp(pos$conf.int)
Diastolic blood pressure for a two groups of patients.
data(bloodp)
data(bloodp)
A data frame with 15 observations on the following 2 variables.
the diastolic blood pressure.
a factor with levels group1
and group2
.
The data is given in Table 9.6, page 227, of Metha and Pathel (2001). Note that there are some tied observations. The permutation test using the raw blood pressure values does not lead to a rejection of the null hypothesis of exchangeability: p-value = 0.1040 (two-sided) and p-value = 0.0564 (one-sided). The asymptotic two-sided p-value is 0.1070.
For the Wilcoxon-Mann-Whitney test, the one-sided p-value is 0.0542 and the two-sided one is 0.0989 (Metha & Patel, 2001, page 229).
The one-sided p-value for the v.d.Waeren test is 0.0462 (Metha & Patel, 2001, page 241) and the two-sided p-value is 0.0799.
Cyrus R. Mehta & Nitin R. Patel (2001), StatXact-5 for Windows. Manual, Cytel Software Cooperation, Cambridge, USA
data(bloodp) # Permutation test perm.test(bp ~ group, data=bloodp) perm.test(bp ~ group, data=bloodp, alternative="greater") perm.test(bp ~ group, data=bloodp, exact=FALSE) # Wilcoxon-Mann-Whitney test wilcox.exact(bp ~ group, data=bloodp, conf.int=TRUE, alternative="l") wilcox.exact(bp ~ group, data=bloodp, conf.int=TRUE) # compute the v.d. Waerden test sc <- cscores(bloodp$bp, type="NormalQuantile") X <- sum(sc[bloodp$group == "group2"]) round(pperm(X, sc, 11), 4) ## IGNORE_RDIFF_BEGIN round(pperm(X, sc, 11, simulate=TRUE), 4) round(pperm(X, sc, 11, alternative="two.sided"), 4) round(pperm(X, sc, 11, alternative="two.sided", simulate=TRUE), 4) ## IGNORE_RDIFF_END # use scores mapped into integers (cf. dperm) sc <- cscores(bloodp$bp, type="NormalQuantile", int=TRUE) X <- sum(sc[bloodp$group == "group2"]) round(pperm(X, sc, 11), 4) round(pperm(X, sc, 11, alternative="two.sided"), 4)
data(bloodp) # Permutation test perm.test(bp ~ group, data=bloodp) perm.test(bp ~ group, data=bloodp, alternative="greater") perm.test(bp ~ group, data=bloodp, exact=FALSE) # Wilcoxon-Mann-Whitney test wilcox.exact(bp ~ group, data=bloodp, conf.int=TRUE, alternative="l") wilcox.exact(bp ~ group, data=bloodp, conf.int=TRUE) # compute the v.d. Waerden test sc <- cscores(bloodp$bp, type="NormalQuantile") X <- sum(sc[bloodp$group == "group2"]) round(pperm(X, sc, 11), 4) ## IGNORE_RDIFF_BEGIN round(pperm(X, sc, 11, simulate=TRUE), 4) round(pperm(X, sc, 11, alternative="two.sided"), 4) round(pperm(X, sc, 11, alternative="two.sided", simulate=TRUE), 4) ## IGNORE_RDIFF_END # use scores mapped into integers (cf. dperm) sc <- cscores(bloodp$bp, type="NormalQuantile", int=TRUE) X <- sum(sc[bloodp$group == "group2"]) round(pperm(X, sc, 11), 4) round(pperm(X, sc, 11, alternative="two.sided"), 4)
This function can be used to compute several scores for a data vector.
## Default S3 method: cscores(y, type=c("Data", "Wilcoxon", "NormalQuantile", "AnsariBradley", "Median", "Savage", "ConSal"), int=FALSE, maxs=length(y), ... ) ## S3 method for class 'factor' cscores(y, ...) ## S3 method for class 'Surv' cscores(y, type="LogRank", int=FALSE, maxs=nrow(y), ...)
## Default S3 method: cscores(y, type=c("Data", "Wilcoxon", "NormalQuantile", "AnsariBradley", "Median", "Savage", "ConSal"), int=FALSE, maxs=length(y), ... ) ## S3 method for class 'factor' cscores(y, ...) ## S3 method for class 'Surv' cscores(y, type="LogRank", int=FALSE, maxs=nrow(y), ...)
y |
a numeric, factor or logical vector or an object of class
|
type |
a character string which specifies the type of the scores to be
computed. |
int |
a logical, forcing integer valued scores. |
maxs |
an integer defining the maximal value of the scores
if |
... |
additional arguments, not passed to anything at the moment. |
This function will serve as the basis for a more general framework of rank and permutation tests in future versions of this package. Currently, it is only used in the examples.
The logrank scores are computed as given in Hothorn & Lausen (2002).
If integer valued scores are requested (int = TRUE
), the
scores
are mapped into integers by
round(scores*length(scores)/max(scores))
. See dperm
for
more details.
type
is self descriptive, except for ConSal
which implements
scores suggested by Conover & Salsburg (1988).
A vector of scores for y
with an attribute scores
indicating
the kind of scores used is returned.
Torsten Hothorn & Berthold Lausen (2003), On the exact distribution of maximally selected rank statistics. Computational Statistics & Data Analysis, 43(2), 121-137.
William J. Conover & David S. Salsburg (1988), Locally most powerful tests for detecting treatment effects when only a subset of patients can be expected to "respond" to treatment. Biometrics, 44, 189-196.
y <- rnorm(50) # v.d. Waerden scores nq <- cscores(y, type="Normal", int=TRUE) # quantile for m=20 observations in the first group qperm(0.1, nq, 20)
y <- rnorm(50) # v.d. Waerden scores nq <- cscores(y, type="Normal", int=TRUE) # quantile for m=20 observations in the first group qperm(0.1, nq, 20)
Density, distribution function and quantile function for the distribution of one and two sample permutation tests using the Shift-Algorithm by Streitberg & R\"ohmel.
dperm(x, scores, m, paired=NULL, tol = 0.01, fact=NULL, density=FALSE, simulate=FALSE, B=10000) pperm(q, scores, m, paired=NULL, tol = 0.01, fact=NULL, alternative=c("less", "greater", "two.sided"), pprob=FALSE, simulate=FALSE, B=10000) qperm(p, scores, m, paired=NULL, tol = 0.01, fact=NULL, simulate=FALSE, B=10000) rperm(n, scores, m)
dperm(x, scores, m, paired=NULL, tol = 0.01, fact=NULL, density=FALSE, simulate=FALSE, B=10000) pperm(q, scores, m, paired=NULL, tol = 0.01, fact=NULL, alternative=c("less", "greater", "two.sided"), pprob=FALSE, simulate=FALSE, B=10000) qperm(p, scores, m, paired=NULL, tol = 0.01, fact=NULL, simulate=FALSE, B=10000) rperm(n, scores, m)
x , q
|
vector of quantiles. |
p |
vector of probabilities. |
scores |
arbitrary scores of the observations
of the |
m |
sample size of the |
paired |
logical. Indicates if paired observations are used. Needed
to discriminate between a paired problem and the distribution
of the total sum of the scores (which has mass 1 at the
point |
.
tol |
real. Real valued scores are mapped into integers by rounding
after multiplication with an appropriate factor.
Make sure that the absolute difference between the
each possible test statistic for the original scores and the
rounded scores is less than |
fact |
real. If |
n |
number of random observations to generate. |
alternative |
character indicating whether the probability
|
pprob |
logical. Indicates if the probability |
density |
logical. When |
simulate |
logical. Use conditional Monte-Carlo to compute the distribution. |
B |
number of Monte-Carlo replications to be used. |
The exact distribution of the sum of the first m
scores is
evaluated using the Shift-Algorithm by Streitberg & R\"ohmel under the
hypothesis of exchangeability (or, equivalent, the hypothesis that all
permutations of the scores are equally likely). The algorithm is able
to deal with tied scores, so the conditional distribution can be
evaluated.
The algorithm is defined for positive integer valued scores only.
There are two ways dealing with real valued scores.
First, one can try to find integer valued scores that lead to statistics
which differ not more than tol
from the statistics computed for the original scores. This can be done as
follows.
Without loss of generality let denote real valued scores in
reverse ordering and
a positive factor (this is the
fact
argument).
Let . Then
Clearly, the maximum difference between and
is given by
. Therefore one searches for
with
If induces more that 100.000 columns in the Shift-Algorithm by
Streitberg & R\"ohmel,
is restricted to the largest integer
that does not.
The second idea is to map the scores into integers by taking the
integer part of (Hothorn & Lausen, 2002).
This induces additional ties, but the shape of the
scores is very similar. That means we do not try to approximate something
but use a different test (with integer valued scores), serving for the
same purpose
(due to a similar shape of the scores). However, this has to be done prior
to calling
pperm
(see the examples).
Exact two-sided p-values are computed as suggested in the StatXact-5 manual, page 225, equation (9.31) and equation (8.18), p. 179 (paired case). In detail: For the paired case the two-sided p-value is just twice the one-sided one. For the independent sample case the two sided p-value is defined as
where is the quantile passed to
pperm
.
dperm
gives the density, pperm
gives the distribution
function and qperm
gives the quantile function. If pprob
is
true, pperm
returns a list with elements
PVALUE |
the probability specified by |
PPROB |
the probability |
rperm
is a wrapper to sample
.
Bernd Streitberg & Joachim R\"ohmel (1986), Exact distributions for permutations and rank tests: An introduction to some recently published algorithms. Statistical Software Newsletter 12(1), 10–17.
Bernd Streitberg & Joachim R\"ohmel (1987), Exakte Verteilungen f\"ur Rang- und Randomisierungstests im allgemeinen $c$-Stichprobenfall. EDV in Medizin und Biologie 18(1), 12–19.
Torsten Hothorn (2001), On exact rank tests in R. R News 1(1), 11–12.
Cyrus R. Mehta & Nitin R. Patel (2001), StatXact-5 for Windows. Manual, Cytel Software Cooperation, Cambridge, USA
Torsten Hothorn & Berthold Lausen (2003), On the exact distribution of maximally selected rank statistics. Computational Statistics & Data Analysis, 43(2), 121-137.
# exact one-sided p-value of the Wilcoxon test for a tied sample x <- c(0.5, 0.5, 0.6, 0.6, 0.7, 0.8, 0.9) y <- c(0.5, 1.0, 1.2, 1.2, 1.4, 1.5, 1.9, 2.0) r <- cscores(c(x,y), type="Wilcoxon") pperm(sum(r[seq(along=x)]), r, 7) # Compare the exact algorithm as implemented in ctest and the # Shift-Algorithm by Streitberg & Roehmel for untied samples # Wilcoxon: n <- 10 x <- rnorm(n, 2) y <- rnorm(n, 3) r <- cscores(c(x,y), type="Wilcoxon") # exact distribution using the Shift-Algorithm dwexac <- dperm((n*(n+1)/2):(n^2 + n*(n+1)/2), r, n) sum(dwexac) # should be something near 1 :-) # exact distribution using dwilcox dw <- dwilcox(0:(n^2), n, n) # compare the two distributions: plot(dw, dwexac, main="Wilcoxon", xlab="dwilcox", ylab="dperm") # should give a "perfect" line # Wilcoxon signed rank test n <- 10 x <- rnorm(n, 5) y <- rnorm(n, 5) r <- cscores(abs(x - y), type="Wilcoxon") pperm(sum(r[x - y > 0]), r, length(r)) wilcox.test(x,y, paired=TRUE, alternative="less") psignrank(sum(r[x - y > 0]), length(r)) # Ansari-Bradley n <- 10 x <- rnorm(n, 2, 1) y <- rnorm(n, 2, 2) # exact distribution using the Shift-Algorithm sc <- cscores(c(x,y), type="Ansari") dabexac <- dperm(0:(n*(2*n+1)/2), sc, n) sum(dabexac) # real scores are allowed (but only result in an approximation) # e.g. v.d. Waerden test n <- 10 x <- rnorm(n) y <- rnorm(n) scores <- cscores(c(x,y), type="NormalQuantile") X <- sum(scores[seq(along=x)]) # <- v.d. Waerden normal quantile statistic # critical value, two-sided test abs(qperm(0.025, scores, length(x))) # p-values p1 <- pperm(X, scores, length(x), alternative="two.sided") # generate integer valued scores with the same shape as normal quantile # scores, this no longer v.d.Waerden, but something very similar scores <- cscores(c(x,y), type="NormalQuantile", int=TRUE) X <- sum(scores[seq(along=x)]) p2 <- pperm(X, scores, length(x), alternative="two.sided") # compare p1 and p2 p1 - p2
# exact one-sided p-value of the Wilcoxon test for a tied sample x <- c(0.5, 0.5, 0.6, 0.6, 0.7, 0.8, 0.9) y <- c(0.5, 1.0, 1.2, 1.2, 1.4, 1.5, 1.9, 2.0) r <- cscores(c(x,y), type="Wilcoxon") pperm(sum(r[seq(along=x)]), r, 7) # Compare the exact algorithm as implemented in ctest and the # Shift-Algorithm by Streitberg & Roehmel for untied samples # Wilcoxon: n <- 10 x <- rnorm(n, 2) y <- rnorm(n, 3) r <- cscores(c(x,y), type="Wilcoxon") # exact distribution using the Shift-Algorithm dwexac <- dperm((n*(n+1)/2):(n^2 + n*(n+1)/2), r, n) sum(dwexac) # should be something near 1 :-) # exact distribution using dwilcox dw <- dwilcox(0:(n^2), n, n) # compare the two distributions: plot(dw, dwexac, main="Wilcoxon", xlab="dwilcox", ylab="dperm") # should give a "perfect" line # Wilcoxon signed rank test n <- 10 x <- rnorm(n, 5) y <- rnorm(n, 5) r <- cscores(abs(x - y), type="Wilcoxon") pperm(sum(r[x - y > 0]), r, length(r)) wilcox.test(x,y, paired=TRUE, alternative="less") psignrank(sum(r[x - y > 0]), length(r)) # Ansari-Bradley n <- 10 x <- rnorm(n, 2, 1) y <- rnorm(n, 2, 2) # exact distribution using the Shift-Algorithm sc <- cscores(c(x,y), type="Ansari") dabexac <- dperm(0:(n*(2*n+1)/2), sc, n) sum(dabexac) # real scores are allowed (but only result in an approximation) # e.g. v.d. Waerden test n <- 10 x <- rnorm(n) y <- rnorm(n) scores <- cscores(c(x,y), type="NormalQuantile") X <- sum(scores[seq(along=x)]) # <- v.d. Waerden normal quantile statistic # critical value, two-sided test abs(qperm(0.025, scores, length(x))) # p-values p1 <- pperm(X, scores, length(x), alternative="two.sided") # generate integer valued scores with the same shape as normal quantile # scores, this no longer v.d.Waerden, but something very similar scores <- cscores(c(x,y), type="NormalQuantile", int=TRUE) X <- sum(scores[seq(along=x)]) p2 <- pperm(X, scores, length(x), alternative="two.sided") # compare p1 and p2 p1 - p2
Survival times of ventilating tubes of left and right ears in 78 children with otitis media.
data(ears)
data(ears)
A data frame with 78 observations on the following 5 variables.
Survival time in month of tube in left ear.
Censoring indicator for left ear: 0
censored and
1
event.
Survival time in month of tube in right ear.
Censoring indicator for right ear: 0
censored and
1
event.
a factor with levels control
and treat
.
Sin-Ho Jung and Jong-Hyeon Jeong (2003). Rank tests for clustered survival data. Lifetime Data Analysis, 9, 21-33.
V.M. Howie and R.H. Schwarz (1983). Acute otitis media: One year in general pediatric practice. American Journal of Diseases in Children, 137, 155-158.
D.W. Teele, J.O. Klein, B. Rosner et al. (1989). Epidemiology of otitis media during the first seven years of life in children in greater Boston. Journal of Infectious Diseases, 160, 89-94.
data(ears) if (require(survival, quietly=TRUE)) { ls <- cscores(Surv(ears$left, ears$lcens), int=TRUE) perm.test(ls ~ group, data=ears) }
data(ears) if (require(survival, quietly=TRUE)) { ls <- cscores(Surv(ears$left, ears$lcens), int=TRUE) perm.test(ls ~ group, data=ears) }
A non-randomized pilot study on malignant glioma patients with pretargeted adjuvant radioimmunotherapy using Yttrium-90-biotin.
data(glioma)
data(glioma)
A data frame with 37 observations on the following 7 variables.
patient number.
patients ages in years.
a factor with levels F
(emale) and M
(ale).
a factor with levels GBM
(grade IV) and
Grade3
(grade III)
survival times in month.
censoring indicator: 0
censored and 1
dead.
a factor with levels Control
and RIT
.
The primary endpoint of this small pilot study is survival. Survival times are tied, the usual asymptotic log-rank test may be inadequate in this setup. Therefore, a permutation test (via Monte-Carlo sampling) was conducted in the original paper. The data are taken from Tables 1 and 2 of Grana et al. (2002).
C. Grana, M. Chinol, C. Robertson, C. Mazzetta, M. Bartolomei, C. De Cicco, M. Fiorenza, M. Gatti, P. Caliceti & G. Paganelli (2002), Pretargeted adjuvant radioimmunotherapy with Yttrium-90-biotin in malignant glioma patients: A pilot study. British Journal of Cancer, 86(2), 207–212.
data(glioma) if(require(survival, quietly = TRUE)) { par(mfrow=c(1,2)) # Grade III glioma g3 <- glioma[glioma$Histology == "Grade3",] # Plot Kaplan-Meier curves plot(survfit(Surv(Survival, Cens) ~ Group, data=g3), main="Grade III Glioma", lty=c(2,1), legend.text=c("Control", "Treated"), legend.bty=1, ylab="Probability", xlab="Survival Time in Month") # log-rank test survdiff(Surv(Survival, Cens) ~ Group, data=g3) # permutation test with integer valued log-rank scores lsc <- cscores(Surv(g3$Survival, g3$Cens), int=TRUE) perm.test(lsc ~ Group, data=g3) # permutation test with real valued log-rank scores lsc <- cscores(Surv(g3$Survival, g3$Cens), int=FALSE) tr <- (g3$Group == "RIT") T <- sum(lsc[tr]) pperm(T, lsc, sum(tr), alternative="tw") pperm(T, lsc, sum(tr), alternative="tw", simulate=TRUE) # Grade IV glioma gbm <- glioma[glioma$Histology == "GBM",] # Plot Kaplan-Meier curves plot(survfit(Surv(Survival, Cens) ~ Group, data=gbm), main="Grade IV Glioma", lty=c(2,1), legend.text=c("Control", "Treated"), legend.bty=1, legend.pos=1, ylab="Probability", xlab="Survival Time in Month") # log-rank test survdiff(Surv(Survival, Cens) ~ Group, data=gbm) # permutation test with integer valued log-rank scores lsc <- cscores(Surv(gbm$Survival, gbm$Cens), int=TRUE) perm.test(lsc ~ Group, data=gbm) # permutation test with real valued log-rank scores lsc <- cscores(Surv(gbm$Survival, gbm$Cens), int=FALSE) tr <- (gbm$Group == "RIT") T <- sum(lsc[tr]) pperm(T, lsc, sum(tr), alternative="tw") pperm(T, lsc, sum(tr), alternative="tw", simulate=TRUE) }
data(glioma) if(require(survival, quietly = TRUE)) { par(mfrow=c(1,2)) # Grade III glioma g3 <- glioma[glioma$Histology == "Grade3",] # Plot Kaplan-Meier curves plot(survfit(Surv(Survival, Cens) ~ Group, data=g3), main="Grade III Glioma", lty=c(2,1), legend.text=c("Control", "Treated"), legend.bty=1, ylab="Probability", xlab="Survival Time in Month") # log-rank test survdiff(Surv(Survival, Cens) ~ Group, data=g3) # permutation test with integer valued log-rank scores lsc <- cscores(Surv(g3$Survival, g3$Cens), int=TRUE) perm.test(lsc ~ Group, data=g3) # permutation test with real valued log-rank scores lsc <- cscores(Surv(g3$Survival, g3$Cens), int=FALSE) tr <- (g3$Group == "RIT") T <- sum(lsc[tr]) pperm(T, lsc, sum(tr), alternative="tw") pperm(T, lsc, sum(tr), alternative="tw", simulate=TRUE) # Grade IV glioma gbm <- glioma[glioma$Histology == "GBM",] # Plot Kaplan-Meier curves plot(survfit(Surv(Survival, Cens) ~ Group, data=gbm), main="Grade IV Glioma", lty=c(2,1), legend.text=c("Control", "Treated"), legend.bty=1, legend.pos=1, ylab="Probability", xlab="Survival Time in Month") # log-rank test survdiff(Surv(Survival, Cens) ~ Group, data=gbm) # permutation test with integer valued log-rank scores lsc <- cscores(Surv(gbm$Survival, gbm$Cens), int=TRUE) perm.test(lsc ~ Group, data=gbm) # permutation test with real valued log-rank scores lsc <- cscores(Surv(gbm$Survival, gbm$Cens), int=FALSE) tr <- (gbm$Group == "RIT") T <- sum(lsc[tr]) pperm(T, lsc, sum(tr), alternative="tw") pperm(T, lsc, sum(tr), alternative="tw", simulate=TRUE) }
Globulin fraction of plasma (g/l) in two groups of 10 patients.
data(globulin)
data(globulin)
This data frame contains the following variables:
Globulin fraction of plasma
a factor with levels group1
and group2
See page 75 of Gardner & Altman (1989).
M. J. Gardner & D. G. Altman (1989), Statistics with Confidence. Published by the British Medical Journal.
Joachim R\"ohmel (1996), Precision intervals for estimates of the difference in success rates for binary random variables based on the permutation principle. Biometrical Journal, 38(8), 977–993.
data(globulin) perm.test(gfrac ~ group, data=globulin, conf.int=TRUE)
data(globulin) perm.test(gfrac ~ group, data=globulin, conf.int=TRUE)
Compute the number of elements less or equal the elements in a given vector.
irank(x, ox = NULL)
irank(x, ox = NULL)
x |
a numeric vector. |
ox |
|
A vector of integers.
x <- rnorm(10) irank(x) rank(x) x <- c(1,2,3,3,0) irank(x) rank(x)
x <- rnorm(10) irank(x) rank(x) x <- c(1,2,3,3,0) irank(x) rank(x)
Survival times for patients suffering lung cancer for a treatment and control group.
data(lungcancer)
data(lungcancer)
A data frame with 14 observations on the following 3 variables.
survival time in days.
censoring indicator: 0 censored, 1 event.
a factor with levels control
and newdrug
.
The data is given in Table 9.19, page 293, of Metha and Pathel (2001). The two-sided p-value for the log-rank test is 0.001 (page 295).
Cyrus R. Mehta & Nitin R. Patel (2001), StatXact-5 for Windows. Manual, Cytel Software Cooperation, Cambridge, USA
data(lungcancer) attach(lungcancer) # round logrank scores scores <- cscores.Surv(cbind(time, cens)) T <- sum(scores[group=="newdrug"]) mobs <- sum(group=="newdrug") (prob <- pperm(T, scores, m=mobs, al="le")) pperm(T, scores, m=mobs, al="tw") pperm(T, scores, m=mobs, al="tw", simulate=TRUE) # map into integers, faster scores <- cscores.Surv(cbind(time, cens), int=TRUE) T <- sum(scores[group=="newdrug"]) mobs <- sum(group=="newdrug") (prob <- pperm(T, scores, m=mobs, al="le")) pperm(T, scores, m=mobs, al="tw") pperm(T, scores, m=mobs, al="tw", simulate=TRUE) detach(lungcancer)
data(lungcancer) attach(lungcancer) # round logrank scores scores <- cscores.Surv(cbind(time, cens)) T <- sum(scores[group=="newdrug"]) mobs <- sum(group=="newdrug") (prob <- pperm(T, scores, m=mobs, al="le")) pperm(T, scores, m=mobs, al="tw") pperm(T, scores, m=mobs, al="tw", simulate=TRUE) # map into integers, faster scores <- cscores.Surv(cbind(time, cens), int=TRUE) T <- sum(scores[group=="newdrug"]) mobs <- sum(group=="newdrug") (prob <- pperm(T, scores, m=mobs, al="le")) pperm(T, scores, m=mobs, al="tw") pperm(T, scores, m=mobs, al="tw", simulate=TRUE) detach(lungcancer)
The logarithm of the ratio of pain scores at baseline and after four weeks for a control and treatment group.
data(neuropathy)
data(neuropathy)
A data frame with 58 observations on the following 2 variables.
Pain scores: ln(baseline/final).
a factor with levels control
and treat
.
Data from Table 1 of Conover & Salsburg (1988).
William J. Conover and David S. Salsburg (1988), Locally most powerful tests for detecting treatment effects when only a subset of patients can be expected to "respond" to treatment. Biometrics, 44, 189–196.
data(neuropathy) # compare with Table 2 of Conover & Salsburg (1988) wilcox.exact(pain ~ group, data=neuropathy, alternative="less") css <- cscores(neuropathy$pain, type="ConSal") pperm(sum(css[neuropathy$group=="control"]),css, m=sum(neuropathy$group=="control"))
data(neuropathy) # compare with Table 2 of Conover & Salsburg (1988) wilcox.exact(pain ~ group, data=neuropathy, alternative="less") css <- cscores(neuropathy$pain, type="ConSal") pperm(sum(css[neuropathy$group=="control"]),css, m=sum(neuropathy$group=="control"))
Survival times of 35 women suffering ovarian carcinoma at stadium II and IIA.
data(ocarcinoma)
data(ocarcinoma)
A data frame with 35 observations on the following 3 variables.
time in days.
censoring indicator: 0 censored, 1 event.
a factor with levels II
and IIA
.
Data from Fleming et al. (1980, 1984), reanalysed in Schumacher and Schulgen (2002).
Thomas R. Fleming, Judith R. O'Fallon, Peter C. O'Brien & David P. Harrington (1980), Modified Kolmogorov-Smirnov test procedures with applications to arbitrarily censored data. Biometrics, 36, 607–625.
Thomas R. Fleming, Stephanie J. Green & David P. Harrington (1984), Considerations of monitoring and evaluating treatment effects in clinical trials. Controlled Clinical Trials, 5, 55–66.
Martin Schumacher & Gabi Schulgen (2002), Methodik klinischer Studien: methodische Grundlagen der Planung, Durchf\"uhrung und Auswertung. Springer, Heidelberg.
data(ocarcinoma) attach(ocarcinoma) # compute integer valued logrank scores logrsc <- cscores.Surv(cbind(time, cens), int=TRUE) # the test statistic lgT <- sum(logrsc[stadium == "II"]) # p-value round(pperm(lgT, logrsc, m=sum(stadium=="II"), al="tw"), 4) # compute logrank scores and simulate p-value logrsc <- cscores.Surv(cbind(time, cens), int=FALSE) # the test statistic lgT <- sum(logrsc[stadium == "II"]) # p-value round(pperm(lgT, logrsc, m=sum(stadium=="II"), al="tw", simulate=TRUE), 4)
data(ocarcinoma) attach(ocarcinoma) # compute integer valued logrank scores logrsc <- cscores.Surv(cbind(time, cens), int=TRUE) # the test statistic lgT <- sum(logrsc[stadium == "II"]) # p-value round(pperm(lgT, logrsc, m=sum(stadium=="II"), al="tw"), 4) # compute logrank scores and simulate p-value logrsc <- cscores.Surv(cbind(time, cens), int=FALSE) # the test statistic lgT <- sum(logrsc[stadium == "II"]) # p-value round(pperm(lgT, logrsc, m=sum(stadium=="II"), al="tw", simulate=TRUE), 4)
Performs the permutation test for the one and two sample problem.
## Default S3 method: perm.test(x, y, paired=FALSE, alternative=c("two.sided", "less", "greater"), mu=0, exact=NULL, conf.int=FALSE, conf.level=0.95, tol=NULL, ...) ## S3 method for class 'formula' perm.test(formula, data, subset, na.action, ...)
## Default S3 method: perm.test(x, y, paired=FALSE, alternative=c("two.sided", "less", "greater"), mu=0, exact=NULL, conf.int=FALSE, conf.level=0.95, tol=NULL, ...) ## S3 method for class 'formula' perm.test(formula, data, subset, na.action, ...)
x |
numeric vector of integer data values. |
y |
numeric vector of integer data values. |
paired |
a logical indicating whether you want a paired test. |
alternative |
the alternative hypothesis must be
one of |
mu |
a number specifying an optional location parameter. |
exact |
a logical indicating whether an exact p-value should be computed. |
conf.int |
a logical indicating whether a confidence interval should be computed. |
conf.level |
confidence level of the interval. |
tol |
real. real valued scores are mapped into integers by
multiplication. Make sure that the absolute difference between
the "true" quantile and the approximated quantile is less
than |
formula |
a formula of the form |
data |
an optional data frame containing the variables in the model formula. |
subset |
an optional vector specifying a subset of observations to be used. |
na.action |
a function which indicates what should happen when
the data contain |
... |
further arguments to be passed to or from methods. |
The permutation test is performed for integer valued observations or
scores. If real values x
or y
are passed to this function
the following applies: if exact
is true (i.e. the sample size is
less than 50 observations) and tol
is not given, the scores are
mapped into , see
pperm
for the details.
Otherwise the p-values are computed using tol
. If the sample size
exceeds $50$ observations, the usual normal approximation is used.
P-values are computed according to the StatXact-manual, see
pperm
.
For (in principle) continuous variables the confidence sets represent the "largest shift in location being consistent with the observations". For discrete variables with only a few categories they are hard to interpret. In the case of binary data (e.g. success / failure) the confidence sets can be interpreted as the differences of two success-rates covered by the data. For a detailed description see R\"ohmel (1996).
Confidence intervals are only available for independent samples. When the
sample sizes are unbalanced, length(x)
needs to be smaller than
length(y)
.
A list with class "htest"
containing the following components:
statistic |
the value of the test statistic with a name describing it. |
p.value |
the p-value for the test. |
pointprob |
this gives the probability of observing the test statistic itself. |
null.value |
the location parameter |
alternative |
a character string describing the alternative hypothesis. |
method |
the type of test applied. |
data.name |
a character string giving the names of the data. |
conf.int |
a confidence interval for the location parameter.
(Only present if argument |
Confidence intervals may need some cpu-time ...
Joachim R\"ohmel (1996), Precision intervals for estimates of the difference in success rates for binary random variables based on the permutation principle. Biometrical Journal, 38(8), 977–993.
Cyrus R. Mehta & Nitin R. Patel (2001), StatXact-5 for Windows. Manual, Cytel Software Cooperation, Cambridge, USA
# Example from Gardner & Altman (1989), p. 30 # two treatments A and B, 1 means improvement, 0 means no improvement # confidence sets cf. R\"ohmel (1996) A <- c(rep(1, 61), rep(0, 19)) B <- c(rep(1, 45), rep(0, 35)) perm.test(A, B, conf.int=TRUE, exact=TRUE) # one-sample AIDS data (differences only), Methta and Patel (2001), # Table 8.1 page 181 data(sal) attach(sal) ppdiff <- pre - post detach(sal) # p-values in StatXact == 0.0011 one-sided, 0.0021 two.sided, page 183 perm.test(ppdiff) perm.test(ppdiff, alternative="less") perm.test(ppdiff, exact=FALSE)
# Example from Gardner & Altman (1989), p. 30 # two treatments A and B, 1 means improvement, 0 means no improvement # confidence sets cf. R\"ohmel (1996) A <- c(rep(1, 61), rep(0, 19)) B <- c(rep(1, 45), rep(0, 35)) perm.test(A, B, conf.int=TRUE, exact=TRUE) # one-sample AIDS data (differences only), Methta and Patel (2001), # Table 8.1 page 181 data(sal) attach(sal) ppdiff <- pre - post detach(sal) # p-values in StatXact == 0.0011 one-sided, 0.0021 two.sided, page 183 perm.test(ppdiff) perm.test(ppdiff, alternative="less") perm.test(ppdiff, exact=FALSE)
The endurance time of 24 rats in two groups in a rotating cylinder.
data(rotarod)
data(rotarod)
A data frame with 24 observations on the following 2 variables.
the endurance time
a factor with levels control
and treatment
.
The 24 rats received a fixed oral dose of a centrally acting muscle relaxant (treatment) or a saline solvent (control). They were placed on a rotating cylinder and the length of time each rat remains on the cylinder is measured, up to a maximum of 300 seconds. The rats were randomly assigned to the control and treatment group.
Note that the empirical variance in the control group is 0 and that the group medians are identical.
This dataset serves as the basis of an comparision of the results of the Wilcoxon-Mann-Whitney test computed by 11 statistical packages in Bergmann et al. (2000). The exact conditional p-value is $0.0373$ (two-sided) and $0.0186$ (one-sided). The asymptotic two-sided p-value (corrected for ties) is reported as $0.0147$.
Reinhard Bergmann, John Ludbrook & Will P.J.M. Spooren (2000), Different outcomes of the Wilcoxon-Mann-Whitney test from different statistics packages. The American Statistician, 54(1), 72–77.
data(rotarod) wilcox.exact(time ~ group, data=rotarod, alternative="g") wilcox.exact(time ~ group, data=rotarod, conf.int=TRUE) wilcox.exact(time ~ group, data=rotarod, exact=FALSE) # the permutation test perm.test(time ~ group, data=rotarod) perm.test(time ~ group, data=rotarod, exact=FALSE)
data(rotarod) wilcox.exact(time ~ group, data=rotarod, alternative="g") wilcox.exact(time ~ group, data=rotarod, conf.int=TRUE) wilcox.exact(time ~ group, data=rotarod, exact=FALSE) # the permutation test perm.test(time ~ group, data=rotarod) perm.test(time ~ group, data=rotarod, exact=FALSE)
The response of serum antigen level to AZT in 20 patients suffering AIDS.
data(sal)
data(sal)
A data frame with 20 observations on the following 2 variables.
level pre treatment.
level post treatment.
The data is given in Metha and Patel (2001), Table 8.1, page 181. Two-sided p-value for the Wilcoxon-Signed Rank Test: 0.0021 (page 183) or 0.0038 (asymptotically).
Cyrus R. Mehta & Nitin R. Patel (2001), StatXact-5 for Windows. Manual, Cytel Software Cooperation, Cambridge, USA
data(sal) attach(sal) wilcox.exact(pre, post, paired=TRUE, conf.int=TRUE) wilcox.exact(pre,post, paired=TRUE, conf.int=TRUE, exact=FALSE) detach(sal)
data(sal) attach(sal) wilcox.exact(pre, post, paired=TRUE, conf.int=TRUE) wilcox.exact(pre,post, paired=TRUE, conf.int=TRUE, exact=FALSE) detach(sal)
Performs one and two sample Wilcoxon tests on vectors of data for possibly tied observations.
## Default S3 method: wilcox.exact(x, y = NULL, alternative = c("two.sided", "less", "greater"), mu = 0, paired = FALSE, exact = NULL, conf.int = FALSE, conf.level = 0.95, ...) ## S3 method for class 'formula' wilcox.exact(formula, data, subset, na.action, ...)
## Default S3 method: wilcox.exact(x, y = NULL, alternative = c("two.sided", "less", "greater"), mu = 0, paired = FALSE, exact = NULL, conf.int = FALSE, conf.level = 0.95, ...) ## S3 method for class 'formula' wilcox.exact(formula, data, subset, na.action, ...)
x |
numeric vector of data values. |
y |
an optional numeric vector of data values. |
alternative |
the alternative hypothesis must be
one of |
mu |
a number specifying an optional location parameter. |
paired |
a logical indicating whether you want a paired test. |
exact |
a logical indicating whether an exact p-value should be computed. |
conf.int |
a logical indicating whether a confidence interval should be computed. |
conf.level |
confidence level of the interval. |
formula |
a formula of the form |
data |
an optional data frame containing the variables in the model formula. |
subset |
an optional vector specifying a subset of observations to be used. |
na.action |
a function which indicates what should happen when
the data contain |
... |
further arguments to be passed to or from methods. |
This version computes exact conditional (on the data) p-values and quantiles using the Shift-Algorithm by Streitberg & R\"ohmel for both tied and untied samples.
If only x
is given, or if both x
and y
are given
and paired
is TRUE
, a Wilcoxon signed rank test of the
null that the median of x
(in the one sample case) or of
x-y
(in the paired two sample case) equals mu
is
performed.
Otherwise, if both x
and y
are given and paired
is FALSE
, a Wilcoxon rank sum test (equivalent to the
Mann-Whitney test) is carried out. In this case, the null hypothesis
is that the location of the distributions of x
and y
differ by mu
.
By default (if exact
is not specified), an exact p-value is
computed if the samples contain less than 50 finite values and there
are no ties. Otherwise, a normal approximation is used.
Optionally (if argument conf.int
is true), a nonparametric
confidence interval for the median (one-sample case) or for the
difference of the location parameters x-y
is computed. If
exact p-values are available, an exact confidence interval is obtained
by the algorithm described in Bauer (1972). Otherwise, an asymptotic
confidence interval is returned.
A list with class "htest"
containing the following components:
statistic |
the value of the test statistic with a name describing it. |
p.value |
the p-value for the test. |
pointprob |
this gives the probability of observing the test
statistic itself (called |
null.value |
the location parameter |
alternative |
a character string describing the alternative hypothesis. |
method |
the type of test applied. |
data.name |
a character string giving the names of the data. |
conf.int |
a confidence interval for the location parameter.
(Only present if argument |
estimate |
Hodges-Lehmann estimate of the location parameter.
(Only present if argument |
Myles Hollander & Douglas A. Wolfe (1973), Nonparametric statistical inference. New York: John Wiley & Sons. Pages 27–33 (one-sample), 68–75 (two-sample).
David F. Bauer (1972), Constructing confidence sets using rank statistics. Journal of the American Statistical Association 67, 687–690.
Cyrus R. Mehta & Nitin R. Patel (2001), StatXact-5 for Windows. Manual, Cytel Software Cooperation, Cambridge, USA
perm.test
for the one and two sample permutation test.
## One-sample test. ## Hollander & Wolfe (1973), 29f. ## Hamilton depression scale factor measurements in 9 patients with ## mixed anxiety and depression, taken at the first (x) and second ## (y) visit after initiation of a therapy (administration of a ## tranquilizer). x <- c(1.83, 0.50, 1.62, 2.48, 1.68, 1.88, 1.55, 3.06, 1.30) y <- c(0.878, 0.647, 0.598, 2.05, 1.06, 1.29, 1.06, 3.14, 1.29) wilcox.exact(x, y, paired = TRUE, alternative = "greater") wilcox.exact(y - x, alternative = "less") # The same. ## Two-sample test. ## Hollander & Wolfe (1973), 69f. ## Permeability constants of the human chorioamnion (a placental ## membrane) at term (x) and between 12 to 26 weeks gestational ## age (y). The alternative of interest is greater permeability ## of the human chorioamnion for the term pregnancy. x <- c(0.80, 0.83, 1.89, 1.04, 1.45, 1.38, 1.91, 1.64, 0.73, 1.46) y <- c(1.15, 0.88, 0.90, 0.74, 1.21) wilcox.exact(x, y, alternative = "g") # greater ## Formula interface. data(airquality) boxplot(Ozone ~ Month, data = airquality) wilcox.exact(Ozone ~ Month, data = airquality, subset = Month %in% c(5, 8)) # Hollander & Wolfe, p. 39, results p. 40 and p. 53 x <- c(1.83, 0.50, 1.62, 2.48, 1.68, 1.88, 1.55, 3.06, 1.30) y <- c(0.878, 0.647, 0.598, 2.05, 1.06, 1.29, 1.06, 3.14, 1.29) wilcox.exact(y,x, paired=TRUE, conf.int=TRUE) # Hollander & Wolfe, p. 110, results p. 111 and p. 126 x <- c(0.8, 0.83, 1.89, 1.04, 1.45, 1.38, 1.91, 1.64, 0.73, 1.46) y <- c(1.15, 0.88, 0.90, 0.74, 1.21) wilcox.exact(y,x, conf.int=TRUE)
## One-sample test. ## Hollander & Wolfe (1973), 29f. ## Hamilton depression scale factor measurements in 9 patients with ## mixed anxiety and depression, taken at the first (x) and second ## (y) visit after initiation of a therapy (administration of a ## tranquilizer). x <- c(1.83, 0.50, 1.62, 2.48, 1.68, 1.88, 1.55, 3.06, 1.30) y <- c(0.878, 0.647, 0.598, 2.05, 1.06, 1.29, 1.06, 3.14, 1.29) wilcox.exact(x, y, paired = TRUE, alternative = "greater") wilcox.exact(y - x, alternative = "less") # The same. ## Two-sample test. ## Hollander & Wolfe (1973), 69f. ## Permeability constants of the human chorioamnion (a placental ## membrane) at term (x) and between 12 to 26 weeks gestational ## age (y). The alternative of interest is greater permeability ## of the human chorioamnion for the term pregnancy. x <- c(0.80, 0.83, 1.89, 1.04, 1.45, 1.38, 1.91, 1.64, 0.73, 1.46) y <- c(1.15, 0.88, 0.90, 0.74, 1.21) wilcox.exact(x, y, alternative = "g") # greater ## Formula interface. data(airquality) boxplot(Ozone ~ Month, data = airquality) wilcox.exact(Ozone ~ Month, data = airquality, subset = Month %in% c(5, 8)) # Hollander & Wolfe, p. 39, results p. 40 and p. 53 x <- c(1.83, 0.50, 1.62, 2.48, 1.68, 1.88, 1.55, 3.06, 1.30) y <- c(0.878, 0.647, 0.598, 2.05, 1.06, 1.29, 1.06, 3.14, 1.29) wilcox.exact(y,x, paired=TRUE, conf.int=TRUE) # Hollander & Wolfe, p. 110, results p. 111 and p. 126 x <- c(0.8, 0.83, 1.89, 1.04, 1.45, 1.38, 1.91, 1.64, 0.73, 1.46) y <- c(1.15, 0.88, 0.90, 0.74, 1.21) wilcox.exact(y,x, conf.int=TRUE)