Dunnett's test is a post-hoc test used after a significant ANOVA to compare multiple treatment groups against a single control group. It is specifically designed for experimental research when you need to determine if any treatment groups differ significantly from a control group, while controlling the familywise error rate. This calculator performs Dunnett's test on your data, providing p-values for each comparison and indicating which differences are statistically significant based on your chosen significance level (alpha). Click here to populate the sample data for a quick example.
Calculator
1. Load Your Data
2. Select Columns & Options
Learn More
Dunnett's Test
Definition
Dunnett's Test is a multiple comparison procedure used to compare several treatments against a single control group. It maintains the family-wise error rate while providing more statistical power than methods that compare all pairs.
Formula
Test Statistic:
Where:
- = mean of treatment group
- = mean of the control group
- = sample size of treatment group
- = sample size of the control group
- = standard error of the mean
The standard error of the mean is calculated as:
Where is the pooled variance, combining the variances of all groups:
In ANOVA, the pooled variance corresponds to the within-group variance:
Key Assumptions
Practical Example
Step 1: State the Data
Group | Data | N | Mean | SD |
---|---|---|---|---|
Control | 8.5, 7.8, 8, 8.2, 7.9 | 5 | 8.08 | 0.27 |
Treatment A | 9.1, 9.3, 8.9, 9, 9.2 | 5 | 9.10 | 0.16 |
Treatment B | 7.2, 7.5, 7, 7.4, 7.3 | 5 | 7.28 | 0.19 |
Treatment C | 10.1, 10.3, 10, 10.2, 9.9 | 5 | 10.10 | 0.16 |
Step 2: State Hypotheses
For each treatment group i vs control:
Step 3: Calculate SS and MSE
- with
- with
Step 4: Calculate Test Statistics
For each treatment vs control:
- Treatment A:
- Treatment B:
- Treatment C:
Step 5: Compare with Critical Value
Critical value for , treatments, :
Compare with critical value:
- Treatment A: (Significant)
- Treatment B: (Significant)
- Treatment C: (Significant)
Step 6: Draw Conclusions
All treatments show significant differences from the control group ():
- Treatment A significantly increases response
- Treatment B significantly decreases response
- Treatment C shows largest significant increase
Code Examples
library(multcomp)
library(tidyverse)
# Data preparation
df = tibble(
Group = rep(c("Control", "Treatment A", "Treatment B", "Treatment C"), each = 5),
Response = c(8.5, 7.8, 8, 8.2, 7.9,
9.1, 9.3, 8.9, 9, 9.2,
7.2, 7.5, 7, 7.4, 7.3,
10.1, 10.3, 10, 10.2, 9.9)
)
# multcom package requires the Group variable to be a factor
df$Group <- as.factor(df$Group)
# Perform one-way ANOVA
model <- aov(Response ~ Group, data = df)
# Perform Dunnett's test
dunnett_test <- glht(model, linfct = mcp(Group = "Dunnett"))
summary(dunnett_test)
import numpy as np
from statsmodels.stats.multicomp import pairwise_tukeyhsd
import pandas as pd
# Create example data
data = pd.DataFrame({
'Response': [8.5, 7.8, 8.0, 8.2, 7.9, # Control
9.1, 9.3, 8.9, 9.0, 9.2, # Treatment A
7.2, 7.5, 7.0, 7.4, 7.3, # Treatment B
10.1, 10.3, 10.0, 10.2, 9.9], # Treatment C
'Group': np.repeat(['Control', 'Treatment A',
'Treatment B', 'Treatment C'], 5)
})
# Perform multiple pairwise comparisons using Tukey's test
# (Note: Dunnett's test focuses only on comparisons against a control group,
# but statsmodels does not provide a direct implementation of Dunnett's test.)
results = pairwise_tukeyhsd(data['Response'],
data['Group'])
print(results)
Alternative Tests
- Tukey's HSD: When comparing all groups to each other
- Bonferroni: When a simpler but more conservative approach is needed
- Games-Howell: When variances are unequal