knitr::opts_chunk$set( dev = "png", dpi = 150, fig.asp = 0.618, fig.width = 5, out.width = "60%", fig.align = "center", comment = NA, collapse = TRUE, comment = "#>" )
library(qcr)
Exploramos los datos de la base pistonrings
Los datos están en el data frame pistonrings que consta de 200 observaciones medidas en 25 muestras cada una de tamaño 5.
data(pistonrings) attach(pistonrings) summary(pistonrings) boxplot(diameter ~ sample) plot(sample, diameter, cex=0.7) lines(tapply(diameter,sample,mean)) detach(pistonrings)
Podremos encontrar los valores de los límites de control $3\sigma$ para la media como:
$LCL = \bar{\bar{x}}-\frac{3}{\sqrt{n}d_2}\bar{R}=\bar{\bar{x}}-A_2\bar{R}$
$CL = \bar{\bar{x}}$
$UCL = \bar{\bar{x}}+\frac{3}{\sqrt{n}d_2}\bar{R}=\bar{\bar{x}}+A_2\bar{R}$
x <- droplevels(pistonrings[1:125,]) res.qcs <- qcs.xbar(x, data.name="pistonrings", std.dev = "UWAVE-R") plot(res.qcs, title = expression(paste("Gráfico de control para pistonrings:", bar(x)," ")))
x <- droplevels(pistonrings[1:125,]) res.qcs <- qcs.R(x, data.name="pistonrings",std.dev = "UWAVE-R") plot(res.qcs, title = "Gráfico de control para pistonrings: R")
Podremos encontrar los valores de los límites de control $3\sigma$ para la media como:
$LCL = \bar{\bar{x}}-\frac{3}{\sqrt{n}c_2}\bar{s}=\bar{\bar{x}}-A_1\bar{s}$
$CL = \bar{\bar{x}}$
$UCL = \bar{\bar{x}}+\frac{3}{\sqrt{n}c_2}\bar{s}=\bar{\bar{x}}+A_1\bar{s}$
x <- droplevels(pistonrings[1:125,]) res.qcs <- qcs.xbar(x, data.name = "pistonrings", std.dev = "UWAVE-SD") plot(res.qcs, title = expression(paste("Gráfico de control para pistonrings:", bar(x)," ")))
x <- droplevels(pistonrings[1:125,]) res.qcs <- qcs.S(x, data.name = "pistonrings", std.dev = "UWAVE-SD") plot(res.qcs, title = "Gráfico de control para pistonrings: S")
Para cada muestra, definimos la variable aleatoria fracción disconforme muestral como $\hat{p}_i=\frac{X_i}{n}$. Observar que $\hat{p}_i$ seguirá una distribución binomial con varianza:
$E(\hat{p}_i)=\frac{E(X_i)}{n}=p$
$Var(\hat{p}_i)=\frac{Var(X_i)}{n^2}=\frac{p(1-p)}{n}$.
Por tanto, $\lim_{n\rightarrow \infty}\hat{p}_i=N\left( p,\sqrt{\frac{p(1-p)}{n}} \right)$.
Si $p$ es desconocida, la podemos estimar:
$\bar{p}=\frac{1}{k}\sum_{i=1}^{k}\hat{p}_i$.
Según el modelo de Shewart tendremos que:
$LCL = \bar{p}-3\sqrt{\frac{\bar{p}(1-\bar{p})}{n}}$
$CL = \bar{p}$
$UCL = \bar{p}+3\sqrt{\frac{\bar{p}(1-\bar{p})}{n}}$
En caso de que el tamaño muestral ($n_i$) diferentes, el estimador para $p$ ser??a:
$\bar{p}=\frac{\sum_{i=1}^{k}n_i\hat{p}i}{\sum{i=1}^{k}n_i}.$
Datos
Jugo de naranja (orangejuice): Es un data frame con 54 Observaciones y 4 variables. Donde se mide el jugo de naranja concentrado congelado que se envasa en latas de cartón de 6 oz. Estas latas se forman en una máquina de hilatura. Una lata es inspeccionado para determinar si, cuando se llena, el líquido puede derramarse ya sea en la costura lateral o alrededor de la articulación de la parte inferior. Si esto ocurre, una lata se considera no conforme.
Se tomaron 30 muestras de 50 latas cada una en intervalos de media hora durante un período de tres turnos (la máquina estaba en funcionamiento continuo). A partir de la muestra 15 se utiliza un nuevo bacth de stock.
Las variables del data frame son:
data(orangejuice) str(orangejuice) datos.qcd <- qcd(data = orangejuice, var.index = 1, sample.index = 2, sizes = orangejuice$size, type.data = "atributte") res.qcs <- qcs.p(datos.qcd) summary(res.qcs) plot(res.qcs) datos.qcs <- qcs.p(orangejuice[orangejuice$trial,c(1,2)], sizes = orangejuice[orangejuice$trial,3]) plot(datos.qcs)
Para la construcción de este tipo de gráficos se estimarán las proporciones de la misma forma que en los gráficos P pero se construirán los gráficos basados en la media del proceso del siguiente modo:
$LCL = n\bar{p}-3\sqrt{\frac{n\bar{p}(1-\bar{p})}{n}}$
$CL = n\bar{p}$
$UCL = n\bar{p}+3\sqrt{\frac{n\bar{p}(1-\bar{p})}{n}}$
data(orangejuice) str(orangejuice) datos.qcd <- qcd(data = orangejuice, var.index = 1, sample.index = 2, sizes = orangejuice$size, type.data = "atributte") res.qcs <- qcs.np(datos.qcd) summary(res.qcs) plot(res.qcs) datos.qcs <- qcs.np(orangejuice[orangejuice$trial,c(1,2)], sizes = orangejuice[orangejuice$trial,3]) plot(datos.qcs)
Según el modelo de Shewart tendremos que:
$LCL = n_i\hat{u}-3\sqrt{{\hat{u}}{n_i}}$
$CL = n_i\hat{u}$
$UCL = n_i\hat{u}+3\sqrt{{\hat{u}}{n_i}}$
Como el tamaño muestral ($n_i$) es diferente para cada subgrupo, para calcular los límites podemos optar por distintos métodos.
Datos
Placas impresas (Circuit boards data): Número de no conformidades observadas en 26 muestras sucesivas de 100 placas de circuitos impresos. Muestra 6 y 20 están fuera de los límites de control. Muestra 6 fue examinado por un nuevo inspector que no había reconocido varios tipos de no conformidades.
Además, el número inusualmente grande de las no conformidades en la muestra 20 se debío a un problema de control de la temperatura en la máquina de soldadura, que fue reparado subsequentemente. Los últimos 20 muestras son otras muestras recogidas en las unidades de inspección (cada una formada por 100 paneles). Las variables del data frame son:
data(circuit) str(circuit) datos <- circuit datos$sample <- 1:length(datos$x) str(datos) datos.qcd <- qcd(data = datos, var.index = 1,sample.index = 2, sizes = 100, type.data = "atributte") res.qcs <- qcs.c(datos.qcd) summary(res.qcs) plot(res.qcs)
Los gráficos CUSUM se basan en la decisión de comprobar si el proceso está bajo control o no analizando toda o la mayor parte de la muestra. Para este fin se usará el estadístico $s_r$: [ s_r=\sum_{i=1}^{r}(\bar{x}_i-\mu_0). ]
Bajo supuestos de normalidad es evidente deducir la distribución del estadístico $s_r$: [ s_r\in N\left( r(\mu-\mu_0), \frac{r\sigma_0^2}{n} \right). ]
data(pistonrings) res.qcd <- qcd(pistonrings, type.data = "dependence") res.qcs <- qcs.cusum(res.qcd, type = "cusum") summary(res.qcs) plot(res.qcs)
Los límites de control y la línea central son entonces: $LCL = \mu_0-3\sigma\sqrt{\frac{\lambda(1-(1-\lambda)^{2i})}{2-\lambda}}$
$LCS = \mu_0$
$UCL = \mu_0+3\sigma\sqrt{\frac{\lambda(1-(1-\lambda)^{2i})}{2-\lambda}}$
Si $i$ es muy elevado se tiene que, aproximadamente,
$LCL = \mu_0-3\sigma\sqrt{\frac{\lambda}{2-\lambda}}$
$LCS = \mu_0$
$UCL = \mu_0+3\sigma\sqrt{\frac{\lambda}{2-\lambda}}$
data(pistonrings) res.qcd <- qcd(pistonrings, type.data = "dependence") res.qcs <- qcs.ewma(res.qcd, type = "ewma") summary(res.qcs) plot(res.qcs)
En la siguiente sección se presentan gráficos de control para monitorizar la tendencia central de la variable de calidad: diamétro de los aros de los pistones.
Se realiza un gráfico de medias para monitorizar el diámetro de los piston rings:
str(pistonrings) pistonrings.qcd<-qcd(pistonrings) class(pistonrings.qcd) res.qcs <- qcs.xbar(pistonrings.qcd) plot(res.qcs,title="Control Chart Xbar for pistonrings I", std.dev = "UWAVE-R") summary(res.qcs)
Se crea el objeto qcd (Quality Control Data) y el objeto qcs (Quality Control Statistics) del tipo xbar.
Con el comando summary se obtienen las estimaciones de la media y la varianza así como los límites de control y con el comando plot se realiza el correspondiente gráfico de control.
Además para indicar que el tipo de estimación de la varianza es por medio de Rangos, en la opción std.dev = "UWAVE-R" (método de estimación por defecto).
Se puede observar tres puntos que indican que el proceso está fuera de control. Dos de estos salen fuera de los límites de control y un punto que está dentro de los límites pero corresponde a una racha.
Por tanto, el proceso no esta bajo control. Se utiliza la función state.control que permite eliminar los puntos fuera de control y adempás devuelve un objeto del tipo qcd que se utiliza para construir un nuevo gráfico de control.
res.qcd <- state.control(res.qcs) res.qcs <- qcs.xbar(res.qcd) plot(res.qcs,title="Control Chart Xbar for pistonrings II") summary(res.qcs)
Aún existe un punto fuera de los límites de control. Se utiliza la función state.control para la eliminación de puntos fuera de control y se estiman los límites de control hasta que el proceso este bajo control, es decir, no existan puntos fuera de los límites o rachas.
res.qcd <- state.control(res.qcs) res.qcs <- qcs.xbar(res.qcd) plot(res.qcs,title="Control Chart Xbar for pistonrings III") summary(res.qcs)
En este ejemplo se parte de un proceso bajo control (Fase I) y una vez calculado los límites se realiza la monitorización del proceso (Fase II). Para la Fase I se considera las primeras 25 muestras de los datos de piston rings y para la Fase II se utilizan el resto de las muestras.
x <- droplevels(pistonrings[1:125,]) y <- droplevels(pistonrings[126:200,]) res.qcs <- qcs.xbar(x, data.name="Control Chart Xbar for pistonrings") plot(res.qcs) res.qcs <- qcs.add(x = res.qcs, value = y[,c(1,2)]) plot(res.qcs) summary(res.qcs)
x <- droplevels(pistonrings[1:125,]) res.qcs <- qcs.xbar(x, data.name="Control Chart Xbar for pistonrings") plot(res.qcs,conf.nsigma.alert=2)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.