许可优化
许可优化
产品
产品
解决方案
解决方案
服务支持
服务支持
关于
关于
软件库
当前位置:服务支持 >  软件文章 >  SPC控制图:用Pandas和Matplotlib绘制X-bar控制图

SPC控制图:用Pandas和Matplotlib绘制X-bar控制图

阅读数 6
点赞 0
article_banner

@anniehan333 问到怎么用Python画分组的 X -bar控制图,题目如下:(来自她正在编写的书籍)


   这是她用 MiniTab 画的图:


   以下是Python实现过程:

主要是用pandas的groupby来实现分组子图

代码 整合:

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt


"""字典形式导入数据"""
x1 = {'Measure_1': [28.4,28.9,29.0,28.4,28.6], 
      'Measure_2': [28.4,29.0,29.1,28.5,28.6], 
      'Measure_3': [28.4,29.0,29.1,28.5,28.6]}   # A测定员
x2 = {'Measure_1': [28.5,28.8,29.0,28.5,28.6], 
      'Measure_2': [28.4,28.9,29.0,28.5,28.6], 
      'Measure_3': [28.4,28.8,29.0,28.5,28.6]}   # B测定员
x3 = {'Measure_1': [28.4,28.9,28.9,28.4,28.6], 
      'Measure_2': [28.5,28.9,28.9,28.5,28.7], 
      'Measure_3': [28.5,28.9,29.0,28.4,28.7]}   # C测定员


"""数据转换成DataFrame存储方便画图"""
df1 = pd.DataFrame(x1)
x1_bar = df1.mean().mean()
R1 = (df1.max(axis=1) - df1.min(axis=1)).sum()/5
df1['sample_no'] = ['#'+str(i) for i in range(1,6)]
df1['researcher'] = 'A'

df2 = pd.DataFrame(x2)
x2_bar = df2.mean().mean()
R2 = (df2.max(axis=1) - df2.min(axis=1)).sum()/5
df2['sample_no'] = ['#'+str(i) for i in range(1,6)]
df2['researcher'] = 'B'

df3 = pd.DataFrame(x3)
x3_bar = df3.mean().mean()
R3 = (df3.max(axis=1) - df3.min(axis=1)).sum()/5
df3['sample_no'] = ['#'+str(i) for i in range(1,6)]
df3['researcher'] = 'C'

df = pd.concat([df1,df2,df3],ignore_index=True)     # ABC测定员3组数据连接在同一张表


"""X-bar Chart"""
A2 = 1.023
xbarbar = (x1_bar+x2_bar+x3_bar)/3
rbar = (R1+R2+R3)/3
ucl = xbarbar + A2 * rbar
lcl = xbarbar - A2 * rbar

grouped = df.groupby('researcher')    # 按照researcher来分组
fig, axes = plt.subplots(nrows=1, ncols=3, figsize=(16,4), sharey=True)     # 定义包含1行3列子图
fig.suptitle('Xbar Chart', fontsize=18, y=0)

for (key, ax) in zip(grouped.groups.keys(), axes.flatten()):
    df_group = grouped.get_group(key)[['Measure_1','Measure_2','Measure_3']].mean(axis=1)
    df_group.index = range(1,6)     # 取样本编号1,2,3,4,5作为x轴
    df_group.plot(ax=ax, xticks=df_group.index, title=key, label='sample', style='go-', linewidth=2)    # sample
    ax.plot(range(1,6),xbarbar*np.ones(5),'k',label=r'$\bar\bar{x}$')    # xbar
    ax.plot(range(1,6),ucl*np.ones(5), label='UCL')      # ucl
    ax.plot(range(1,6),lcl*np.ones(5), label='LCL')      # lcl
    ax.legend()
    ax.grid(False)     # 隐藏网格

画图效果:


免责声明:本文系网络转载或改编,未找到原创作者,版权归原作者所有。如涉及版权,请联系删


相关文章
技术文档
QR Code
微信扫一扫,欢迎咨询~
customer

online

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 board-phone 155-2731-8020
close1
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

姓名不为空

姓名不为空
手机不正确

手机不正确

手机不正确
公司不为空

公司不为空

公司不为空