Skip to contents

Cushny and Peebles (1905) studied the effects of hydrobromides related to scopolamine and atropine in producing sleep. The sleep of mental patients was measured without hypnotic (Control) and after treatment with one of three drugs: L. hyoscyamine hydrobromide (L_hyoscyamine), L. hyoscine hydrobromide (L_hyoscyine), and a mixture (racemic) form, DL_hyoscine, called atropine. The L (levo) and D (detro) form of a given molecule are optical isomers (mirror images).

The drugs were given on alternate evenings, and the hours of sleep were compared with the intervening control night. Each of the drugs was tested in this manner a varying number of times in each subject. The average number of hours of sleep for each treatment is the response.

Student (1908) used these data to illustrate the paired-sample t-test in small samples, testing the hypothesis that the mean difference between a given drug and the control condition was zero. This data set became well known when used by Fisher (1925). Both Student and Fisher had problems labeling the drugs correctly (see Senn & Richardson (1994)), and consequently came to wrong conclusions.

But as well, the sample sizes (number of nights) for each mean differed widely, ranging from 3-9, and this was not taken into account in their analyses. To allow weighted analyses, the number of observations for each mean is contained in the data frame CushnyPeeblesN.

Usage

data(CushnyPeebles)
data(CushnyPeeblesN)

Format

CushnyPeebles: A data frame with 11 observations on the following 4 variables.

Control

a numeric vector: mean hours of sleep

L_hyoscyamine

a numeric vector: mean hours of sleep

L_hyoscine

a numeric vector: mean hours of sleep

D_hyoscine

a numeric vector: mean hours of sleep

CushnyPeeblesN: A data frame with 11 observations on the following 4 variables.

Control

a numeric vector: number of observations

L_hyoscyamine

a numeric vector: number of observations

L_hyoscine

a numeric vector: number of observations

DL_hyoscine

a numeric vector: number of observations

Details

The last patient (11) has no Control observations, and so is often excluded in analyses or other versions of this data set.

Source

Cushny, A. R., and Peebles, A. R. (1905), "The Action of Optical Isomers. II: Hyoscines," Journal of Physiology, 32, 501-510.

References

Fisher, R. A. (1925), Statistical Methods for Research Workers, Edinburgh and London: Oliver & Boyd.

Student (1908), "The Probable Error of a Mean," Biometrika, 6, 1-25.

Senn, S.J. and Richardson, W. (1994), "The first t-test", Statistics in Medicine, 13, 785-803.

See also

sleep for an alternative form of this data set.

Examples

data(CushnyPeebles)
# quick looks at the data
plot(CushnyPeebles)

boxplot(CushnyPeebles, ylab="Hours of Sleep", xlab="Treatment")


##########################
# Repeated measures MANOVA

CPmod <- lm(cbind(Control, L_hyoscyamine, L_hyoscine, DL_hyoscine) ~ 1, data=CushnyPeebles)

# Assign within-S factor and contrasts
Treatment <- factor(colnames(CushnyPeebles), levels=colnames(CushnyPeebles))
contrasts(Treatment) <- matrix(
  c(-3, 1, 1, 1,
     0,-2, 1, 1,
     0, 0,-1, 1), ncol=3)
colnames(contrasts(Treatment)) <- c("Control.Drug", "L.DL", "L_hy.DL_hy")

Treats <- data.frame(Treatment)
if (require(car)) {
(CPaov <- Anova(CPmod, idata=Treats, idesign= ~Treatment))
}
#> Note: model has only an intercept; equivalent type-III tests substituted.
#> 
#> Type III Repeated Measures MANOVA Tests: Pillai test statistic
#>             Df test stat approx F num Df den Df    Pr(>F)    
#> (Intercept)  1   0.90437   85.113      1      9 6.969e-06 ***
#> Treatment    1   0.70354    5.537      3      7   0.02896 *  
#> ---
#> Signif. codes:  0 '***' 0.001 '**' 0.01 '*' 0.05 '.' 0.1 ' ' 1
summary(CPaov, univariate=FALSE)
#> 
#> Type III Repeated Measures MANOVA Tests:
#> 
#> ------------------------------------------
#>  
#> Term: (Intercept) 
#> 
#>  Response transformation matrix:
#>               (Intercept)
#> Control                 1
#> L_hyoscyamine           1
#> L_hyoscine              1
#> DL_hyoscine             1
#> 
#> Sum of squares and products for the hypothesis:
#>             (Intercept)
#> (Intercept)      3385.6
#> 
#> Multivariate Tests: (Intercept)
#>                  Df test stat approx F num Df den Df     Pr(>F)    
#> Pillai            1  0.904370 85.11285      1      9 6.9692e-06 ***
#> Wilks             1  0.095630 85.11285      1      9 6.9692e-06 ***
#> Hotelling-Lawley  1  9.456983 85.11285      1      9 6.9692e-06 ***
#> Roy               1  9.456983 85.11285      1      9 6.9692e-06 ***
#> ---
#> Signif. codes:  0 '***' 0.001 '**' 0.01 '*' 0.05 '.' 0.1 ' ' 1
#> 
#> ------------------------------------------
#>  
#> Term: Treatment 
#> 
#>  Response transformation matrix:
#>               TreatmentControl.Drug TreatmentL.DL TreatmentL_hy.DL_hy
#> Control                          -3             0                   0
#> L_hyoscyamine                     1            -2                   0
#> L_hyoscine                        1             1                  -1
#> DL_hyoscine                       1             1                   1
#> 
#> Sum of squares and products for the hypothesis:
#>                       TreatmentControl.Drug TreatmentL.DL TreatmentL_hy.DL_hy
#> TreatmentControl.Drug                291.60       170.100              -0.540
#> TreatmentL.DL                        170.10        99.225              -0.315
#> TreatmentL_hy.DL_hy                   -0.54        -0.315               0.001
#> 
#> Multivariate Tests: Treatment
#>                  Df test stat approx F num Df den Df   Pr(>F)  
#> Pillai            1 0.7035419  5.53737      3      7 0.028955 *
#> Wilks             1 0.2964581  5.53737      3      7 0.028955 *
#> Hotelling-Lawley  1 2.3731584  5.53737      3      7 0.028955 *
#> Roy               1 2.3731584  5.53737      3      7 0.028955 *
#> ---
#> Signif. codes:  0 '***' 0.001 '**' 0.01 '*' 0.05 '.' 0.1 ' ' 1

if (require(heplots)) {
  heplot(CPmod, idata=Treats, idesign= ~Treatment, iterm="Treatment", 
  xlab="Control vs Drugs", ylab="L vs DL drug")
  pairs(CPmod, idata=Treats, idesign= ~Treatment, iterm="Treatment")
}
#> Loading required package: heplots
#> Loading required package: broom
#> Note: model has only an intercept; equivalent type-III tests substituted.
#> Note: model has only an intercept; equivalent type-III tests substituted.



################################
# reshape to long format, add Ns

CPlong <- stack(CushnyPeebles)[,2:1]
colnames(CPlong) <- c("treatment", "sleep")
CPN <- stack(CushnyPeeblesN)
CPlong <- data.frame(patient=rep(1:11,4), CPlong, n=CPN$values)
str(CPlong)
#> 'data.frame':	44 obs. of  4 variables:
#>  $ patient  : int  1 2 3 4 5 6 7 8 9 10 ...
#>  $ treatment: Factor w/ 4 levels "Control","L_hyoscyamine",..: 1 1 1 1 1 1 1 1 1 1 ...
#>  $ sleep    : num  0.6 3 4.7 5.5 6.2 3.2 2.5 2.8 1.1 2.9 ...
#>  $ n        : int  9 9 8 9 9 8 8 7 8 9 ...