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


    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库。

    1. import numpy as np
    2. import matplotlib.pyplot as plt
    3. import pandas as pd
    4. plt.rcParams['font.sans-serif'] = ['SimHei'] # 防止中文标签乱码
    5. plt.rcParams['axes.unicode_minus'] = False
    6. # 生成随机数据,例如,生成5个样本,每个样本5个数据点
    7. data = np.random.rand(5, 5)
    8. # 创建一个Pandas DataFrame
    9. df = pd.DataFrame(data, columns=['Sample 1', 'Sample 2', 'Sample 3', 'Sample 4', 'Sample 5'])
    10. # 将数据写入CSV文件
    11. df.to_csv('sample_data.csv', index=False)
    12. # 从CSV文件读取数据
    13. df = pd.read_csv('sample_data.csv')
    14. # 打印数据框的前几行以确保数据已成功加载
    15. print(df.head())
    16. # 计算每个样本的平均值
    17. x_bar = df.mean(axis=1)
    18. # 计算每个样本的范围(R)
    19. R = df.max(axis=1) - df.min(axis=1)
    20. # 计算平均值和R的平均值
    21. x_bar_avg = x_bar.mean()
    22. R_avg = R.mean()
    23. # 计算X-bar图的控制限(通常为平均值的上下控制限)
    24. x_bar_upper_limit = x_bar_avg + 0.577 * R_avg
    25. x_bar_lower_limit = x_bar_avg - 0.577 * R_avg
    26. # 计算R图的控制限(通常为R的上限)
    27. R_upper_limit = R_avg * 2.114
    28. # 打印计算结果
    29. print(f'X-bar平均值: {x_bar_avg}')
    30. print(f'R平均值: {R_avg}')
    31. print(f'X-bar控制限: ({x_bar_lower_limit}, {x_bar_upper_limit})')
    32. print(f'R控制限: {R_upper_limit}')
    33. # 绘制X-bar图和R图(二行一列)
    34. fig, axes = plt.subplots(2, 1, figsize=(6, 6)) # 创建2行1列的子图
    35. #plt.subplots_adjust(hspace=1) # 调整垂直间距
    36. # 绘制X-bar图
    37. axes[0].plot(x_bar, marker='o', linestyle='-')
    38. axes[0].axhline(y=x_bar_avg, color='r', linestyle='--', label='平均值')
    39. axes[0].axhline(y=x_bar_upper_limit, color='g', linestyle='--', label='控制限')
    40. axes[0].axhline(y=x_bar_lower_limit, color='g', linestyle='--')
    41. axes[0].set_title('X-bar图')
    42. axes[0].set_xlabel('样本编号')
    43. axes[0].set_ylabel('平均值')
    44. axes[0].legend()
    45. axes[0].grid()
    46. # 绘制R图
    47. axes[1].plot(R, marker='o', linestyle='-')
    48. axes[1].axhline(y=R_avg, color='r', linestyle='--', label='平均值')
    49. axes[1].axhline(y=R_upper_limit, color='g', linestyle='--', label='控制限')
    50. axes[1].set_title('R图')
    51. axes[1].set_xlabel('样本编号')
    52. axes[1].set_ylabel('范围 (R)')
    53. axes[1].legend()
    54. axes[1].grid()
    55. plt.tight_layout() # 调整子图之间的间距
    56. plt.show()
    57. # Sample 1 Sample 2 Sample 3 Sample 4 Sample 5
    58. # 0 0.333763 0.887816 0.047209 0.282097 0.285214
    59. # 1 0.215519 0.150961 0.528661 0.025044 0.737905
    60. # 2 0.464588 0.940235 0.709169 0.169721 0.247870
    61. # 3 0.146446 0.792779 0.222903 0.870784 0.340836
    62. # 4 0.743698 0.344687 0.299164 0.517687 0.120320
    63. # X-bar平均值: 0.417002982417057
    64. # R平均值: 0.7343395449701438
    65. # X-bar控制限: (-0.006710935030715903, 0.84071689986483)
    66. # R控制限: 1.5523937980668838

     

    --------------------------------------

    1. import numpy as np
    2. import matplotlib.pyplot as plt
    3. plt.rcParams['font.sans-serif'] = ['SimHei'] # 防止中文标签乱码,还有通过导入字体文件的方法
    4. plt.rcParams['axes.unicode_minus'] = False
    5. # 假设您已经有了样本数据,存储在x_bar_values和R_values中
    6. # 计算中心线和控制限
    7. x_bar_centerline = np.mean(x_bar_values)
    8. R_centerline = np.mean(R_values)
    9. R_bar = np.mean(R_values)
    10. # 计算控制限(通常使用常见的控制图常数,如A2,D3,D4)
    11. A2 = 0.729
    12. D3 = 0
    13. D4 = 2.282
    14. x_bar_UCL = x_bar_centerline + A2 * R_bar
    15. x_bar_LCL = x_bar_centerline - A2 * R_bar
    16. R_UCL = D4 * R_bar
    17. R_LCL = D3 * R_bar
    18. # 绘制X-bar图
    19. plt.figure(figsize=(12, 6))
    20. plt.subplot(2, 1, 1)
    21. plt.plot(x_bar_values, marker='o', linestyle='-')
    22. plt.axhline(y=x_bar_centerline, color='r', linestyle='--', label='中心线')
    23. plt.axhline(y=x_bar_UCL, color='g', linestyle='--', label='上限控制限')
    24. plt.axhline(y=x_bar_LCL, color='g', linestyle='--', label='下限控制限')
    25. plt.title('X-bar图')
    26. plt.xlabel('样本编号')
    27. plt.ylabel('平均值')
    28. plt.legend()
    29. plt.grid()
    30. # 绘制R图
    31. plt.subplot(2, 1, 2)
    32. plt.plot(R_values, marker='o', linestyle='-')
    33. plt.axhline(y=R_centerline, color='r', linestyle='--', label='中心线')
    34. plt.axhline(y=R_UCL, color='g', linestyle='--', label='上限控制限')
    35. plt.title('R图')
    36. plt.xlabel('样本编号')
    37. plt.ylabel('范围 (R)')
    38. plt.legend()
    39. plt.grid()
    40. plt.tight_layout()
    41. plt.show()

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

  • 相关阅读:
    Springboot毕业设计毕设作品,微信校园疫情防控小程序设计与实现
    【JAVA数据类型】
    中介子方程二十二
    【Leetcode】573. Squirrel Simulation
    关于ABB速度,加速度,轴监控指令
    docker 学习
    华为云云耀云服务器L实例评测|华为云上的CentOS性能监测与调优指南
    内裤洗衣机到底值不值得买?四款公认好用的内衣洗衣机推荐
    C++笔记 05
    在Centos上配置bgp路由
  • 原文地址:https://blog.csdn.net/book_dw5189/article/details/133153507