概率统计Python计算:双因素等重复试验方差分析

2024-08-22 22:48

本文主要是介绍概率统计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=1rj=1sk=1tXijkXij=t1k=1tXijk,i=1,2,;r,j=1,2,,sXi=st1j=1sk=1tXijk=s1j=1sXij,i=1,2,,rXj=rt1i=1rk=1tXijk=r1i=1rXij,j=1,2,sST=i=1rj=1sk=1t(XijkX)2
其中, X ‾ \overline{X} X为样本总均值, X ‾ i ⋅ \overline{X}_{i\cdot} Xi为因素水平 A i A_i Ai对应的样本均值, X ‾ ⋅ j \overline{X}_{\cdot j} Xj为因素水平 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=1rj=1sk=1t(XijkXij)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=1r(XiX)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=1s(XjX)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=1rj=1s(XijXiXj+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 1ir,1js)为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} Xj为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=1rj=1sk=1t(XijkX)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=1r(XiX)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=1s(XjX)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=1rj=1s(XijXiXj+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=1rj=1sμij μ i ⋅ = 1 s ∑ j = 1 s μ i j \mu_{i\cdot}=\frac{1}{s}\sum\limits_{j=1}^s\mu_{ij} μi=s1j=1sμij μ ⋅ j = 1 r ∑ i = 1 r μ i j \mu_{\cdot j}=\frac{1}{r}\sum\limits_{i=1}^r\mu_{ij} μj=r1i=1rμ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(t1)SA/(r1)~ F ( r − 1 , r s ( t − 1 ) ) F(r-1,rs(t-1)) F(r1,rs(t1)),第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(t1))SB/(s1)~ F ( s − 1 , r s ( t − 1 ) ) F(s-1,rs(t-1)) F(s1,rs(t1)),第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(t1))SAB/(r1)(s1)~ F ( ( r − 1 ) ( s − 1 ) , r s ( t − 1 ) ) F((r-1)(s-1), rs(t-1)) F((r1)(s1),rs(t1)),第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 A158.2,52.656.2,41.265.3,60.8
燃料 A 2 A_2 A249.1,42.854.1,50.551.6,48,4
燃料 A 3 A_3 A360.1,58.370.9,73.239.2,40.7
燃料 A 4 A_4 A475.8,71.558.2,51.048.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 1i4 1 ≤ j ≤ 3 1\leq j\leq3 1j3。希望通过对试验数据的分析,判断选择最佳的燃料与推进器的搭配( α = 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计算:双因素等重复试验方差分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097614

相关文章

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调

Python下载Pandas包的步骤

《Python下载Pandas包的步骤》:本文主要介绍Python下载Pandas包的步骤,在python中安装pandas库,我采取的方法是用PIP的方法在Python目标位置进行安装,本文给大... 目录安装步骤1、首先找到我们安装python的目录2、使用命令行到Python安装目录下3、我们回到Py

Python GUI框架中的PyQt详解

《PythonGUI框架中的PyQt详解》PyQt是Python语言中最强大且广泛应用的GUI框架之一,基于Qt库的Python绑定实现,本文将深入解析PyQt的核心模块,并通过代码示例展示其应用场... 目录一、PyQt核心模块概览二、核心模块详解与示例1. QtCore - 核心基础模块2. QtWid