R/qcs.R.r

Defines functions qcs.R.qcd qcs.R.default qcs.R

Documented in qcs.R qcs.R.default qcs.R.qcd

#-----------------------------------------------------------------------------#
#                                                                             #
#                  QUALITY CONTROL STATISTICS IN R                            #
#                                                                             #
#  An R package for statistical in-line quality control.                      #
#                                                                             #
#  Written by: Miguel A. Flores Sanchez                                       #
#              Professor of Mathematic Department                             #
#              Escuela Politecnica Nacional, Ecuador                          #
#              miguel.flores@epn.edu.ec                                       #
#                                                                             #
#-----------------------------------------------------------------------------#
  #-------------------------------------------------------------------------
  # R chart
  #-------------------------------------------------------------------------
  ##' Function to plot Shewhart R chart
  ##'
  ##' This function is used to compute statistics required by the R chart.
  ##'
  ##' @param x   An object of class "qcd".
  ##' @param ... Arguments passed to or from methods.
  ##' @export
  ##' @examples
  ##' 
  ##' ##
  ##' ##  Continuous data 
  ##' ##
  ##'library(qcr)
  ##'data(pistonrings)
  ##'str(pistonrings)
  ##'pistonrings.qcd<-qcd(pistonrings)
  ##'
  ##'class(pistonrings.qcd)
  ##'
  ##'res.qcs <- qcs.R(pistonrings.qcd)
  ##'class(res.qcs)
  ##'plot(res.qcs,title="Control Chart R for pistonrings")
  ##'summary(res.qcs)  
  ##'
  qcs.R <- function(x, ...) {
    UseMethod("qcs.R")
  }

  ##' @rdname qcs.R
  ##' @method qcs.R default
  ##' @inheritParams qcd
  ##' @param center A value specifying the center of group statistics or the
  ##' ''target'' value of the process.
  ##' @param std.dev  A value or an available method specifying the within-group standard
  ##' deviation(s) of the process. Several methods are available for estimating the
  ##' standard deviation in case of a continuous process variable.
  ##' @param conf.nsigma  A numeric value used to compute control limits, specifying the
  ##' number of standard deviations (if \code{conf.nsigma} > 1) or the confidence level (if 0
  ##' < \code{conf.nsigma} < 1).
  ##' @param limits A two-values vector specifying control limits.
  ##' @param plot Logical value. If \code{TRUE} a R chart should be plotted.
  ## @details
  ## In the default method \code{qcs.R.default} parameter \code{x} is a matrix
  ## or data-frame where it should contain data, index sample and, optionally, covariate(s).
  ##' @seealso
  ##' \code{\link{qcs}}, \code{\link{qcd}}
  ##' @export
  qcs.R.default <- function(x, var.index  =  1, sample.index  =  2,
                            covar.index  =  NULL, covar.names  =  NULL,
                            data.name = NULL,
                            sizes  =  NULL,
                            center = NULL,
                            std.dev  =  c("UWAVE-R", "MVLUE-R"),
                            conf.nsigma  =  3, limits = NULL, plot = FALSE, ...)
#.........................................................................
    {
    if (!is.numeric(std.dev))
      std.dev <- match.arg(std.dev)

    obj<-qcd(data= x, var.index = var.index, sample.index = sample.index,
             covar.index = covar.index, covar.names = covar.names,
             data.name = data.name, sizes = sizes)
    
    result<-qcs.R.qcd(x = obj,  center = center, std.dev = std.dev,
                         conf.nsigma = conf.nsigma, 
                         limits = limits, plot = plot)  
    return(result)
    #.........................................................................
  } # qcs.R.default
#.........................................................................  
  
  ##' @rdname  qcs.R
  ##' @method qcs.R qcd
  # @inheritParams qcs.S.default
  ##' @export
  ##' 
  qcs.R.qcd <- function(x, center = NULL,
                        std.dev = c("UWAVE-R", "MVLUE-R"),
                        conf.nsigma  =  3, limits = NULL, plot = FALSE, ...) 
#.........................................................................  
    {
    #.........................................................................
    if (!is.numeric(std.dev))
      std.dev <- match.arg(std.dev)
    
    if(is.null(x) || !inherits(x, "qcd"))
      stop("data must be an objects of class (or extending) 'qcd'")
    
    sizes <- x$sizes
    type.data <- "continuous"
    
    
    qcs<-qcs(x$x, x$sample, sizes, type  =  "R",
             center, std.dev, conf.nsigma, limits, type.data)
    
    center <- qcs$center
    R <- qcs$statistics
    std.dev <- qcs$std.dev
    sizes <- qcs$sizes
    limits <- qcs$limits
    violations <- qcs$violations
    
    statistics <- data.frame(R)
    m <- length(x)
    sample <- x$sample
    if (m > 3) {
      new.x <- x[, -c(1, 2, length(x))]
      cov <- apply(new.x, 2, function(x) unlist(lapply(split(x, sample), unique)))
      statistics <- data.frame(R, cov)
    }
    
    row.names(statistics) <- unique(x$sample)
    data.name <- attr(x, "data.name")
    result <- list(qcd  =  x, type  =  "R", statistics  =  statistics,
                   center  =  center, std.dev  =  std.dev,
                   limits  =  limits, conf.nsigma  =  conf.nsigma,
                   sizes  =  sizes, data.name  =  data.name,
                   violations  =  violations)
    
    oldClass(result) <- c("qcs.R", "qcs")
    
    if(plot) plot(result, ...)
    
    return(result)
    #.........................................................................
  } # qcs.R.qcd
#.........................................................................  
mflores72000/qcr documentation built on July 1, 2023, 9:17 p.m.