方差分析

概念

方差分析:又称变异分析,是英国统计学家R.A.Fisher于1923年提出的一种统计方法,故有时也称为F检验。

可简写为ANOVA。用于多组均数 之间的显著性检验。

要求:各组观察值服从正态分布或近似正态分布,并且各组之间的方差具有齐性

基本思想:将所有测量值间的总变异按照其变异的来源分解为多个部份,然后进行比较,评价由某种因素所引起的变异是否具有统计学意义。

计算方法

总变异(Total variation):全部测量值xij与总均数间μ的差异

组间变异( between group variation ):各组的均数μi与总均数μ间的差异

组内变异(within groupvariation ):每组的每个测量值xij与该组均数μi的差异

其中,三种变异的关系为:SST = SSB + SSW,DT = DB+ DW

例题

有三组人,分别服用了不同的高血压药A,B,C一个月以后,观察每一个人血压下降数:

A组               4             5             7             3             8             5             3                                           μA= 5.00

B组               1             5             3             7             4             2             7             4             1             μB= 3.78

C组               7             8             10           6             9             8                                                          μC= 8.00

我们想要知道A,B,C三个药对于下降血压的效果是否有明显的区别。

解题

假设:

H0:A,B,C三个药下降血压效果没有区别,即μA= μB= μC

H1:A,B,C三个药下降血压有区别

1. 首先我们需要求SST,SSB,SSW

求SST之前我们先需要求出A,B,C三组人的平均值:

μ = (xA1+xA2+…+xAn+xB1+xB2+…+xBn+xC1+xC2+…+xCn)

= (4+5+7+3+8+5+3+1+5+3+7+4+2+7+4+1+7+8+10+6+9+8)/22

= 5.32

所以SST = (xA1-μ)2+…+(xAn-μ)2+(xB1-μ)2…+(xBn-μ)2+(xC1-μ)2…+(xCn-μ)2

= (4-μ)2+…+(3 -μ)2+(1-μ)2…+(1-μ)2+(7-μ)2…+(8-μ)2

= 139

再求SSB = (μA -μ) 2+(μA-μ)2+( μA-μ)2+( μB-μ)2+( μB-μ)2+( μB-μ)2+( μC-μ)2+( μC-μ)2+( μC-μ)2=65.2

最后求

SSW = (xA1- μA)2+…+(xAn- μA)2+(xB1-μB)2…+(xBn- μB)2+(xC1-μC)2…+(xCn- μC)2

= (4-5.00)2+…+(3 -5.00)2+(1-3.78)2…+(1-3.78)2+(7-8.00)2…+(8 -8.00)2

= 73.6

根据性质SST = SSW + SSB,所以这三个只要求出其它两个,另外一个用等式SST= SSW + SSB即可求出。

2. 我们求自由度:DT,DB,DW

我们知道样本总共有22个,而且我们知道样本总体的值,所以我们只需要知道其中21个样本,剩下的1个就可以的出来,所以总体自由度DT= 22-1 = 21

因为我们有3组,我们只需要知道其中的两组,另外一组也可以的出来,所以组间自由度DB= 3-2 = 2

第一组有7个样本,我们只需要知道其中的6个,剩下的一个可以的出来,所以第一组的自由度DW1= (7-1) = 6,同理,第二三组的也可以的出来,所以总的组内自由度DW= (7-1) + (9-1) +(6-1) = 19

同理,我们有性质DT = DB + DW,所以我们只要知道其中两个自由度,剩下的一个可以由公式得出。

3. 最后我们求F,F的公式为F = (SSB/DB) / (SSW/DW) =(65.2/2) / (73.6/19) = 8.42,且自由度为F(2,19)

此时我们α=0.05的F分布表如下图,我们看到自由度为2和19时,置信度为95%的值为3.52,而此时我们的值为8.42,远超过3.52,所以我们接受H0的概率小于0.05,所以拒绝H0假设,接受H1,即A,B,C三个药的效果有明显的不同

R语言实现

anova = function(x){    x_mean = sapply(x,mean)  total_mean = mean(unlist(x))    sst = sum((unlist(x)-total_mean)^2)    ssw = 0  for(i in 1:length(x)){    w = sum((x[[i]]-x_mean[i])^2)    ssw = ssw + w  }    ssb = 0  for(i in 1:length(x)){    b = length(x[[i]])*((x_mean[i]-total_mean)^2)    ssb = ssb + b  }    Nt = length(unlist(x))-1 # 总自由度  Nb = length(x)-1 # 组间自由度  Nw = Nt - Nb     f = (ssb/Nb)/(ssw/Nw)    result = c(sst,ssb,ssw,Nt,Nb,Nw,f)  names(result)= c('sst','ssb','ssw','Nt','Nb','Nw','f')    return(result)  }x1 = c(4,5,7,3,8,5,3)x2 = c(1,5,3,7,4,2,7,4,1)x3 = c(7,8,10,6,9,8)x = list(x1,x2,x3)f = anova(x)

最后得出f为:

(0)

相关推荐