| Statistics Toolbox |    | 
Two-way Analysis of Variance (ANOVA)
Syntax
p = anova2(X,reps) 
p = anova2(X,reps,'displayopt') 
[p,table] = anova2(...)
[p,table,stats] = anova2(...)
Description
anova2(X,reps) performs a balanced two-way ANOVA for comparing the means of two or more columns and two or more rows of the observations in X. The data in different columns represent changes in factor A. The data in different rows represent changes in factor B. If there is more than one observation for each combination of factors, input reps indicates the number of replicates in each "cell," which much be constant. (For unbalanced designs, use anovan.)
The matrix below shows the format for a set-up where column factor A has two levels, row factor B has three levels, and there are two replications (reps=2). The subscripts indicate row, column, and replicate, respectively.
 
When reps is 1 (default), anova2 returns two p-values in vector p:
X) are drawn from the same population
X) are drawn from the same population 
When reps is greater than 1, anova2 returns a third p-value in vector p:
If any p-value is near zero, this casts doubt on the associated null hypothesis. A sufficiently small p-value for H0A suggests that at least one column-sample mean is significantly different that the other column-sample means; i.e., there is a main effect due to factor A. A sufficiently small p-value for H0B suggests that at least one row-sample mean is significantly different than the other row-sample means; i.e., there is a main effect due to factor B. A sufficiently small p-value for H0AB suggests that there is an interaction between factors A and B. The choice of a limit for the p-value to determine whether a result is "statistically significant" is left to the researcher. It is common to declare a result significant if the p-value is less than 0.05 or 0.01.
anova2 also displays a figure showing the standard ANOVA table, which divides the variability of the data in X into three or four parts depending on the value of reps:
The ANOVA table has five columns:
p = anova2(X,reps,' enables the ANOVA table display when 'displayopt')
displayopt' is 'on' (default) and suppresses the display when 'displayopt' is 'off'.
[p,table] = anova2(...)
 returns the ANOVA table (including column and row labels) in cell array table. (Copy a text version of the ANOVA table to the clipboard by using the Copy Text item on the Edit menu.)
[p,table,stats] = anova2(...)
 returns a stats structure that you can use to perform a follow-up multiple comparison test. 
The anova2 test evaluates the hypothesis that the row, column, and interaction effects are all the same, against the alternative that they are not all the same. Sometimes it is preferable to perform a test to determine which pairs of effects are significantly different, and which are not. Use the multcompare function to perform such tests by supplying the stats structure as input.
Examples
The data below come from a study of popcorn brands and popper type (Hogg 1987). The columns of the matrix popcorn are brands (Gourmet, National, and Generic). The rows are popper type (Oil and Air.) The study popped a batch of each brand three times with each popper. The values are the yield in cups of popped popcorn. 
load popcorn popcorn popcorn = 5.5000 4.5000 3.5000 5.5000 4.5000 4.0000 6.0000 4.0000 3.0000 6.5000 5.0000 4.0000 7.0000 5.5000 5.0000 7.0000 5.0000 4.5000 p = anova2(popcorn,3) p = 0.0000 0.0001 0.7462
The vector p shows the p-values for the three brands of popcorn, 0.0000, the two popper types, 0.0001, and the interaction between brand and popper type, 0.7462. These values indicate that both popcorn brand and popper type affect the yield of popcorn, but there is no evidence of a synergistic (interaction) effect of the two.
The conclusion is that you can get the greatest yield using the Gourmet brand and an Air popper (the three values popcorn(4:6,1)).
Reference
[1] Hogg, R. V. and J. Ledolter. Engineering Statistics. MacMillan Publishing Company, 1987.
|   | anova1 | anovan |  |