Python绘制X-bar图和R图 | 统计过程控制SPC

2023-09-22 00:57:42

X-bar图和R图是用于统计过程控制(SPC)的两种常用工具,用于监测过程的平均值和范围(变异性)。这些图有助于识别过程中的变化和异常,以便及时采取纠正措施。

**X-bar图(平均值控制图)**显示了一系列样本的平均值,用于监测过程的平均值是否保持在可接受的范围内。X-bar图通常由以下几个要素组成:

  1. 样本平均值:每个样本的数据点的平均值,通常用于每个样本的数据集。

  2. 中心线:通常是所有样本平均值的平均值,表示过程的目标值。

  3. 控制限:通常包括上限控制限和下限控制限,用于指示过程平均值的可接受范围。控制限的计算方法可以根据需求不同而有所不同,常用的方法包括使用标准偏差和样本大小。

  4. 数据点:每个样本的平均值在X-bar图上以数据点的形式表示,通常用线连接这些数据点以显示趋势。

**R图(范围控制图)**显示了一系列样本的范围(最大值和最小值之间的差异),用于监测过程的变异性。R图通常由以下几个要素组成:

  1. 范围(R):每个样本的最大值和最小值之间的差异。

  2. 中心线:通常是所有R值的平均值,表示过程的变异性目标。

  3. 控制限:通常包括上限控制限,用于指示R值的可接受范围。控制限的计算方法可以根据需求不同而有所不同,常用的方法包括使用标准偏差和样本大小。

  4. 数据点:每个样本的R值在R图上以数据点的形式表示,通常用线连接这些数据点以显示趋势。

在绘制X-bar图和R图之前,需要进行以下步骤:

  1. 收集样本数据并确定样本大小和采样频率。

  2. 计算每个样本的平均值(X-bar图)和范围(R图)。

  3. 计算X-bar图和R图的中心线和控制限。

  4. 绘制X-bar图和R图,并将样本数据点与中心线和控制限一起显示。

要生成表格数据并写入文件,然后读取数据并计算X-bar图和R图所需的平均值、标准差等,您可以按照以下步骤进行操作。首先,确保您已经安装了NumPy、matplotlib和Pandas库。

import numpy as np
import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = ['SimHei']  # 防止中文标签乱码,还有通过导入字体文件的方法
plt.rcParams['axes.unicode_minus'] = False

# 生成随机数据,例如,生成5个样本,每个样本5个数据点
data = np.random.rand(5, 5)

# 创建一个Pandas DataFrame
df = pd.DataFrame(data, columns=['Sample 1', 'Sample 2', 'Sample 3', 'Sample 4', 'Sample 5'])

# 将数据写入CSV文件
df.to_csv('sample_data.csv', index=False)

# 从CSV文件读取数据
df = pd.read_csv('sample_data.csv')

# 打印数据框的前几行以确保数据已成功加载
print(df.head())
# 计算每个样本的平均值
x_bar = df.mean(axis=1)

# 计算每个样本的范围(R)
R = df.max(axis=1) - df.min(axis=1)

# 计算平均值和R的平均值
x_bar_avg = x_bar.mean()
R_avg = R.mean()

# 计算X-bar图的控制限(通常为平均值的上下控制限)
x_bar_upper_limit = x_bar_avg + 0.577 * R_avg
x_bar_lower_limit = x_bar_avg - 0.577 * R_avg

# 计算R图的控制限(通常为R的上限)
R_upper_limit = R_avg * 2.114

# 打印计算结果
print(f'X-bar平均值: {x_bar_avg}')
print(f'R平均值: {R_avg}')
print(f'X-bar控制限: ({x_bar_lower_limit}, {x_bar_upper_limit})')
print(f'R控制限: {R_upper_limit}')

 

# 绘制X-bar图
plt.figure(figsize=(10, 6))
plt.plot(x_bar, marker='o', linestyle='-')
plt.axhline(y=x_bar_avg, color='r', linestyle='--', label='平均值')
plt.axhline(y=x_bar_upper_limit, color='g', linestyle='--', label='控制限')
plt.axhline(y=x_bar_lower_limit, color='g', linestyle='--')
plt.title('X-bar图')
plt.xlabel('样本编号')
plt.ylabel('平均值')
plt.legend()
plt.grid()
plt.show()

# 绘制R图
plt.figure(figsize=(10, 6))
plt.plot(R, marker='o', linestyle='-')
plt.axhline(y=R_avg, color='r', linestyle='--', label='平均值')
plt.axhline(y=R_upper_limit, color='g', linestyle='--', label='控制限')
plt.title('R图')
plt.xlabel('样本编号')
plt.ylabel('范围 (R)')
plt.legend()
plt.grid()
plt.show()

#    Sample 1  Sample 2  Sample 3  Sample 4  Sample 5
# 0  0.341066  0.113474  0.924694  0.877339  0.257942
# 1  0.659984  0.817222  0.555201  0.529651  0.241852
# 2  0.093103  0.897216  0.900418  0.633101  0.339030
# 3  0.349210  0.725956  0.897110  0.887086  0.779876
# 4  0.642032  0.084140  0.161629  0.898554  0.606429
# X-bar平均值: 0.568532531479609
# R平均值: 0.7112440409136231
# X-bar控制限: (0.1581447198724485, 0.9789203430867696)
# R控制限: 1.5035699024913993

 

import numpy as np
import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = ['SimHei']  # 防止中文标签乱码,还有通过导入字体文件的方法
plt.rcParams['axes.unicode_minus'] = False

# 假设您已经有了样本数据,存储在x_bar_values和R_values中

# 计算中心线和控制限
x_bar_centerline = np.mean(x_bar_values)
R_centerline = np.mean(R_values)
R_bar = np.mean(R_values)

# 计算控制限(通常使用常见的控制图常数,如A2,D3,D4)
A2 = 0.729
D3 = 0
D4 = 2.282
x_bar_UCL = x_bar_centerline + A2 * R_bar
x_bar_LCL = x_bar_centerline - A2 * R_bar
R_UCL = D4 * R_bar
R_LCL = D3 * R_bar

# 绘制X-bar图
plt.figure(figsize=(12, 6))
plt.subplot(2, 1, 1)
plt.plot(x_bar_values, marker='o', linestyle='-')
plt.axhline(y=x_bar_centerline, color='r', linestyle='--', label='中心线')
plt.axhline(y=x_bar_UCL, color='g', linestyle='--', label='上限控制限')
plt.axhline(y=x_bar_LCL, color='g', linestyle='--', label='下限控制限')
plt.title('X-bar图')
plt.xlabel('样本编号')
plt.ylabel('平均值')
plt.legend()
plt.grid()

# 绘制R图
plt.subplot(2, 1, 2)
plt.plot(R_values, marker='o', linestyle='-')
plt.axhline(y=R_centerline, color='r', linestyle='--', label='中心线')
plt.axhline(y=R_UCL, color='g', linestyle='--', label='上限控制限')
plt.title('R图')
plt.xlabel('样本编号')
plt.ylabel('范围 (R)')
plt.legend()
plt.grid()

plt.tight_layout()
plt.show()

这段代码将生成X-bar图和R图,帮助您监控过程的平均值和范围,以便识别任何过程中的异常或变化。请根据您的数据和需求进行适当的修改。在实际应用中,您可能需要根据标准和过程的特性来调整控制限和常数。

 

更多推荐

20230912在ubuntu18.04下使用pigz来提高tar命令压缩解压缩的速度

20230912在ubuntu18.04下使用pigz来提高tar命令压缩解压缩的速度2023/9/1522:19https://blog.csdn.net/wb4916/article/details/12844729820221226编译Toybrick的TB-RK3588X开发板的Android12系统2-SDK

设计的思考,设计是什么? 优漫动游

设计是什么?这是个大问题,但也是个小众问题。可能有很多人会说,“设计就是“你所需要的”东西。”这个回答或许说的很直白:因为有很多人都是从自己的角度去思考问题。”——我想做好一件事情。”——这是我喜欢做好一件事情的动力之一。”——但是这些解释是片面的。为什么?因为大家都会发现:自己所做的任何事情都不可能解决所有的问题。而

图论第四天|127. 单词接龙、841. 钥匙和房间、463. 岛屿的周长

127.单词接龙★文档讲解:代码随想录-127.单词接龙状态:开始学习。(★:需要多次回顾并重点回顾)思路:本题需要解决两个问题:图中的线是如何连在一起的题目中并没有给出点与点之间的连线,而是要我们自己去连,条件是字符只能差一个,所以判断点与点之间的关系,要自己判断是不是差一个字符,如果差一个字符,那就是有链接。起点和

大数据快速入门开发环境篇:CentOS 7安装配置Hadoop大数据框架开发环境

注意:在开始安装之前,请确保您的CentOS7系统已经正确安装和配置了Java。Hadoop需要Java来运行。目录一、下载与配置Hadoop框架:1.1、下载与环境变量设置1.2、XML配置文件Hadoop设置1.3、格式化HDFS二、Hadoop3.x版本中hdfs命令的问题解决与配置方法2.1、问题描述与解决方法

时序预测 | MATLAB实现BO-BiGRU贝叶斯优化双向门控循环单元时间序列预测

时序预测|MATLAB实现BO-BiGRU贝叶斯优化双向门控循环单元时间序列预测目录时序预测|MATLAB实现BO-BiGRU贝叶斯优化双向门控循环单元时间序列预测效果一览基本介绍模型搭建程序设计参考资料效果一览基本介绍MATLAB实现BO-BiGRU贝叶斯优化双向门控循环单元时间序列预测。基于贝叶斯(bayes)优化

【Unity2D】提升tilemap地图绘制速度的技巧

先安装好对应的包正文教程下面的都是我找到的不错教程,学会了也就能少花冤枉钱,不被Unity中国坑。【Unity小技巧】Unity2DTileMap的探究(最简单,最全面的TileMap使用介绍)这个博客会详细讲解了规则瓦片的各种功能,帮助我们可以快速自动地铺好地图,偏向俯视角地图制作,但是太全了,也没个参照,所以对于新

opencv 轮廓顶点重新排序----四边形

defreorder(myPoints):#print(myPoints.shape)#创建一个与myPoints具有相同形状和类型的数组myPointsNew=np.zeros_like(myPoints)#数组重塑为一个4行2列的数组myPoints=myPoints.reshape((4,2))#计算myPoin

三维模型3DTile格式轻量化压缩处理的数据质量提升方法分析

三维模型3DTile格式轻量化压缩处理的数据质量提升方法分析在处理三维模型3DTile格式的轻量化压缩时,如何在减少数据量的同时,保证或提升数据质量是一大挑战。以下为一些提升数据质量的方法分析:改进几何简化算法:在进行几何简化时,除了考虑顶点数量的减少,更要注重误差度量和形状特征。选择具有视觉优化功能的算法,例如基于四

Api接口加密策略

接口安全要求:1.防伪装攻击(案例:在公共网络环境中,第三方有意或恶意的调用我们的接口)2.防篡改攻击(案例:在公共网络环境中,请求头/查询字符串/内容在传输过程被修改)3.防重放攻击(案例:在公共网络环境中,请求被截获,稍后被重放或多次重放)4.防数据信息泄漏(案例:截获用户登录请求,截获到账号、密码等)设计原则:1

java - 散列算法 SHA-256 hash值计算

文章目录前言java-散列算法SHA-256hash值计算1.散列算法是什么?2.散列算法的主要特征是什么?3.计算SHA-256值有没有可能重复4.SHA-256算法实现示例前言如果您觉得有用的话,记得给博主点个赞,评论,收藏一键三连啊,写作不易啊^_^。而且听说点赞的人每天的运气都不会太差,实在白嫖的话,那欢迎常来

MQTT Paho Android 支持SSL/TLS(亲测有效)

MQTTPahoAndroid支持SSL/TLS(亲测有效)登录时支持ssl的交互这是调测登录界面设计代码中对ssl/tls的支持使用MqttAndroidClient配置mqtt客户端请求时,不加密及加密方式连接存在以下几点差异:url及端口差异valuri:String=if(tlsConnection){"ssl

热文推荐