Skip to main content

A Python helper library for generating Process Behaviour Charts

Project description

statprocon

statprocon is a Python helper library for generating data for use in Statistical Process Control charts. SPC charts are also known as Process Behaviour Charts, Control charts or Shewhart charts.

SPC Charts help answer questions like:

  • How do I know a change has occurred in a process?
  • What is the expected variation in a process?
  • Is a process stable or unpredictable?

Installation

pip install statprocon

Usage

from statprocon import XmR

counts = [10, 50, 40, 30]

xmr = XmR(counts)
moving_ranges = xmr.moving_ranges()
unpl = xmr.upper_natural_process_limit()[0]  # 85.7
lnpl = xmr.lower_natural_process_limit()[0]  # -20.7
x_cl = xmr.x_central_line()[0]  # 32.5

url = xmr.upper_range_limit()[0]  # 65.36
mr_cl = xmr.mr_central_line()[0]  # 20

Currently, this library only supports the data for generating an XmR chart. An XmR chart is the most universal way of using process behaviour charts. XmR is short for individual values (X) and a moving range (mR). More chart data options can be added via pull requests.

For more information, please read Making Sense of Data by Donald Wheeler.

pandas

Visualize XmR charts using Jupyter Notebooks and pandas

import pandas as pd
from statprocon import XmR

xmr = XmR(counts)

pd.DataFrame(xmr.x_to_dict()).astype(float).plot()
pd.DataFrame(xmr.mr_to_dict()).astype(float).plot()

Screenshot from 2023-07-22 13-53-22

Charts can display X-axis labels by using the following code:

labels = ['0', '1', '2', '3']
pd.DataFrame(xmr.x_to_dict(), index=labels).astype(float).plot()

Or use built-in methods to generate charts that highlight detection points:

import pandas as pd

labels = ['J', 'F', 'M', ...]
xmr = XmR(counts)
xmr.x_plot(pd, labels)
xmr.mr_plot(pd, labels)

Screenshot from 2023-09-10 11-27-40

Data points that meet detection rules are marked by the following colours:

Rule Colour
Rule 1 Red
Rule 2 Green
Rule 3 Orange

If one data point meets the criteria for multiple detection rules, the lower numbered detection rule will take priority and be marked. For example, if a data point meets all detection rules, it will be displayed in red. If a data point meets rule 2 and rule 3, it will be displayed in green.

CSV

Generate a CSV of all the data needed to create XmR charts.

print(xmr.to_csv())

Google Sheets Charts

Generate XmR Charts in Google Sheets

https://github.com/mattmccormick/statprocon/assets/436801/0de1a9f3-a8ad-4047-8c9d-0f890e0bf453

  1. Make a copy of the statprocon XmR Template sheet
  2. Paste the CSV output from above into cell A1
  3. Click Data -> Split Text to Columns

The X and MR charts will appear on the right.

Note that the Lower Natural Process Limit may not make sense if your count data could not possibly go negative. If LNPL is not needed, remove it with the following steps:

  1. Double-click on the X Chart
  2. Click the Setup tab
  3. Under Series, find LNPL
  4. Click the 3 dot menu on the right next to LNPL
  5. Click Remove

The LNPL line will be removed from the X Chart.

Advanced Usage

Halfway Lines

Halfway lines between the X central line and the Upper and Lower Natural Process Limits can be returned by using the include_halfway_lines argument:

xmr.x_to_dict(include_halfway_lines=True)

When the process is predictable, approximately 85% of the X values fall between the Upper and Lower halfway lines.

Trending Limits

With data points that trend upwards or downwards over time, use Trending Limits to calculate a sloping X central line, Upper Natural Process Limits and Lower Natural Process Limits.

from statprocon import XmRTrending

counts = [...]  # data from TrendingTestCase.test_trending_limits

source = XmR(counts)
trending = XmRTrending(source)
pd.DataFrame(trending.x_to_dict()).astype(float).plot()

trending-limits

Use the Median Moving Range

If your data contains extreme outliers, it may be better to compute the limits using the median moving range.

xmr = XmR(counts, moving_range_uses='median')

Use the Median for the X Central Line

xmr = XmR(counts, x_central_line_uses='median')

Note: It's assumed that by using the median for the X central line that the median moving range should also be used. For example, you cannot do the following:

xmr = XmR(counts, x_central_line_uses='median', moving_range_uses='average')

Calculate Limits from Subset of Counts

The central lines and limits calculations can be restricted to a subset of the count data. Use the subset_start_index and subset_end_index parameters when instantiating the XmR object:

xmr = XmR(counts, subset_start_index=10, subset_end_index=34)  # 24 points of data starting at index 10

When one or both of these optional arguments are provided, the the X and MR central line calculations will be modified to only use the data from subset_start_index up to, but not including, subset_end_index. When these optional arguments are not provided, subset_start_index defaults to 0 and subset_end_index defaults to the length of counts.

Dependencies

There are a few other Python libraries for generating SPC charts but they all contain large dependencies in order to include the ability to graph the chart. This package will remain small and light and not require large dependencies. The user will need to convert the data into charts on their own.

This package also contains extensive tests for verifying the integrity of the calculated data.


Development

Create virtualenv

python3 -m venv venv

Activate virtualenv

source venv/bin/activate

Build

python -m build

Upload

python -m twine upload dist/statprocon-x.y.z*

Testing

Install package from source

python3 -m pip install .

Run tests

tox

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

statprocon-1.0.2.tar.gz (19.0 kB view details)

Uploaded Source

Built Distribution

statprocon-1.0.2-py3-none-any.whl (12.5 kB view details)

Uploaded Python 3

File details

Details for the file statprocon-1.0.2.tar.gz.

File metadata

  • Download URL: statprocon-1.0.2.tar.gz
  • Upload date:
  • Size: 19.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.10.12

File hashes

Hashes for statprocon-1.0.2.tar.gz
Algorithm Hash digest
SHA256 a8a01c9565d64f20eaf9d1ddb59d48570bd5c3a619363daa47420ddf80e587cb
MD5 2bd97438994e45f5c94b004008505863
BLAKE2b-256 8178cdbf26c7e3633aa832af615c48bcfa82c8a28cc6a58ab6f5c331294ad3b2

See more details on using hashes here.

File details

Details for the file statprocon-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: statprocon-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 12.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.10.12

File hashes

Hashes for statprocon-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 3ddd2a92404da32820339556ee59c70e7163d6a0fbce6ee273006783c61ec3e5
MD5 40ddcd1f2b079070638538b62629a1f0
BLAKE2b-256 7417146e08a1c3b64cf44913af2a52ab43e6fcff90ec17ae3060064f268a3867

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page