本文主要是介绍概率统计Python计算:双因素等重复试验方差分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
双因素等重复试验的数据模型 X X X是一个结构为 r × s × t r\times s\times t r×s×t的3-维矩阵(张量),其中 X i j k X_{ijk} Xijk取自于总体指标 N ( μ i j , σ 2 ) N(\mu_{ij},\sigma^2) N(μij,σ2), i = 1 , 2 , ⋯ , r , j = 1 , 2 , ⋯ , s , k = 1 , 2 , ⋯ , t i=1,2,\cdots,r,j=1,2,\cdots,s,k=1,2,\cdots,t i=1,2,⋯,r,j=1,2,⋯,s,k=1,2,⋯,t。记 X ‾ = 1 r s t ∑ i = 1 r ∑ j = 1 s ∑ k = 1 t X i j k X ‾ i j = 1 t ∑ k = 1 t X i j k , i = 1 , 2 , ⋯ ; r , j = 1 , 2 , ⋯ , s X ‾ i ⋅ = 1 s t ∑ j = 1 s ∑ k = 1 t X i j k = 1 s ∑ j = 1 s X ‾ i j , i = 1 , 2 , ⋯ , r X ‾ ⋅ j = 1 r t ∑ i = 1 r ∑ k = 1 t X i j k = 1 r ∑ i = 1 r X ‾ i j , j = 1 , 2 ⋯ , s S T = ∑ i = 1 r ∑ j = 1 s ∑ k = 1 t ( X i j k − X ‾ ) 2 \overline{X}=\frac{1}{rst}\sum_{i=1}^r\sum_{j=1}^s\sum_{k=1}^{t}X_{ijk}\\\overline{X}_{ij}=\frac{1}{t}\sum_{k=1}^tX_{ijk},i=1,2,\cdots;r,j=1,2,\cdots,s\\\overline{X}_{i\cdot}=\frac{1}{st}\sum_{j=1}^s\sum_{k=1}^tX_{ijk}=\frac{1}{s}\sum_{j=1}^s\overline{X}_{ij},i=1,2,\cdots,r\\ \overline{X}_{\cdot j}=\frac{1}{rt}\sum_{i=1}^r\sum_{k=1}^tX_{ijk}=\frac{1}{r}\sum_{i=1}^r\overline{X}_{ij},j=1,2\cdots,s\\ S_T=\sum_{i=1}^r\sum_{j=1}^s\sum_{k=1}^t(X_{ijk}-\overline{X})^2 X=rst1i=1∑rj=1∑sk=1∑tXijkXij=t1k=1∑tXijk,i=1,2,⋯;r,j=1,2,⋯,sXi⋅=st1j=1∑sk=1∑tXijk=s1j=1∑sXij,i=1,2,⋯,rX⋅j=rt1i=1∑rk=1∑tXijk=r1i=1∑rXij,j=1,2⋯,sST=i=1∑rj=1∑sk=1∑t(Xijk−X)2
其中, X ‾ \overline{X} X为样本总均值, X ‾ i ⋅ \overline{X}_{i\cdot} Xi⋅为因素水平 A i A_i Ai对应的样本均值, X ‾ ⋅ j \overline{X}_{\cdot j} X⋅j为因素水平 B j B_j Bj对应的样本均值, X ‾ i j \overline{X}_{ij} Xij为组合因素样本均值, S T S_T ST为样本总变差。
令 S E = ∑ i = 1 r ∑ j = 1 s ∑ k = 1 t ( X i j k − X ‾ i j ) 2 S_E=\sum\limits_{i=1}^r\sum\limits_{j=1}^s\sum\limits_{k=1}^t(X_{ijk}-\overline{X}_{ij})^2 SE=i=1∑rj=1∑sk=1∑t(Xijk−Xij)2,称为误差平方和; S A = s t ∑ i = 1 r ( X ‾ i ⋅ − X ‾ ) 2 S_A=st\sum\limits_{i=1}^{r}(\overline{X}_{i\cdot}-\overline{X})^2 SA=sti=1∑r(Xi⋅−X)2,称为因素 A A A的效应平方和; S B = r t ∑ j = 1 s ( X ‾ ⋅ j − X ‾ ) 2 S_B=rt\sum\limits_{j=1}^s(\overline{X}_{\cdot j}-\overline{X})^2 SB=rtj=1∑s(X⋅j−X)2,称为效应 B B B的平方和; S A B = t ∑ i = 1 r ∑ j = 1 s ( X ‾ i j − X ‾ i ⋅ − X ‾ ⋅ j + X ‾ ) 2 S_{AB}=t\sum\limits_{i=1}^r\sum\limits_{j=1}^s(\overline{X}_{ij}-\overline{X}_{i\cdot}-\overline{X}_{\cdot j}+\overline{X})^2 SAB=ti=1∑rj=1∑s(Xij−Xi⋅−X⋅j+X)2,称为因素 A A A与 B B B的交互效应平方和。
与单因素试验模型中样本总变差 S T S_T ST的分解类似,双因素等重复试验的样本总变差 S T S_T ST可分解为
S T = S E + S A + S B + S A B . S_T=S_E+S_A+S_B+S_{AB}. ST=SE+SA+SB+SAB.
下列代码定义双因素等重复试验的样本总变差 S T S_T ST的分解函数。
def dfeDecompose(X):(r,s,t)=X.shape #模型数据结构X_bar=X.mean(axis=2) #组合因素样本均值Xi_bar=X_bar.mean(axis=1).reshape(r,1) #A因素水平样本均值Xj_bar=X_bar.mean(axis=0).reshape(1,s) #B因素水平样本均值Xt_bar=X.mean() #样本总均值ST=((X-Xt_bar)**2).sum() #样本总变差SA=s*t*((Xi_bar-Xt_bar)**2).sum() #A效应平方和SB=r*t*((Xj_bar-Xt_bar)**2).sum() #B效应平方和SAB=t*((X_bar-Xi_bar-Xj_bar+Xt_bar)**2).sum() #交互效应平方和SE=ST-SA-SB-SAB #误差平方和return r, s, t, SA, SB, SAB, SE
第2行从X的结构中读取其宽度r,长度s和深度t。第3行计算因素水平 A i A_i Ai, B j B_j Bj组合对应的样本均值 X ‾ i j \overline{X}_{ij} Xij( 1 ≤ i ≤ r , 1 ≤ j ≤ s 1\leq i\leq r,1\leq j\leq s 1≤i≤r,1≤j≤s)为X_bar。它是由参数X表示的张量按下标 k k k方向计算样本均值:X.mean(axis=2)所得,这是一个 r × s r\times s r×s的矩阵。第4行由X_bar按下标 j j j的方向计算因素水平 A i A_i Ai对应的样本均值 X ‾ i ⋅ \overline{X}_{i\cdot} Xi⋅为Xi_bar,设置为一个 r × 1 r\times1 r×1的矩阵。相仿地,第5行由X_bar按下标 i i i的方向计算因素水平 B j B_j Bj对应的样本均值 X ‾ ⋅ j \overline{X}_{\cdot j} X⋅j为Xj_bar,设置为一个 1 × s 1\times s 1×s的矩阵。第6行计算总样本均值 X ‾ \overline{X} X为Xt_bar,这是一个实数。第7行计算总变差平方 S T = ∑ i = 1 r ∑ j = 1 s ∑ k = 1 t ( X i j k − X ‾ ) 2 S_T=\sum\limits_{i=1}^r\sum\limits_{j=1}^s\sum\limits_{k=1}^t(X_{ijk}-\overline{X})^2 ST=i=1∑rj=1∑sk=1∑t(Xijk−X)2为ST。第8行计算因素 A A A的效应平方和 S A = s t ∑ i = 1 r ( X ‾ i ⋅ − X ‾ ) 2 S_A=st\sum\limits_{i=1}^{r}(\overline{X}_{i\cdot}-\overline{X})^2 SA=sti=1∑r(Xi⋅−X)2为SA。第9行计算因素 B B B的效应平方和 S B = r t ∑ j = 1 s ( X ‾ ⋅ j − X ‾ ) 2 S_B=rt\sum\limits_{j=1}^s(\overline{X}_{\cdot j}-\overline{X})^2 SB=rtj=1∑s(X⋅j−X)2为SB。第10行计算因素的交互效应平方和 S A B = t ∑ i = 1 r ∑ j = 1 s ( X ‾ i j − X ‾ i ⋅ − X ‾ ⋅ j + X ‾ ) 2 S_{AB}=t\sum\limits_{i=1}^r\sum\limits_{j=1}^s(\overline{X}_{ij}-\overline{X}_{i\cdot}-\overline{X}_{\cdot j}+\overline{X})^2 SAB=ti=1∑rj=1∑s(Xij−Xi⋅−X⋅j+X)2为SAB,正因为我们将Xi_bar和Xj_bar设置成了 r × 1 r\times1 r×1和 1 × s 1\times s 1×s的矩阵,所以此处的表达式才几乎和数学表达式一样简洁。利用算得的数据 r r r, s s s, t t t, S A S_A SA, S B S_B SB, S A B S_{AB} SAB和 S E S_E SE计算假设
H 01 : μ i ⋅ − μ = 0 , i = 1 , 2 , ⋯ , r H 02 : μ ⋅ j − μ = 0 , j = 1 , 2 , ⋯ , s H 03 : μ i j − μ i ⋅ − μ ⋅ j + μ = 0 , i = 1 , 2 , ⋯ , r , j = 1 , 2 , ⋯ , s H_{01}:\mu_{i\cdot}-\mu=0,i=1,2,\cdots,r\\ H_{02}:\mu_{\cdot j}-\mu=0,j=1,2,\cdots,s\\ H_{03}:\mu_{ij}-\mu_{i\cdot}-\mu_{\cdot j}+\mu=0,i=1,2,\cdots,r,j=1,2,\cdots,s H01:μi⋅−μ=0,i=1,2,⋯,rH02:μ⋅j−μ=0,j=1,2,⋯,sH03:μij−μi⋅−μ⋅j+μ=0,i=1,2,⋯,r,j=1,2,⋯,s
其中,令 μ = 1 r s ∑ i = 1 r ∑ j = 1 s μ i j \mu=\frac{1}{rs}\sum\limits_{i=1}^r\sum\limits_{j=1}^s\mu_{ij} μ=rs1i=1∑rj=1∑sμij, μ i ⋅ = 1 s ∑ j = 1 s μ i j \mu_{i\cdot}=\frac{1}{s}\sum\limits_{j=1}^s\mu_{ij} μi⋅=s1j=1∑sμij, μ ⋅ j = 1 r ∑ i = 1 r μ i j \mu_{\cdot j}=\frac{1}{r}\sum\limits_{i=1}^r\mu_{ij} μ⋅j=r1i=1∑rμij。接受 H 01 H_{01} H01意味着因素A对试验没有显著影响;接受 H 02 H_{02} H02,意味着因素B对试验结果没有显著影响;接受 H 03 H_{03} H03意味因素A和B对试验结果没有交互影响。
下列代码定义在显著水平 α \alpha α下检验假设 H 01 H_{01} H01, H 02 H_{02} H02和 H 03 H_{03} H03的函数。
def dfeTest(r, s, t, SA, SB, SAB, SE, alpha):F=(r*s*(t-1))*SA/SE/(r-1) #H01检验统计量值accept1=ftestR(F, r-1, r*s*(t-1), alpha)F=(r*s*(t-1))*SB/SE/(s-1) #H02检验统计量值accept2=ftestR(F, s-1,r*s*(t-1), alpha)F=(r*s*(t-1)*SAB)/((r-1)*(s-1)*SE) #H03检验统计量值accept3=ftestR(F, (r-1)*(s-1), r*s*(t-1), alpha)return accept1, accept2, accept3
第2行设置假设 H 01 H_{01} H01的检验统计量值 S A / ( r − 1 ) S E / r s ( t − 1 ) \frac{S_A/(r-1)}{S_E/rs(t-1)} SE/rs(t−1)SA/(r−1)~ F ( r − 1 , r s ( t − 1 ) ) F(r-1,rs(t-1)) F(r−1,rs(t−1)),第3行调用函数ftestR计算假设 H 01 H_{01} H01的右侧检验。第4行设置 H 02 H_{02} H02的检验统计量值 S B / ( s − 1 ) S E / ( r s ( t − 1 ) ) \frac{S_B/(s-1)}{S_E/(rs(t-1))} SE/(rs(t−1))SB/(s−1)~ F ( s − 1 , r s ( t − 1 ) ) F(s-1,rs(t-1)) F(s−1,rs(t−1)),第5行计算假设 H 02 H_{02} H02右侧的检验。第6行设置 H 03 H_{03} H03的检验统计量值 S A B / ( r − 1 ) ( s − 1 ) S E / ( r s ( t − 1 ) ) \frac{S_{AB}/(r-1)(s-1)}{S_E/(rs(t-1))} SE/(rs(t−1))SAB/(r−1)(s−1)~ F ( ( r − 1 ) ( s − 1 ) , r s ( t − 1 ) ) F((r-1)(s-1), rs(t-1)) F((r−1)(s−1),rs(t−1)),第7行计算假设 H 03 H_{03} H03的右侧检验。
例1一火箭使用四种燃料,三种推进器作射程试验。每种燃料与每种推进器的组合各发射火箭两次,得射程(单位:海里)如下:
推进器 B 1 B_1 B1 | 推进器 B 2 B_2 B2 | 推进器 B 3 B_3 B3 | |
---|---|---|---|
燃料 A 1 A_1 A1 | 58.2,52.6 | 56.2,41.2 | 65.3,60.8 |
燃料 A 2 A_2 A2 | 49.1,42.8 | 54.1,50.5 | 51.6,48,4 |
燃料 A 3 A_3 A3 | 60.1,58.3 | 70.9,73.2 | 39.2,40.7 |
燃料 A 4 A_4 A4 | 75.8,71.5 | 58.2,51.0 | 48.7,41.4 |
假定火箭对应第 i i i种燃料,第 j j j种推进器的射程服从 N ( μ i j , σ 2 ) N(\mu_{ij},\sigma^2) N(μij,σ2), 1 ≤ i ≤ 4 1\leq i\leq4 1≤i≤4, 1 ≤ j ≤ 3 1\leq j\leq3 1≤j≤3。希望通过对试验数据的分析,判断选择最佳的燃料与推进器的搭配( α = 0.05 \alpha=0.05 α=0.05)。
解: 下列代码计算本例。
alpha=0.05
X=np.array([[[58.2, 52.6],[56.2, 41.2],[65.3, 60.8]],[[49.1, 42.8],[54.1, 50.5],[51.6, 48.4]],[[60.1, 58.3],[70.9, 73.2],[39.2, 40.7]],[[75.8, 71.5],[58.2, 51.0],[48.7, 41.4]]])
r, s, t, SA, SB, SAB, SE=dfeDecompose(X)
H0=dfeTest(r, s, t, SA, SB, SAB, SE, alpha)
print(H0)
第1~5行按题面设置数据。第6行调用函数dfeDecompose分解样本总变差,得到数据 r r r, s s s, t t t, S A S_A SA, S B S_B SB, S A B S_{AB} SAB和 S E S_E SE。第7行调用函数dfeTest计算假设 H 01 H_{01} H01, H 02 H_{02} H02和 H 03 H_{03} H03的检验。运行程序,输出
(False, False, False)
表示拒绝假设 H 01 H_{01} H01, H 02 H_{02} H02和 H 03 H_{03} H03,燃料、推进器以及两者的组合都显著影响火箭的射程。由表观察可见燃料4和推进器1的组合有利于射程。
写博不易,敬请支持:
如果阅读本文于您有所获,敬请点赞、评论、收藏,谢谢大家的支持!
代码诚可贵,原理价更高。若为AI学,读正版书好。
返回《导引》
这篇关于概率统计Python计算:双因素等重复试验方差分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!