0% found this document useful (0 votes)
205 views7 pages

ANOVA Analysis in R Guide

1. The document describes conducting a 1-way ANOVA in R to analyze data from an experiment testing 6 insect sprays. 2. Descriptive statistics including the means, variances, and sample sizes for each spray are calculated and a boxplot of the data is viewed. 3. A 1-way ANOVA is run using the oneway.test() and aov() functions and post hoc tests including TukeyHSD are examined. 4. Assumptions of the ANOVA are checked including homogeneity of variance and normality of residuals. Non-parametric alternatives are also considered.

Uploaded by

jubatus.libro
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
205 views7 pages

ANOVA Analysis in R Guide

1. The document describes conducting a 1-way ANOVA in R to analyze data from an experiment testing 6 insect sprays. 2. Descriptive statistics including the means, variances, and sample sizes for each spray are calculated and a boxplot of the data is viewed. 3. A 1-way ANOVA is run using the oneway.test() and aov() functions and post hoc tests including TukeyHSD are examined. 4. Assumptions of the ANOVA are checked including homogeneity of variance and normality of residuals. Non-parametric alternatives are also considered.

Uploaded by

jubatus.libro
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 7

ANOVA in R

1-Way ANOVA Were going to use a data set called InsectSprays. 6 different insect sprays (1 Independent Variable with 6 levels) were tested to see if there was a difference in the nu ber of insects found in the field after each spraying (!ependent Variable).
> attach(InsectSprays) > data(InsectSprays) > str(InsectSprays) 'data.frame': 72 obs. of 2 variables: $ count: num ! 7 2! " " 2 ! 2# 7 2! ... $ spray: $actor %& ' levels ()(*(+(*(,(*(-(*..:

...

1. Descriptive statistics a. "ean# variance# nu ber of ele ents in each cell b. Visualise the data $ bo%plot& loo' at distribution# loo' for outliers Well use the tapply() function which is a helpful shortcut in processing data# basically allowing you to specify a response variable# a factor (or factors) and a function that should be applied to each subset of the response variable defined by each level of the factor. I.e. Instead of doing( > mean(count[spray=="A"]) # and the same for B, C, D etc. We use tapply(response#factor#function)na e) as follows *ets loo' at the eans(
> tapply(count* spray* mean) ) + , "./!!!!! /.###### 2.!0#### ".1 '''7 . #./!!!!! $ '.'''''7

+he variances(
'.2'/ /2 . $ #.!!!!!! #0.'!'!'

> tapply(count* spray* var) ) + , 22.272727 0.2"2"2" #.1! / /

,nd sa ple si-es

> tapply(count* spray* len2th) ) + , - . $ 2 2 2 2 2 2

,nd a bo%plot(

> bo3plot(count 4 spray)

o .ow does the data loo'/

A couple of Asides !efault order is alphabetical. 0 needs# for e%a ple# the control condition to be 1st for treat ent contrasts to be easily interpreted. If theyre not auto atically in the correct order $ i.e. if they were ordered variables# but ca e out alphabetically (e.g. "Very.short","Short","Long","Very.long" or A, B, Control)# re)order the variables for ordered IV( +o change to# for e%a ple# 1 2 3 2 4 2 ! 2 5 2 ,# use(
> 5hotoperiod67ordered(spray*levels8c(($(*(+(*(,(*(-(*(.(*()())

4hec' it(
> tapply(count*5hotoperiod*mean) $ + , '.'''''7 /.###### 2.!0#### ".1 '''7 . #./!!!!! ) "./!!!!!

If you want to chec' that a variable is a factor (especially for variables with nu bers as factor levels). We use the is.factor directive to find this out

is.factor(spray) 9 : ;<=.

2. Run 1-way ANOVA a. Oneway.test ( ) 6se# for e%a ple(

> one%ay.test(count4spray) >ne7%ay analysis of means (not assumin2 e?ual variances) data: count and spray $ 8 #'.!'/"* num df 8 /.!!!* denom df 8 #!.!"#* p7value 8 7.111e7 2

!efault is e7ual variances (i.e. ho ogeneity of variance) not assu ed $ i.e. Welchs correction applied (and this e%plains why the deno df (which is nor ally '8(n)1)) is not a whole nu ber in the output) o +o change this# set 9var.e?ual8( option to +065 corrects for non)ho ogeneity# but doesnt give uch infor ation $ i.e. :ust F# p)value and dfs for nu erator and deno inator $ no "S etc.
>ne%ay.test( )

b. Run an ANOVA using aov( ) 6se this function and store output and use e%traction functions to e%tract what you need.
> aov.out 8 aov(count 4 spray* data8InsectSprays) > summary(aov.out)

F( !"") # $%.&' p ( .))) 3. *ost +oc tests ,u-ey +.D(+onestly .ignificant Difference) is default in R
> ;u@eyAS-(aov.out) ;u@ey multiple comparisons of means 1/B family7%ise confidence level $it: aov(formula 8 count 4 spray* data 8 InsectSprays) $spray +7) ,7) -7) .7) $7) ,7+ -7+ .7+ $7+ -7, .7, $7, .7$7$7. diff !.0###### 7 2." ''''7 71./0##### 7 .!!!!!!! 2. '''''7 7 #.2/!!!!! 7 !." ''''7 7 .0###### .####### 2.0###### ." ''''7 "./0##### 7 ." ''''7 .7/!!!!! #. '''''7 l%r 7#.0''!7/ /./#27"2 7 7. '!7/ 77.7 72/0 7 ".2027"2 7".00#12/ 7 /.'11"!1 7'.#!!/1 72./#27"2 '.0''!7/ 7 7.1"1"!1 70.//!/1 7 /. '!7/ 7/.7 72/0 7 './#27"2 77. ##12/ 7#.#''!7/ '.!#27"2 7 .0''!7/ 7./#27"2 7#.2027"2 '. '!7/ 1.00#12/ 1.2027"2 7'. '!7/ #.2027"2 7.!/!/1 '.""1"!1 0."'72/0 7.0''!7/ upr !.11/ 0 ! !.!!!!!!! !.!!!!! " !.!!!!!!! !.7/"2 "7 !.!!!!!!! !.!!!!!!2 !.!!!!!!! !.1'!#!7/ !."12!7!7 !.1"00''1 !.!!!!!!! !.1"00''1 !.!!!!!!! !.!!!!!!! p adC

; 4. /ontrasts <3( ,<=V, and linear regression are the sa e thing $ ore on that to orrow. 1or the o ent# the ain point to note is that you can loo' at the results fro aov() in ter s of the linear regression that was carried out# i.e. you can see the para eters that were esti ated.
> summary.lm(aov.out)

I plicitly this can be understood as a set of (non)orthogonal) contrasts of the first group against each of the other groups. 0 uses these so)called >+reat ent contrasts as the default# but you can re7uest alternative contrasts (see later) 0nterpreting a ,reat1ent /ontrasts Output

5. ,est assu1ptions a. +o1ogeneity of variance

bartlett.test(count 4 spray* data8InsectSprays) +artlett test of homo2eneity of variances data: count by spray +artlett's D7s?uared 8 2/.1/10* df 8 /* p7value 8 1.!0/e7!/

> plot(aov.out)

Significant result, therefore variances cannot be assumed to be equal b. 2odel c3ec-ing plots

E the aov command prepares the data for these plots

+his shows if there is a pattern in the residuals# and ideally should show si ilar scatter for each condition. .ere there is a worrying effect of larger residuals for larger fitted values. +his

is called >heteroscedascity eaning that not only is variance in the response not e7ual across groups# but that the variance has so e specific relationship with the si-e of the response. In fact you could see this in the original bo%plots. It contradicts assu ptions ade when doing an ,<=V,.

+his loo's for nor ality of the residuals& if they are not nor al# the assu ptions of ,<=V, are potentially violated.

+his is li'e the first plot but now to specifically test if the residuals increase with the fitted values# which they do.

+his gives an idea of which levels of the factor are best fitted. 6. Non-para1etric alternative to ANOVA4
> @rus@al.test(count 4 spray* data8InsectSprays) Drus@al7Fallis ran@ sum test data: count by spray Drus@al7Fallis chi7s?uared 8 /".'1 #* df 8 /* p7value 8

./

e7 !

,s for the Wilco%on test (or "ann)Whitney test) with two sa ples# this test converts the response values to ran's# and tests whether the ran's are distributed e7ually across the conditions# as would be e%pected under the null hypothesis. . ANOVA as 5inear Regression Analysis +his ti e# rather than >attaching the data fra e# we will use the >with construct (see session one) to na e the data fra e and then do operations on variables within it.
> summary(5lantGro%th) %ei2ht 2roup Hin. :#./1! ctrl: ! st Iu.:".//! trt : ! Hedian :/. // trt2: ! Hean :/.!7# #rd Iu.:/./#! Ha3. :'.# ! > %ith(5lantGro%th* tapply(%ei2ht* 2roup* mean)) ctrl trt trt2 /.!#2 ".'' /./2' > %ith(5lantGro%th* tapply(%ei2ht* 2roup* var)) ctrl trt trt2 !.##111/' !.'2112 !. 1/07 > %ith(5lantGro%th* bartlett.test(%ei2ht 4 2roup)) +artlett test of homo2eneity of variances

data: %ei2ht by 2roup +artlett's D7s?uared 8 2.070'* df 8 2* p7value 8 !.2#7

<ow instead of running an ,<=V, with aov()# we will run a linear regression with l ()
> lm.out 8 %ith(5lantGro%th* lm(%ei2ht 4 2roup)) > summary(lm.out) E the default summary display %ill be the linear re2ression ,all: lm(formula 8 %ei2ht 4 2roup) <esiduals: Hin I Hedian 7 .!7 ! 7!." 0! 7!.!!'! #I !.2'27 Ha3 .#'1!

,oefficients: .stimate Std. .rror t value 5r(>JtJ) (Intercept) /.!#2! !. 17 2/./27 62e7 ' KKK 2rouptrt 7!.#7 ! !.2700 7 .## !. 1"" 2rouptrt2 !."1"! !.2700 .772 !.!077 . 777 Si2nif. codes: ! LKKKM !.!! LKKM !.! LKM !.!/ L.M !. <esidual standard error: !.'2#" on 27 de2rees of freedom Hultiple <7s?uared: !.2'" * )dCusted <7s?uared: !.2!1' $7statistic: ".0"' on 2 and 27 -$* p7value: !.! /1 > summary.aov(lm.out) 2roup <esiduals

L M

E %e can as@ for the correspondin2 )N>O) table

-f Sum S? Hean S? $ value 5r(>$) 2 #.7'' .00#2 ".0"' !.! /1 27 !."12 !.#00'

+here is a difference# but where does this difference lie/ ?ost .oc test(
> ;u@eyAS-(results) ;u@ey multiple comparisons of means 1/B family7%ise confidence level $it: aov(formula 8 %ei2ht 4 2roup) $2roup diff l%r upr p adC trt 7ctrl 7!.#7 7 .!'22 ' !.#2!2 ' !.#1!07 trt27ctrl !."1" 7!. 172 ' . 0/2 ' !. 1711'! trt27trt !.0'/ !. 7#70#1 .//'2 ' !.! 2!!'"

You might also like