Chapter 10 Lab 10: Factorial ANOVA
Simplicity is complex. It’s never simple to keep things simple. Simple solutions require the most advanced thinking. —Richie Norton
10.1 Does standing up make you focus more?
This lab activity uses the data from “Stand by your Stroop: Standing up enhances selective attention and cognitive control” (Rosenbaum, Mama, Algom, 2017) to teach the analysis of a 2x2 design using ANOVA. Although the research design is a 2x2 repeated meaures design, we treat the design both as repeated measures, and as a between-subjects design to illustrate how to conduct either type of ANOVA in software.
10.1.1 STUDY DESCRIPTION
Do you pay more attention when you are sitting or standing? We analyse the data from “Stand by your Stroop: Standing up enhances selective attention and cognitive control” (Rosenbaum, Mama, Algom, 2017). This paper asked whether sitting versus standing would influence a measure of selective attention, the ability to ignore distracting information.
They used a classic test of selective attention, called the Stroop effect. In a typical Stroop experiment, subjects name the color of words as fast as they can. The trick is that sometimes the color of the word is the same as the name of the word, and sometimes it is not. Here are some examples:
Congruent trials occur when the color and word match. So, the correct answers for each of the congruent stimuli shown would be to say, red, green, blue and yello. Incongruent trials occur when the color and word mismatch. The correct answers for each of the incongruent stimuli would be: blue, yellow, red, green.
The Stroop effect is an example of a well-known phenomena. What happens is that people are faster to name the color of the congruent items compared to the color of the incongruent items. This difference (incongruent reaction time - congruent reaction time) is called the Stroop effect.
Many researchers argue that the Stroop effect measures something about selective attention, the ability to ignore distracting information. In this case, the target information that you need to pay attention to is the color, not the word. For each item, the word is potentially distracting, it is not information that you are supposed to respond to. However, it seems that most people can’t help but notice the word, and their performance in the color-naming task is subsequently influenced by the presence of the distracting word.
People who are good at ignoring the distracting words should have small Stroop effects. They will ignore the word, and it won’t influence them very much for either congruent or incongruent trials. As a result, the difference in performance (the Stroop effect) should be fairly small (if you have “good” selective attention in this task). People who are bad at ignoring the distracting words should have big Stroop effects. They will not ignore the words, causing them to be relatively fast when the word helps, and relatively slow when the word mismatches. As a result, they will show a difference in performance between the incongruent and congruent conditions.
If we take the size of the Stroop effect as a measure of selective attention, we can then start wondering what sorts of things improve selective attention (e.g., that make the Stroop effect smaller), and what kinds of things impair selective attention (e.g., make the Stroop effect bigger).
The research question of this study was to ask whether standing up improves selective attention compared to sitting down. They predicted smaller Stroop effects when people were standing up and doing the task, compared to when they were sitting down and doing the task.
10.2 Lab Skills Learned
- Conducting a 2x2 between-subjects ANOVA
- Conducting a 2x2 repeated-measures ANOVA
10.3 Important Stuff
- citation: Rosenbaum, D., Mama, Y., & Algom, D. (2017). Stand by Your Stroop: Standing Up Enhances Selective Attention and Cognitive Control. Psychological science, 28(12), 1864-1867.
- Link to .pdf of article
- Data in .csv format
10.4 R
10.4.1 Load the data
Remember that any line with a # makes a comment and the code does not run. Below is how to load the .csv data from the online repository, or from a local file (you need to change the file path to where the local file is, if you downloaded it). The data contains all of the measures and conditions from Experiment 1 in the paper.
library(data.table)
#all_data <- fread("https://github.com/CrumpLab/statisticsLab/raw/master/stroop_stand.csv")
<- fread("data/stroop_stand.csv") all_data
10.4.2 Inspect the dataframe
This will give you a big picture of the data frame. Click the button to view it in your browser, then take a look to see what is in it.
library(summarytools)
view(dfSummary(all_data))
We see there are four columns of numbers. The column names tell us whether the data is for a congruent or incongruent condition, and whether the participant was sitting or standing. Note, this data is in wide-format, not long-format. Each subject has 4 measures per row. We will need to change this to work with the data in R.
10.4.3 Get the data you need
This data file contains all of the data from Experiment 1 in the paper. So, we don’t need to get rid of any rows.
10.4.4 Get the data into the format you want
As mentioned before we need to convert the data from wide to long format. What we want at the end of this conversion is:
- A column for the subject variable
- A column for the congruency variable
- A column for the posture (sit vs. stand) variable
- A column for the DV ( mean reaction times)
We look at two ways to do the transformation from wide to long. The first way is to “do it by hand”, which refers to creating every variable individually, and then putting them together in a single data frame. This next bit of code does this, and you can check out stroop_df
to see the result.
<- c(as.numeric(unlist(all_data[,1])),
RTs as.numeric(unlist(all_data[,2])),
as.numeric(unlist(all_data[,3])),
as.numeric(unlist(all_data[,4]))
)
<- rep(rep(c("Congruent","Incongruent"),each=50),2)
Congruency <- rep(c("Stand","Sit"),each=100)
Posture <- rep(1:50,4)
Subject
<- data.frame(Subject,Congruency,Posture,RTs) stroop_df
Another way to transform between long and wide is to use R functions that were designed to do this job. For example there are the spread
and gather
functions from the tidyr
package, and the melt
and cast
functions, which also do some data frame transforming. The transformation from wide to long can be complicated depending on the structure of the data, and you may often find it helpful to google these functions to look for more examples of their use.
Let’s use the tidyr
gather
function to change our data from wide to long
library(tidyr)
<- gather(all_data, key=Condition, value=RTs,
stroop_long
congruent_stand, incongruent_stand, congruent_sit, incongruent_sit)
Take a moment to look at stroop_long
. It is almost what we need. It is certainly in long format. There is a column for Subjects, and a column for the RTs, but there is only one column for both IVs, that’s no good. There are two IVs, we need two columns. Fortunately, the levels in the new Condition column are coded with a specific and consistent structure:
- congruent_stand
- incongruent_stand
- congruent_sit
- incongruent_sit
If only we could split these by the “_” (underscore), then we would have two columns for the congruency and the posture variable. We can do this using tstrsplit
from the data.table
package
<- tstrsplit(stroop_long$Condition, "_", names=c("Congruency","Posture")) new_columns
You can look inside new_columns
to see that we succesfully made the split. Now, we just need to add them on to the stroop_long data
frame.
<- cbind(stroop_long,new_columns) stroop_long
Look at the stroop_long
data frame and you will find that we have added two new columns, one that codes for Congruency, and the other that codes for posture.
Using this method we still haven’t added a column for subjects. We can do that like this:
<- cbind(stroop_long,Subject=rep(1:50,4)) stroop_long
10.4.5 Look at the data
Remember before we do any analysis, we always want to “look” at the data. This first pass let’s us know if the data “look right”. For example, the data file could be messed up and maybe there aren’t any numbers there, or maybe the numbers are just too weird.
Let’s make a quick histogram of all of the RT data, like this:
hist(stroop_long$RTs)
This looks pretty good, there are no super huge numbers here.
10.4.6 Look at the means
As part of looking at the data, we might as well make a figure that shows the mean reaction times in each condition, and some error bars to look at the spread in each condition. The following code takes two important steps:
Get the means for each condition, by averaging over the means for each subject. These are put into the data frame called
plot_means
.Make a graph with the
plot_means
data frame using ggplot2.
library(dplyr)
library(ggplot2)
<- stroop_long %>%
plot_means group_by(Congruency,Posture) %>%
summarise(mean_RT = mean(RTs),
SEM = sd(RTs)/sqrt(length(RTs)))
ggplot(plot_means, aes(x=Posture, y=mean_RT, group=Congruency, fill=Congruency))+
geom_bar(stat="identity", position="dodge")+
geom_errorbar(aes(ymin=mean_RT-SEM, ymax=mean_RT+SEM),
position=position_dodge(width=0.9),
width=.2)+
theme_classic()+
coord_cartesian(ylim=c(700,1000))
10.4.7 Conduct the ANOVA
In this lab we will show you how to conduct ANOVAs for factorial designs that are for:
- fully between-subjects designs (both IVs are between-subjects IVs)
- fully repeated measures designs (both IVs are repeated measures)
The data we are looking at right now is fully repeated measures.
However, in this lab we are first going to pretend that the experiment was not repeated measures. We are going to pretend it was fully between-subjects. Then we are going to conduct a between-subjects ANOVA. After that, we will conduct a repeated-measures ANOVA, which is what would be most appropriate for this data set. The overall point is to show you how to both of them, and the discuss how to interpret them and write them both up.
10.4.8 Between Subjects ANOVA
We can always conduct a between-subjects version of the ANOVA on repeated-measures data if we wanted to. In this case we wouldn’t really want to do this. But, we will do this for educational purposes to show you how to do it in R.
The syntax is very similar to what we do for one-way ANOVAs, remember the syntax was:
aov(DV ~ IV, dataframe)
If you want to add another IV, all you need to do is insert another one into the formula, like this:
aov(DV ~ IV1*IV2, dataframe)
Just, switch DV to the name of your dependent measure, and IV1 and IV2 to the names of your independent variables. Finally, put the name of your dataframe. Your dataframe must be in long format with one observation of the DV per row.
Our formula will look like this:
aov(RTs ~ Congruency*Posture, stroop_long)
In plain language, this formula means, analyze RTs by the Congruency and Posture Variables. R will automatically produce the main effects for Congruency and Posture, as well as the interaction (Congruency X Posture). Also, remember, that in the following code, we use a few other functions so that we can print out the results nicely.
library(xtable)
<-aov(RTs ~ Congruency*Posture, stroop_long)
aov_out<-summary(aov_out)
summary_out
library(xtable)
::kable(xtable(summary_out)) knitr
Df | Sum Sq | Mean Sq | F value | Pr(>F) | |
---|---|---|---|---|---|
Congruency | 1 | 576821.635 | 576821.635 | 43.7344419 | 0.0000000 |
Posture | 1 | 32303.453 | 32303.453 | 2.4492381 | 0.1191950 |
Congruency:Posture | 1 | 6560.339 | 6560.339 | 0.4974029 | 0.4814808 |
Residuals | 196 | 2585080.215 | 13189.185 | NA | NA |
We can also have R print out the Grand Mean, the means for each level of each main effect, and the means for the interaction term. This is the same print out you would get in the console for R. It is admittedly not very pretty. There’s probably a way to make the means provided by model.tables()
more pretty. If we find a way we will update this section, if you find a way, please let us know.
print(model.tables(aov_out,"means"), format="markdown")
## Tables of means
## Grand mean
##
## 868.6454
##
## Congruency
## Congruency
## congruent incongruent
## 814.9 922.3
##
## Posture
## Posture
## sit stand
## 881.4 855.9
##
## Congruency:Posture
## Posture
## Congruency sit stand
## congruent 821.9 808.0
## incongruent 940.8 903.9
10.4.8.1 ANOVA write-up
Here are the steps for writing up the results of an ANOVA:
- Say what means you analyzed
- Say what test you performed
- Say the inferential statisic for each of the effects (main effects and interaction)
- Say the pattern of results for each effect.
A short example of the whole write-up is below:
Example write-up
We submitted the mean reaction times for each group to a 2 (Congruency: congrueny vs. incongruent) x 2 (Posture: Standing vs. Sitting) between-subjects ANOVA.
There was a main effect of Congruency, F (1, 196) = 43.73, MSE = 13189.185, p < 0.001. Mean reaction times were slower for incongruent (922 ms) than congruent groups (815 ms).
There main effect of Posture was not significant, F (1, 196) = 2.45, MSE = 13189.185, p =.119. Mean reaction times were slower for sitting (881 ms) than standing groups (855 ms).
The two-way interaction between Congruency and Posture was not significant, F (1, 196) = .497, MSE = 13189.185, p < 0.481.
For every F-value, we report F (df1, df2) = F-value, MSE = MSE for the error term, and p = x.xxx.
In R, the df1, for the df in the numerator is always listed beside the name for a particular effect. For example, Congruency has 1 degree of freedom (there are two condition, and 2-1 =1). Similarly, the relevant F and p-value are listed in the same row as the effect of interest.
However, the error term used to calculate the F-value is listed at the bottom, in R this is called “Residuals”. Df2, the df for the denominator is listed beside “Residuals”, in our case it was 196. The important bit is the MSE, which was 13189.185. Notice, that in the write up for each main effect and interaction we always reported the same MSE. That’s because in this between-subjects version of the ANOVA, we divide by same very same error term. Also notice that we don’t report the sums of squares of the MSE for the effect.
Why not? The main reason why not is that you can reconstruct those missing numbers just by knowing the dfs, the MSE for the error, and the f-value.
For example, you can get the MSE for the effect by multiplying the F-value by the MSE for the error. Now you have both MSEs. You can get both Sums of Squares by multiplying by their associated dfs. That’s just working backwards from the F-value.
You can always check if you are reporting the correct MSE for the error term. If the MSE for your effect (numerator) divided by the MSE you are using for the error term does not equal the F-value, then you must be using the wrong terms!
10.4.9 Repeated measures ANOVA
Of course, the design for this experiment was not between-subjects, it was fully within-subjects. Every participant completed both congruent and incongruent trials, while they were standing or sitting. For this reason, we should conduct a repeated measures ANOVA. This way we will be able capitilize on the major benefit provided by the repeated measures design. We can remove the variance due to individual subjects from the error terms we use to calculate F-values for each main effect and interaction.
Rember the formula for the one-factor repeated-measures ANOVA, we’ll remind you:
aov( DV ~ IV + Error(Subject/IV), dataframe)
To do the same for a design with more than one IV we put in another IV to the formula, like this:
aov( DV ~ IV1*IV2 + Error( Subject/(IV1*IV2) ), dataframe)
- DV = name of dependent variable
- IV1 = name of first independent variable
- IV2 = name of second indpendent variable
- Subject = name of the subject variable, coding the means for each subject in each condition
- dataframe = name of the long-format data frame
Here is what our formula will look like:
aov(RTs ~ Congruency*Posture + Error(Subject/(Congruency*Posture)), stroop_long)
The main thing you need to watch out for when running this analysis in R, is that all your factors need to be factors
in R. Often times people will use numbers rather than words or letters to code the levels for specific factors. This can be very often done for the subjects factor, using number 1 for subject one, and number 2 for subject 2. If you want your column variable to be treated as a factor, then you may need to convert it to a factor. We do this below for the Subject variable, which happens to be coded as numbers. If we do not do this, the repeated-measures ANOVA will return incorrect results.
For example, if you look at the stroop_long
data frame, and click the little circle with an arrow on in it in the environment panel, you should see that Subject is an int
. That stands for integer. You should also see that Congruency and Posture are Factor
, that’s good. We need to turn Subject into Factor
.
$Subject <- as.factor(stroop_long$Subject) #convert subject to factor
stroop_long
<-aov(RTs ~ Congruency*Posture + Error(Subject/(Congruency*Posture)), stroop_long)
summary_out
library(xtable)
::kable(xtable(summary_out)) knitr
Df | Sum Sq | Mean Sq | F value | Pr(>F) | |
---|---|---|---|---|---|
Residuals | 49 | 2250738.636 | 45933.4416 | NA | NA |
Congruency | 1 | 576821.635 | 576821.6349 | 342.452244 | 0.0000000 |
Residuals | 49 | 82534.895 | 1684.3856 | NA | NA |
Posture | 1 | 32303.453 | 32303.4534 | 7.329876 | 0.0093104 |
Residuals1 | 49 | 215947.614 | 4407.0942 | NA | NA |
Congruency:Posture | 1 | 6560.339 | 6560.3389 | 8.964444 | 0.0043060 |
Residuals | 49 | 35859.069 | 731.8177 | NA | NA |
print(model.tables(aov_out,"means"), format="markdown")
## Tables of means
## Grand mean
##
## 868.6454
##
## Congruency
## Congruency
## congruent incongruent
## 814.9 922.3
##
## Posture
## Posture
## sit stand
## 881.4 855.9
##
## Congruency:Posture
## Posture
## Congruency sit stand
## congruent 821.9 808.0
## incongruent 940.8 903.9
What’s different here? Are any of the means different now that we have conducted a repeated-meaures version of the ANOVA, instead of the between-subjects ANOVA? NO! The grand mean is still the grand mean. The means for the congruency conditions are still the same, the means for the Posture conditions are still the same, and the means for the interaction effect are still the same. The only thing that has changed is the ANOVA table. Now that we have removed the variance associated with individual subjects, our F-values are different, and so are the-pvalues. Using an alpha of 0.05, all of the effects are “statistically significant”.
Each main effect and the one interaction all have their own error term. In the table below, R lists each effect in one row, and then immediately below lists the error term for that effect.
10.4.9.1 ANOVA write-up
Here is what a write-up would look like.
Example write-up
We submitted the mean reaction times for each subject in each condition to a 2 (Congruency: congrueny vs. incongruent) x 2 (Posture: Standing vs. Sitting) repeated measures ANOVA.
There was a main effect of Congruency, F (1, 49) = 342.45, MSE = 1684.39, p < 0.001. Mean reaction times were slower for incongruent (922 ms) than congruent groups (815 ms).
There main effect of Posture was significant, F (1, 49) = 7.33, MSE = 4407.09, p =.009. Mean reaction times were slower for sitting (881 ms) than standing groups (855 ms).
The two-way interaction between Congruency and Posture was significant, F (1, 49) = 8.96, MSE = 731.82, p < 0.004. The Stroop effect was 23 ms smaller in the standing than sitting conditions.
10.4.10 Follow-up comparisons
In a 2x2 ANOVA there are some follow-up comparisons you may be interested in making that are not done for you with the ANOVA. If an IV only have 2 levels, then you do not have to do any follow-up tests for the main effects of those IVs (that’s what the main effect from the ANOVA tells you). So, we don’t have to do follow-up comparisons for the main effects of congruency or posture. What about the interaction?
Notice the interaction is composed of four means. The mean RT for congruent and incongruent for both sitting and standing.
Also notice that we only got one F-value and one p-value from the ANOVA for the interaction term. So, what comparison was the ANOVA making? And what comparisons was it not making? It has already made one comparison, so you do not need a follow-up test for that…which one is it?
If you remember back to the textbook, we should you how to analyze a 2x2 design with paired-samples t-tests. We analyzed the interaction term as the comparison of difference scores. Here, we would find the differences scores between incongruent and congruent for each level of the posture variable. In other words, we compute the Stroop effect for each subjet when they were sitting and standing, then compare the two Stroop effects. This comparison is looking at the difference between two differences scores, and that is the comparison that the ANOVA does for the interaction. To be more precise the comparison is:
\((sit:incongruent - sit:congruent) - (stand:incongruent - stand:congruent)\)
What comparisons are not made, what are the other ones we could do? Here are some:
- sit:congruent vs sit:incongruent
- stand:congruent vs stand:incongruent
- sit:congruent vs stand:incongruent
- stand:congruent vs sit:incongruent
We could add a few more. These kinds of comparisons are often called simple effects, apparently referring to the fact they are just comparing means in a straight forward way. There are a few different comparisons we could do. Should we do any of them?
Whether or not you compare means usually depends on the research question you are asking. Some comparisons make sense within context of the research question, and others may not. We will do two follow-up comparisons. Our question will be about the size of the Stroop effect in the Sitting and Standing conditions. We already know that the size of the effect was smaller in the Standing condition. But, we don’t know if it got so small that it went away (at least statistically speaking). Now, we can ask:
Was the Stroop effect only for the sitting condition statistically signficant. In other words, was the difference in mean RT between the incongruent and congruent conditions unlikely under the null (or unlikely to be produced by chance)
Was the Stroop effect only for the standing condition statistically signficant. In other words, was the difference in mean RT between the incongruent and congruent conditions unlikely under the null (or unlikely to be produced by chance)
We can answer both of the questions using paired sample t-tests comparing the means in question
10.4.10.1 Sitting Stroop
<- stroop_long %>%
means_to_compare filter(Posture=="sit")
t.test(RTs~Congruency, paired=TRUE, var.equal=TRUE, data=means_to_compare)
##
## Paired t-test
##
## data: RTs by Congruency
## t = -16.516, df = 49, p-value < 2.2e-16
## alternative hypothesis: true mean difference is not equal to 0
## 95 percent confidence interval:
## -133.3250 -104.3997
## sample estimates:
## mean difference
## -118.8623
10.4.10.2 Standing Stroop
<- stroop_long %>%
means_to_compare filter(Posture=="stand")
t.test(RTs~Congruency, paired=TRUE, var.equal=TRUE, data=means_to_compare)
##
## Paired t-test
##
## data: RTs by Congruency
## t = -14.327, df = 49, p-value < 2.2e-16
## alternative hypothesis: true mean difference is not equal to 0
## 95 percent confidence interval:
## -109.41185 -82.49462
## sample estimates:
## mean difference
## -95.95323
10.4.11 Generalization Exercise
Here are some means for four conditions in a 2x2 Design:
IV1 | |||
---|---|---|---|
Level 1 | Level 2 | ||
IV 2 | Level 1 | 100 | 200 |
Level 2 | 200 | 500 |
Your task is to:
A. Compute the mean difference for the main effect of IV1
B. Compute the mean difference for the main effect of IV2
C. Compute the mean difference for the interaction
10.4.12 Writing asignment
(2 points - Graded)
Factorial designs have main effects and interactions.
Explain the concept of a main effect. (1 point)
Explain the concept of an interaction. (1 point)
General grading.
- You will receive 0 points for missing answers
- You must write in complete sentences. Point form sentences will be given 0 points.
- Completely incorrect answers will receive 0 points.
- If your answer is generally correct but very difficult to understand and unclear you may receive half points for the question
10.6 SPSS
In this lab, we will use SPSS to:
- Conduct and graph a Between-Subjects Two-Factor Analysis of Variance (ANOVA)
- Calculate simple effects
- Conduct and graph a Repeated Measures Two-Factor Analysis of Variance (ANOVA)
- Calculate simple effects
10.6.1 Experiment Background
The Rosenbaum, Mama, and Algom (2017) paper asked whether sitting versus standing would influence a measure of selective attention, the ability to ignore distracting information. Selective attention here is measured as performance on the Stroop task.
In a typical Stroop experiment, subjects name the color of words as fast as they can. The trick is that sometimes the color of the word is the same as the name of the word, and sometimes it is not.
The design of the study was a 2x2 design. The first IV was congruency
(congruent vs incongruent). The second IV was posture
(sitting vs. standing). The DV was reaction time (RT
)to name the word.
10.6.2 Conduct a Between-Subjects Two-Factor Analysis of Variance (ANOVA)
Here is a link to our data file. It is named stroopsit.sav. Your data should look like this:
Notice that in this file, there are 200 rows (corresponding to 200 subjects). Each subject is categorized according to 2 independent variables: posture (whether they were in the standing or sitting condition), and congruency (whether the stimuli they received were congruent or incongruent). In this application, we are treating the design as between-subjects. This means each participant only experienced one of the following four conditions:
- congruent stand
- incongruent stand
- congruent sit
- incongruent sit
Now, let’s run our Two-Factor ANOVA. Go to Analyze, then General Linear Model, then Univariate…
A window will appear asking for you to specify your variables. Place RT
into the “Dependent Variable” field, and put both “posture” and “congruency” into the “Fixed Factors” field.
Now, before pressing anything else, click on Plots… (this will allow us to create a plot of means right along with our SPSS output). In the plots window, you must place the congruency
and posture
variables into the fields labeled “Horizontal Axis”” and “Separate Lines”. You can place either variable in either field, and the graph will still make sense. However, for this example, I will be putting congruency
into the “Separate Lines”” field, and posture
in “Horizontal Axis”:
You must click Add for this table to be included in your SPSS output. After you do this, Your window should look like this:
Then click Continue and OK. Your output will include a table labeled “Tests of Between Subjects Effects” and a plot of the means.
You can see from this output that:
- There is no main effect of posture, F(1, 196)=2.449, p=NS
- There is a main effect of congruency, F(1, 196)=43.734, p<.05 where (from looking at the plot) incongruent stimuli were processed with a longer reaction time than congruent stimuli.
- There is no interaction between posture and congruency, F(1, 196)=.497, p=NS
10.6.3 Calculate simple effects
In previous ANOVAs, we have conducted both planned and unplanned comparisons to locate the significant differences. In the case of a two-factor ANOVA, there are many comparisons that can be made. However, the comparisons you choose will depend on the results of your ANOVA. In this case, we found only a significant main effect of congruency. So, we can explore this effect more by asking:
- For the sitting condition only, are congruent and incongruent means significantly different?
- For the standing condition only, are congruent and incongruent means significantly different?
To answer these questions, we must calculate something called simple effects. They look at mean differences within levels of a single independent variable. In order to acheive this in SPSS, we have to get into the coding environment that runs the SPSS program; it’s called Syntax. Don’t freak out here, we’re going to make this as simple as possible.
First, let’s go to the menu just as we did to run this ANOVA. Analyze, General Linear Model, then Univariate…
The next window looks just as we left it, with the variables in the right places. Here, click on the button that says Paste.
The result will be a new window with code already entered into it. This code correponds to the ANOVA setup we have specified.
You are going to edit this code so that it looks like this:
UNIANOVA RT BY posture congruency
/METHOD=SSTYPE(3)
/INTERCEPT=INCLUDE
/PLOT=PROFILE(posture * congruency)
/EMMEANS=TABLES(posture * congruency) COMPARE(congruency) ADJ(LSD)
/CRITERIA=ALPHA(.05)
/DESIGN=posture congruency posture * congruency.
Once it does, click the big green triangle (“play”) at the top of the window.
SPSS will produce a series of tables. The one that refers to simple effects is called “Pairwise Comparisons.”
From this table, we can see that,
- In the sitting condition, the congruent and incongruent conditions are significantly different (p<.05).
- In the standing condition, the congruent and incongruent conditions are significantly different (p<.05).
10.6.4 Conduct a Repeated Measures Two-Factor Analysis of Variance (ANOVA)
Next, we will use this same data but treat it as a repeated measures (within-subjects) design (just as in the original experiment). This means each person in the study experienced ALL 4 conditions.
To start, we need a new data file. Here is link. This data file is called stroopsit_RM.sav. I have set it up so that the data is arranged for a repeated-measures design. Notice that each person is represented by a single row, and the columns correspond to the 4 conditions:
Now, to run a repeated measures ANOVA, we go to Analyze, then General Linear Model, then Repeated Measures:
The next window will ask for the name and number of levels of your within-subjects factors (variables); We have two within-subjects factors: posture
and congruency
, and each factor has two levels. We must enter then here one at a time. First, change the default factor1
name to congruency
, and specify that it has 2 levels:
Click Add, and then enter a new within-subjects factor, posture
with 2 levels as well:
Now, click Add, and then Define. The next window asks for the 4 conditions produced by our two independent variables. Because we entered posture
first, and congruency next
, the four conditions, in THIS EXACT order, are entered as follows:
Click Plots and specify a graph exactly as we did in the previous example. Place posture
in the “Separate Lines” field and congruency
in the “Horizontal axis” field.
Remember, you must click Add to process this graph!
Now, click Continue, then OK.
SPSS will produce several tables of output, along with a graph. The Fs for our ANOVA are located in the table labeled “Tests of Within-Subjects Effects”, and the plot we requested is found below:
According to this output: 1. There is a main effect of congruency, F(1, 49)=342.45, p<.05. 2. There is a main effect of posture, F(1, 49)=7.33, p<.05. 3. There is an interaction effect between congruency and posture, F(1, 49)=8.96, p<.05.
From the plot we can see that incongruent words produced longer RTs than congruent words. We also see that sitting produced longer RTs than standing. As for the interaction, you can see that the difference between congruent and incongruent is more pronounced (larger) in the sitting condition than in the standing condition.
10.6.5 Calculate simple effects
We may want to dissect these effects similarly to the way did in the previous example. This time, because all 3 effects were significant, we will ask SPSS to conduct simple effects for both congruency
and posture
. To begin, go to Analyze, General Linear Model, and Repeated Measures…
In the next window, all of your saved settings are still there, so click Define. In the next window, click Paste:
You will be taken to the SPSS Syntax window.
Change the syntax you see to the following:
GLM congruent_stand congruent_sit incongruent_stand incongruent_sit
/WSFACTOR=congruency 2 Polynomial posture 2 Polynomial
/METHOD=SSTYPE(3)
/PLOT=PROFILE(congruency * posture)
/EMMEANS=TABLES(congruency * posture) compare(congruency) adj(lsd)
/EMMEANS=TABLES(congruency * posture) compare(posture) adj(lsd)
/CRITERIA=ALPHA(.05)
/WSDESIGN=congruency posture congruency * posture.
Click the green triangle (“play”)at the top and you will see several output tables appear in the output window. We will focus on the following two:
When reading these tables, remember that:
- For
posture
, 1=stand and 2=sit - For
congruency
, 1=congruent and 2=incongruent.
In this output, we can see that: 1. For standing only, congruent and incongruent RTs are significantly different (p<.05). 2. For sitting only, congruent and incongruent RTs are significantly different (p<.05). 3. For congruent words only, standing and sitting RTs are not significantly different (p=NS). 4. For incongruent words only, standing and sitting are significantly different (p<.05).
10.6.6 Practice Problems
Below is fictitious data representing the number of milliimeters a plant has grown under several water/sunlight combinations:
Water & Sunlight | NoWater & Sunlight | Water & NoSunlight | NoWater & NoSunlight |
---|---|---|---|
1.2 | 2.4 | 3.1 | 2.5 |
3.0 | 1.1 | 2.2 | 3.4 |
2.5 | 1.2 | 2.5 | 4.2 |
1.6 | 2.4 | 4.3 | 2.1 |
Enter this data into SPSS as appropriate for a Two-Factor Between-Subjects ANOVA (N=16). Perform the ANOVA and report all results in standard statistical reporting format (use alpha=.05). Include a plot of means.
Enter this data into SPSS as appropriate for a Two-Factor Repeated-Measures ANOVA (N=4). Perform the ANOVA and report all results in standard statistical reporting format (use alpha=.05). Include a plot of means.
10.8 CogStat
10.8.1 Goals
In this lab, we will use CogStat to:
Conduct and graph a Between-Subjects Two-Factor Analysis of Variance (ANOVA)
Calculate simple effects
Conduct and graph a Repeated Measures Two-Factor Analysis of Variance (ANOVA)
10.8.2 Experiment background
The Rosenbaum, Mama, and Algom (2017) paper asked whether sitting versus standing would influence a measure of selective attention, the ability to ignore distracting information. Selective attention here is measured as performance on the Stroop task.
In a typical Stroop experiment, subjects name the colour of words as fast as they can. The trick is that sometimes the colour of the word is the same as the name of the word, and sometimes it is not.
The design of the study was a 2x2 design. The first independent variable was congruency (congruent vs incongruent). The second independent variable was posture (sitting vs. standing). The dependent variable was reaction time (RT) to name the word.
10.8.3 Conduct a Between-Subjects Two-Factor Analysis of Variance (ANOVA)
Open the data file we will use this section, called “stroopsit”. Notice that in this file, there are 200 rows (corresponding to 200 participants). Each subject is categorised according to two independent variables: posture (whether they were in the standing or sitting condition), and congruency (whether the stimuli they received were congruent or incongruent). In this application, we are treating the design as between-subjects. This means each participant only experienced one of the following four conditions:
congruent stand
incongruent stand
congruent sit
incongruent sit
By running the ANOVA we would like to find out whether Congruency or Posture have a main effect on Reaction time. As well as we would like to know if there is a relation between these two variables.
Now, let’s run our Two-Factor ANOVA in CogStat. To do this, choose “Analysis” then “Compare groups…”
Select “RT” as “Dependent variable” then “Congruency” and “Posture” as “Groups”, and finally, hit “OK”.
Raw data illustrates the different groups on a graph. As can be seen, there are four groups based on which group a person belongs to in Congruency and Posture.
Sample properties provide the descriptives and boxplots for each group.
Population properties show the confidence intervals, as well as provide the results of the hypothesis test.
This last section gives us the answer to our questions:
There is no main effect of posture, F(1, 196)=2.45, p=0.119 (it is not significant)
There is a main effect of congruency, F(1, 196)=43.76, p<0.001 where (from looking at the plot) incongruent stimuli were processed with a longer reaction time than congruent stimuli.
There is no interaction between posture and congruency, F(1, 196)=0.49, p=0.484 (it is not significant)
10.8.4 CogStat: Display options…
In CogStat with the function “Display options..” you can set how you would like your factors to appear.
After choosing “Display options…” you get some opportunities to change how the factors will be displayed on the graphs.
You can set the minimum and maximum values of axis Y. You can choose some or all the variables to be displayed in different colours. Choose the variables you would like to colour as “Group(s) displayed with colours and hit “OK”. Each factor will be colored differently in the graphs.
By choosing variables as “Group(s) displayed in panels” each variable and its datapoints will be displayed in a different graph, as shown in the pictures below.
10.8.5 Conduct a Repeated Measures Two-Factor Analysis of Variance (ANOVA)
Next, we will use data from the same experiment but will treat it as a repeated measures (within-subjects) design (just as in the original experiment). This means each person in the study experienced all four conditions. To start, we need the modified version of the previous dataset. This data file is called “stroopsit_RM” and is arranged for a repeated-measures design. Load the data into CogStat and notice that each person is represented by a single row, and the columns correspond to the four conditions.
We have to mention here that the purpose of this manipulation is to provide an easy-to-access and easy-to-understand example. In real life, manipulating the dataset in such ways is unacceptable, because it would make the correctness of the analysis questionable. Based on the study design you can have data that is between or within-subject, or mixed, but between-subject data cannot be handled as within-subject, and within-subject data cannot be handled as between-subject. This is because in a between-subject design different groups are assigned only in one condition and their result is compared to other groups. In a within-subject design, every participant can experience every condition, so in the dataset more datapoint belong to one person, and a participants’ results are compared to their results in other conditions, so this design works with repeated measures.
To run a repeated measures ANOVA choose “Analysis” and then “Compare repeated measures variables and groups…” (Ctrl + M).
In this appearing dialogue choose “Factors…” to set the factors.
As you already know, in this new dialogue that just appeared, factors can be added, modified and removed. Choose “Add factor”.
We will have two factors, and in each, we will set two levels. Name the first factor “Congruency” and the second “Posture”.
Now that all the factors needed are set, hit “OK”.
The available variables must be paired with the factors set in the dependent variable part of the dialogue. When choosing the variables available pay attention to the order and consistency of the pairing. For example, congruency 1 should always be the congruent condition, and posture 1 should always be the standing condition. After setting the variables, hit “OK”.
As always raw data shows all the cases, as well as missing values and provides a graph for illustration.
In sample properties, we got the most important descriptive statistics and boxplots graphing the individual values.
In population properties, the confidence intervals can be observed and lastly the hypothesis test is included, too.
The result of the repeated measures ANOVA is: F(1, 49) = 342.45, p < 0.001. From the plot, we can see that incongruent words produced longer RTs than congruent words. We also see that sitting produced longer RTs than standing. As for the interaction, you can see that the difference between congruent and incongruent is more pronounced (larger) in the sitting condition than in the standing condition.
At this moment additional post-hoc tests are not available for the repeated measure two-factor ANOVA, but it is a priority during our software development, so the next update will likely provide you with post hoc tests as well.