Title: | Functional Control Charts |
---|---|
Description: | Provides functional control charts for statistical process monitoring of functional data, using the methods of Capezza et al. (2020) <doi:10.1002/asmb.2507>, Centofanti et al. (2021) <doi:10.1080/00401706.2020.1753581>, Capezza et al. (2024) <doi:10.1080/00401706.2024.2327346>, Capezza et al. (2024) <doi:10.1080/00224065.2024.2383674>, Centofanti et al. (2022) <doi:10.48550/arXiv.2205.06256>. The package is thoroughly illustrated in the paper of Capezza et al (2023) <doi:10.1080/00224065.2023.2219012>. |
Authors: | Christian Capezza [cre, aut], Fabio Centofanti [aut], Antonio Lepore [aut], Biagio Palumbo [aut], Alessandra Menafoglio [ctb], Simone Vantini [ctb] |
Maintainer: | Christian Capezza <[email protected]> |
License: | GPL-3 |
Version: | 1.6.0 |
Built: | 2024-12-12 06:47:40 UTC |
Source: | CRAN |
mfd
objects.Extract observations and/or variables from mfd
objects.
## S3 method for class 'mfd' mfdobj[i = TRUE, j = TRUE]
## S3 method for class 'mfd' mfdobj[i = TRUE, j = TRUE]
mfdobj |
An object of class |
i |
Index specifying functional observations to extract or replace.
They can be numeric, character,
or logical vectors or empty (missing) or NULL.
Numeric values are coerced to integer as by as.integer
(and hence truncated towards zero).
The can also be negative integers,
indicating functional observations to leave out of the selection.
Logical vectors indicate TRUE for the observations to select.
Character vectors will be matched
to the argument |
j |
Index specifying functional variables to extract or replace.
They can be numeric, logical,
or character vectors or empty (missing) or NULL.
Numeric values are coerced to integer as by as.integer
(and hence truncated towards zero).
The can also be negative integers,
indicating functional variables to leave out of the selection.
Logical vectors indicate TRUE for the variables to select.
Character vectors will be matched
to the argument |
This function adapts the fda::"[.fd"
function to be more robust and suitable
for the mfd
class.
In fact, whatever the number of observations
or variables you want to extract,
it always returns a mfd
object with a three-dimensional coef array.
In other words, it behaves as you would
always use the argument drop=FALSE
.
Moreover, you can extract observations
and variables both by index numbers and by names,
as you would normally do when using
`[`
with standard vector/matrices.
a mfd
object with selected observations and variables.
library(funcharts) library(fda) # In the following, we extract the first one/two observations/variables # to see the difference with `[.fd`. mfdobj <- data_sim_mfd() fdobj <- fd(mfdobj$coefs, mfdobj$basis, mfdobj$fdnames) # The argument `coef` in `fd` # objects is converted to a matrix when possible. dim(fdobj[1, 1]$coef) # Not clear what is the second dimension: # the number of replications or the number of variables? dim(fdobj[1, 1:2]$coef) dim(fdobj[1:2, 1]$coef) # The argument `coef` in `mfd` objects is always a three-dimensional array. dim(mfdobj[1, 1]$coef) dim(mfdobj[1, 1:2]$coef) dim(mfdobj[1:2, 1]$coef) # Actually, `[.mfd` works as `[.fd` when passing also `drop = FALSE` dim(fdobj[1, 1, drop = FALSE]$coef) dim(fdobj[1, 1:2, drop = FALSE]$coef) dim(fdobj[1:2, 1, drop = FALSE]$coef)
library(funcharts) library(fda) # In the following, we extract the first one/two observations/variables # to see the difference with `[.fd`. mfdobj <- data_sim_mfd() fdobj <- fd(mfdobj$coefs, mfdobj$basis, mfdobj$fdnames) # The argument `coef` in `fd` # objects is converted to a matrix when possible. dim(fdobj[1, 1]$coef) # Not clear what is the second dimension: # the number of replications or the number of variables? dim(fdobj[1, 1:2]$coef) dim(fdobj[1:2, 1]$coef) # The argument `coef` in `mfd` objects is always a three-dimensional array. dim(mfdobj[1, 1]$coef) dim(mfdobj[1, 1:2]$coef) dim(mfdobj[1:2, 1]$coef) # Actually, `[.mfd` works as `[.fd` when passing also `drop = FALSE` dim(fdobj[1, 1, drop = FALSE]$coef) dim(fdobj[1, 1:2, drop = FALSE]$coef) dim(fdobj[1:2, 1, drop = FALSE]$coef)
This data set has been included from the R package
FRegSigCom
.
The original .RData file is available at
https://github.com/cran/FRegSigCom/blob/master/data/air.RData.
Data collected hourly in 355 days (days with missing values removed) in a significantly polluted area within an Italian city.
data("air")
data("air")
A list of 7 matrices with 355 rows and 24 columns:
Hourly observation of concentration level of NO2 in 355 days
Hourly observation of concentration level of CO in 355 days
Hourly observation of concentration level of NMHC in 355 days
Hourly observation of concentration level of NOx in 355 days
Hourly observation of concentration level of C6H6 in 355 days
Hourly observation of concentration level of temperature in 355 days
Hourly observation of concentration level of humidity in 355 days
https://archive.ics.uci.edu/ml/datasets/Air+quality
De Vito, S., Massera E., Piga M., Martinotto L. and Di Francia G. (2008). On field calibration of an electronic nose for benzene estimation in an urban pollution monitoring scenario Sensors and Actuators B: Chemical, 129: 50-757. doi:10.1016/j.snb.2007.09.060
Xin Qi and Ruiyan Luo (2019). Nonlinear function on function additive model with multiple predictor curves. Statistica Sinica, 29:719-739. doi:10.5705/ss.202017.0249
This function performs Phase I of the Adaptive Multivariate Functional EWMA (AMFEWMA) control chart proposed by Capezza et al. (2024)
AMFEWMA_PhaseI( mfdobj, mfdobj_tuning, lambda = NULL, k = NULL, ARL0 = 200, bootstrap_pars = list(n_seq = 200, l_seq = 2000), optimization_pars = list(lambda_grid = c(0.1, 0.2, 0.3, 0.5, 1), k_grid = c(1, 2, 3, 4), epsilon = 0.1, sd_small = 0.25, sd_big = 2), discrete_grid_length = 25, score_function = "huber", fev = 0.9, n_skip = 100 )
AMFEWMA_PhaseI( mfdobj, mfdobj_tuning, lambda = NULL, k = NULL, ARL0 = 200, bootstrap_pars = list(n_seq = 200, l_seq = 2000), optimization_pars = list(lambda_grid = c(0.1, 0.2, 0.3, 0.5, 1), k_grid = c(1, 2, 3, 4), epsilon = 0.1, sd_small = 0.25, sd_big = 2), discrete_grid_length = 25, score_function = "huber", fev = 0.9, n_skip = 100 )
mfdobj |
An object of class |
mfdobj_tuning |
An object of class |
lambda |
lambda parameter to be used in the score function.
See Equation (7) or (8) of Capezza et al. (2024).
If it is provided, it must be a number between zero and one.
If NULL, it is chosen through the selected according to the
optimization procedure presented in Section 2.4 of Capezza et al. (2024).
In this case, it is chosen among the values of
|
k |
k parameter to be used in the score function.
See Equation (7) or (8) of Capezza et al. (2024).
If it is provided, it must be a number greater than zero.
If NULL, it is chosen through the selected according to the
optimization procedure presented in Section 2.4 of Capezza et al. (2024).
In this case, it is chosen among the values of
|
ARL0 |
The nominal in-control average run length. Default value is 200. |
bootstrap_pars |
Parameters of the bootstrap procedure described in
Section 2.4 of Capezza et al. (2024) for the estimation of the
control chart limit.
It must be a list with two arguments.
|
optimization_pars |
Parameters to be used in the optimization procedure described in Section
2.4 of Capezza et al. (2024) for the selection of the parameters
lambda and k.
It must be a list of the following parameters.
|
discrete_grid_length |
The number of equally spaced argument values at which the |
score_function |
Score function to be used in Equation (7) or (8) of Capezza et al. (2024), to calculate the weighting parameter of the EWMA statistic for each observation of the sequence. Two values are possible. If "huber", it uses the score function (7) inspired by the Huber's function. If "tukey", it uses the score function (8) inspired by the Tukey's bisquare function. |
fev |
Number between 0 and 1 denoting the fraction
of variability that must be explained by the
principal components to be selected after
applying multivariate functional principal component analysis
on |
n_skip |
The upper control limit of the AMFEWMA control chart is set
to achieve a desired in-control ARL, evaluated after the
monitoring statistic has reached steady state.
A monitoring statistic is in a steady state
if the process has been in control long enough
for the effect of the starting value to become negligible
(Lucas and Saccucci, 1990).
In this regard, the first |
A list with the following elements.
lambda
is the selected lambda parameter.
k
is the selected k parameter.
mod_1
contains the estimated Phase I model. It is a list with
the following elements.
mfdobj
the mfdobj
object passed as input to this function,
mfdobj_tuning
the mfdobj_tuning
object
passed as input to this function,
inv_sigmaY_reg
: the matrix containing the discretized
version of the function K^*(s,t) defined in Equation (9) of
Capezza et al. (2024),
mean_mfdobj
: the estimated mean function,
h
: the calculated upper control limit of the AMFEWMA control chart,
ARL0
: the estimated in-control ARL, which should be close to the
nominal value passed as input to this function,
lambda
: the lambda parameter selected by the optimization
procedure described in Section 2.4 of Capezza et al. (2024).
k
: The function C_j(t)=k sigma_j(t) appearing in the score
functions (7) and (8) of Capezza et al. (2024).
grid_points
: the grid containing the points over which
the functional data are discretized before computing the AMFEWMA monitoring
statistic and estimating all the model parameters.
V2_mat
: the n_seq
Xl_seq
matrix containing,
in each column, the AMFEWMA monitoring statistic values of each
bootstrap sequence.
This matrix is used to set the control chart limit h
to
ensure that the desired average run length is achieved.
n_skip
: the n_skip
input parameter passed to this function,
huber
: if the input parameter score_function
is
"huber"
, this is TRUE, else is FALSE,
vectors
: the discretized eigenfunctions psi_l(t) of
the covariance function, appearing in Equation (9) of Capezza et al. (2024).
values
: the eigenvalues rho_l of
the covariance function, appearing in Equation (9) of Capezza et al. (2024).
C. Capezza, F. Centofanti
Capezza, C., Capizzi, G., Centofanti, F., Lepore, A., Palumbo, B. (2024) An Adaptive Multivariate Functional EWMA Control Chart. To appear in Journal of Quality Technology, doi:10.1080/00224065.2024.2383674.
Lucas, J. M., Saccucci, M. S. (1990) Exponentially weighted moving average control schemes: properties and enhancements. Technometrics, 32(1), 1-12.
## Not run: set.seed(0) library(funcharts) dat_I <- simulate_mfd(nobs = 1000, correlation_type_x = c("Bessel", "Bessel", "Bessel"), sd_x = c(0.3, 0.3, 0.3)) dat_tun <- simulate_mfd(nobs = 1000, correlation_type_x = c("Bessel", "Bessel", "Bessel"), sd_x = c(0.3, 0.3, 0.3)) dat_II <- simulate_mfd(nobs = 200, correlation_type_x = c("Bessel", "Bessel", "Bessel"), shift_type_x = c("C", "C", "C"), d_x = c(2, 2, 2), sd_x = c(0.3, 0.3, 0.3)) mfdobj_I <- get_mfd_list(dat_I$X_list) mfdobj_tun <- get_mfd_list(dat_tun$X_list) mfdobj_II <- get_mfd_list(dat_II$X_list) p <- plot_mfd(mfdobj_I[1:100]) lines_mfd(p, mfdobj_II, col = "red") mod <- AMFEWMA_PhaseI(mfdobj = mfdobj_I, mfdobj_tuning = mfdobj_tun) print(mod$k) cc <- AMFEWMA_PhaseII(mfdobj_2 = rbind_mfd(mfdobj_I[1:100], mfdobj_II), mod_1 = mod) plot_control_charts(cc$cc, nobsI = 100) ## End(Not run)
## Not run: set.seed(0) library(funcharts) dat_I <- simulate_mfd(nobs = 1000, correlation_type_x = c("Bessel", "Bessel", "Bessel"), sd_x = c(0.3, 0.3, 0.3)) dat_tun <- simulate_mfd(nobs = 1000, correlation_type_x = c("Bessel", "Bessel", "Bessel"), sd_x = c(0.3, 0.3, 0.3)) dat_II <- simulate_mfd(nobs = 200, correlation_type_x = c("Bessel", "Bessel", "Bessel"), shift_type_x = c("C", "C", "C"), d_x = c(2, 2, 2), sd_x = c(0.3, 0.3, 0.3)) mfdobj_I <- get_mfd_list(dat_I$X_list) mfdobj_tun <- get_mfd_list(dat_tun$X_list) mfdobj_II <- get_mfd_list(dat_II$X_list) p <- plot_mfd(mfdobj_I[1:100]) lines_mfd(p, mfdobj_II, col = "red") mod <- AMFEWMA_PhaseI(mfdobj = mfdobj_I, mfdobj_tuning = mfdobj_tun) print(mod$k) cc <- AMFEWMA_PhaseII(mfdobj_2 = rbind_mfd(mfdobj_I[1:100], mfdobj_II), mod_1 = mod) plot_control_charts(cc$cc, nobsI = 100) ## End(Not run)
This function performs Phase II of the Adaptive Multivariate Functional EWMA (AMFEWMA) control chart proposed by Capezza et al. (2024)
AMFEWMA_PhaseII(mfdobj_2, mod_1, n_seq_2 = 1, l_seq_2 = 2000)
AMFEWMA_PhaseII(mfdobj_2, mod_1, n_seq_2 = 1, l_seq_2 = 2000)
mfdobj_2 |
An object of class |
mod_1 |
The output of the Phase I achieved through the
|
n_seq_2 |
If it is 1, the Phase II monitoring statistic is calculated on
the data sequence.
If it is an integer number larger than 1, a number |
l_seq_2 |
If |
A list with the following elements.
ARL_2
: the average run length estimated over the
bootstrap sequences. If n_seq_2
is 1, it is simply the run length
observed over the Phase II sequence, i.e., the number of observations
up to the first alarm,
RL
: the run length
observed over the Phase II sequence, i.e., the number of observations
up to the first alarm,
V2
: a list with length n_seq_2
, containing the
AMFEWMA monitoring statistic in Equation (8) of Capezza
et al. (2024), calculated in each bootstrap sequence, until the first alarm.
cc
: a data frame with the information needed to plot the
AMFEWMA control chart in Phase II, with the following columns.
id
contains the id of each multivariate functional observation,
amfewma_monitoring_statistic
contains the AMFEWMA monitoring
statistic values calculated on the Phase II sequence,
amfewma_monitoring_statistic_lim
is the upper control limit.
C. Capezza, F. Centofanti
Capezza, C., Capizzi, G., Centofanti, F., Lepore, A., Palumbo, B. (2024) An Adaptive Multivariate Functional EWMA Control Chart. To appear in Journal of Quality Technology, doi:10.1080/00224065.2024.2383674.
## Not run: set.seed(0) library(funcharts) dat_I <- simulate_mfd(nobs = 1000, correlation_type_x = c("Bessel", "Bessel", "Bessel"), sd_x = c(0.3, 0.3, 0.3)) dat_tun <- simulate_mfd(nobs = 1000, correlation_type_x = c("Bessel", "Bessel", "Bessel"), sd_x = c(0.3, 0.3, 0.3)) dat_II <- simulate_mfd(nobs = 200, correlation_type_x = c("Bessel", "Bessel", "Bessel"), shift_type_x = c("C", "C", "C"), d_x = c(2, 2, 2), sd_x = c(0.3, 0.3, 0.3)) mfdobj_I <- get_mfd_list(dat_I$X_list) mfdobj_tun <- get_mfd_list(dat_tun$X_list) mfdobj_II <- get_mfd_list(dat_II$X_list) p <- plot_mfd(mfdobj_I[1:100]) lines_mfd(p, mfdobj_II, col = "red") mod <- AMFEWMA_PhaseI(mfdobj = mfdobj_I, mfdobj_tuning = mfdobj_tun) print(mod$lambda) print(mod$k) cc <- AMFEWMA_PhaseII(mfdobj_2 = rbind_mfd(mfdobj_I[1:100], mfdobj_II), mod_1 = mod) plot_control_charts(cc$cc, nobsI = 100) ## End(Not run)
## Not run: set.seed(0) library(funcharts) dat_I <- simulate_mfd(nobs = 1000, correlation_type_x = c("Bessel", "Bessel", "Bessel"), sd_x = c(0.3, 0.3, 0.3)) dat_tun <- simulate_mfd(nobs = 1000, correlation_type_x = c("Bessel", "Bessel", "Bessel"), sd_x = c(0.3, 0.3, 0.3)) dat_II <- simulate_mfd(nobs = 200, correlation_type_x = c("Bessel", "Bessel", "Bessel"), shift_type_x = c("C", "C", "C"), d_x = c(2, 2, 2), sd_x = c(0.3, 0.3, 0.3)) mfdobj_I <- get_mfd_list(dat_I$X_list) mfdobj_tun <- get_mfd_list(dat_tun$X_list) mfdobj_II <- get_mfd_list(dat_II$X_list) p <- plot_mfd(mfdobj_I[1:100]) lines_mfd(p, mfdobj_II, col = "red") mod <- AMFEWMA_PhaseI(mfdobj = mfdobj_I, mfdobj_tuning = mfdobj_tun) print(mod$lambda) print(mod$k) cc <- AMFEWMA_PhaseII(mfdobj_2 = rbind_mfd(mfdobj_I[1:100], mfdobj_II), mod_1 = mod) plot_control_charts(cc$cc, nobsI = 100) ## End(Not run)
Bind variables of two Multivariate Functional Data Objects
cbind_mfd(mfdobj1, mfdobj2)
cbind_mfd(mfdobj1, mfdobj2)
mfdobj1 |
An object of class mfd, with the same number of replications of mfdobj2 and different variable names with respect to mfdobj2. |
mfdobj2 |
An object of class mfd, with the same number of replications of mfdobj1, and different variable names with respect to mfdobj1. |
An object of class mfd, whose replications are the same of mfdobj1 and mfdobj2 and whose functional variables are the union of the functional variables in mfdobj1 and mfdobj2.
library(funcharts) mfdobj1 <- data_sim_mfd(nvar = 3) mfdobj2 <- data_sim_mfd(nvar = 2) dimnames(mfdobj2$coefs)[[3]] <- mfdobj2$fdnames[[3]] <- c("var10", "var11") plot_mfd(mfdobj1) plot_mfd(mfdobj2) mfdobj_cbind <- cbind_mfd(mfdobj1, mfdobj2) plot_mfd(mfdobj_cbind)
library(funcharts) mfdobj1 <- data_sim_mfd(nvar = 3) mfdobj2 <- data_sim_mfd(nvar = 2) dimnames(mfdobj2$coefs)[[3]] <- mfdobj2$fdnames[[3]] <- c("var10", "var11") plot_mfd(mfdobj1) plot_mfd(mfdobj2) mfdobj_cbind <- cbind_mfd(mfdobj1, mfdobj2) plot_mfd(mfdobj_cbind)
This function produces a contribution plot from functional control charts for a given observation of a phase II data set, using ggplot.
cont_plot(cclist, id_num, which_plot = c("T2", "spe"), print_id = FALSE)
cont_plot(cclist, id_num, which_plot = c("T2", "spe"), print_id = FALSE)
cclist |
A |
id_num |
An index number giving the observation in the phase II data set to be plotted, i.e. 1 for the first observation, 2 for the second, and so on. |
which_plot |
A character vector. Each value indicates which contribution you want to plot: "T2" indicates contribution to the Hotelling's T2 statistic, "spe" indicates contribution to the squared prediction error statistic. |
print_id |
A logical value, if TRUE, it prints also the id of the observation in the title of the ggplot. Default is FALSE. |
A ggplot containing the contributions of functional variables to the monitoring statistics. Each plot is a bar plot, with bars corresponding to contribution values and horizontal black segments denoting corresponding (empirical) upper limits. Bars are coloured by red if contributions exceed their limit.
library(funcharts) data("air") air <- lapply(air, function(x) x[201:300, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:60] y_tuning <- y[61:90] y2 <- y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod <- sof_pc(y1, mfdobj_x1) cclist <- regr_cc_sof(object = mod, y_new = y2, mfdobj_x_new = mfdobj_x2, y_tuning = y_tuning, mfdobj_x_tuning = mfdobj_x_tuning, include_covariates = TRUE) get_ooc(cclist) cont_plot(cclist, 3)
library(funcharts) data("air") air <- lapply(air, function(x) x[201:300, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:60] y_tuning <- y[61:90] y2 <- y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod <- sof_pc(y1, mfdobj_x1) cclist <- regr_cc_sof(object = mod, y_new = y2, mfdobj_x_new = mfdobj_x2, y_tuning = y_tuning, mfdobj_x_tuning = mfdobj_x_tuning, include_covariates = TRUE) get_ooc(cclist) cont_plot(cclist, 3)
This function builds a data frame needed to plot the Hotelling's T2 and squared prediction error (SPE) control charts based on multivariate functional principal component analysis (MFPCA) performed on multivariate functional data, as Capezza et al. (2020) for the multivariate functional covariates. The training data have already been used to fit the model. An optional tuning data set can be provided to estimate the control chart limits. A phase II data set contains the observations to be monitored with the control charts.
control_charts_pca( pca, components = NULL, tuning_data = NULL, newdata, alpha = 0.05, limits = "standard", seed, nfold = 5, ncores = 1, tot_variance_explained = 0.9, single_min_variance_explained = 0, absolute_error = FALSE )
control_charts_pca( pca, components = NULL, tuning_data = NULL, newdata, alpha = 0.05, limits = "standard", seed, nfold = 5, ncores = 1, tot_variance_explained = 0.9, single_min_variance_explained = 0, absolute_error = FALSE )
pca |
An object of class |
components |
A vector of integers with the components over which
to project the multivariate functional data.
If this is not NULL, the arguments |
tuning_data |
An object of class |
newdata |
An object of class |
alpha |
If it is a number between 0 and 1,
it defines the overall type-I error probability and the Bonferroni
correction is applied by setting the type-I error probability
in the two control charts equal to |
limits |
A character value.
If "standard", it estimates the control limits on the tuning
data set. If "cv", the function calculates the control limits only on the
training data using cross-validation
using |
seed |
If |
nfold |
If |
ncores |
If |
tot_variance_explained |
The minimum fraction of variance that has to be explained by the set of multivariate functional principal components retained into the MFPCA model fitted on the functional covariates. Default is 0.9. |
single_min_variance_explained |
The minimum fraction of variance that has to be explained by each multivariate functional principal component such that it is retained into the MFPCA model. Default is 0. |
absolute_error |
If FALSE, the SPE statistic, which monitors the principal components not retained in the MFPCA model, is calculated as the sum of the integrals of the squared prediction error functions, obtained as the difference between the actual functions and their approximation after projection over the selected principal components. If TRUE, the SPE statistic is calculated by replacing the square of the prediction errors with the absolute value, as proposed by Capizzi and Masarotto (2018). Default value is FALSE. |
A data.frame
with as many rows as the number of
multivariate functional observations in the phase II data set and
the following columns:
one id
column identifying the multivariate functional observation
in the phase II data set,
one T2
column containing the Hotelling T2 statistic
calculated for all observations,
one column per each functional variable, containing its contribution to the T2 statistic,
one spe
column containing the SPE statistic calculated
for all observations,
one column per each functional variable, containing its contribution to the SPE statistic,
T2_lim
gives the upper control limit of
the Hotelling's T2 control chart,
one contribution_T2_*_lim
column per each
functional variable giving the
limits of the contribution of that variable
to the Hotelling's T2 statistic,
spe_lim
gives the upper control limit of the SPE control chart
one contribution_spe*_lim
column per each
functional variable giving the
limits of the contribution of that variable to the SPE statistic.
Capezza C, Lepore A, Menafoglio A, Palumbo B, Vantini S. (2020) Control charts for monitoring ship operating conditions and CO2 emissions based on scalar-on-function regression. Applied Stochastic Models in Business and Industry, 36(3):477–500. doi:10.1002/asmb.2507
Capizzi, G., & Masarotto, G. (2018). Phase I distribution-free analysis with the R package dfphase1. In Frontiers in Statistical Quality Control 12 (pp. 3-19). Springer International Publishing.
library(funcharts) data("air") air <- lapply(air, function(x) x[1:220, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:100] y_tuning <- y[101:200] y2 <- y[201:220] mfdobj_x1 <- mfdobj_x[1:100] mfdobj_x_tuning <- mfdobj_x[101:200] mfdobj_x2 <- mfdobj_x[201:220] pca <- pca_mfd(mfdobj_x1) cclist <- control_charts_pca(pca = pca, tuning_data = mfdobj_x_tuning, newdata = mfdobj_x2) plot_control_charts(cclist)
library(funcharts) data("air") air <- lapply(air, function(x) x[1:220, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:100] y_tuning <- y[101:200] y2 <- y[201:220] mfdobj_x1 <- mfdobj_x[1:100] mfdobj_x_tuning <- mfdobj_x[101:200] mfdobj_x2 <- mfdobj_x[201:220] pca <- pca_mfd(mfdobj_x1) cclist <- control_charts_pca(pca = pca, tuning_data = mfdobj_x_tuning, newdata = mfdobj_x2) plot_control_charts(cclist)
This function produces a list of data frames,
each of them is produced by control_charts_pca
and is needed to plot control charts for monitoring
multivariate functional covariates
each evolving up to an intermediate domain point.
control_charts_pca_mfd_real_time( pca_list, components_list = NULL, mfdobj_x_test, mfdobj_x_tuning = NULL, alpha = 0.05, limits = "standard", seed, nfold = NULL, tot_variance_explained = 0.9, single_min_variance_explained = 0, absolute_error = FALSE, ncores = 1 )
control_charts_pca_mfd_real_time( pca_list, components_list = NULL, mfdobj_x_test, mfdobj_x_tuning = NULL, alpha = 0.05, limits = "standard", seed, nfold = NULL, tot_variance_explained = 0.9, single_min_variance_explained = 0, absolute_error = FALSE, ncores = 1 )
pca_list |
A list of lists produced by |
components_list |
A list of components given as input to |
mfdobj_x_test |
A list created using
|
mfdobj_x_tuning |
A list created using
|
alpha |
See |
limits |
See |
seed |
Deprecated: See |
nfold |
See |
tot_variance_explained |
See |
single_min_variance_explained |
See |
absolute_error |
See |
ncores |
If you want parallelization, give the number of cores/threads to be used when creating objects separately for different instants. |
A list of data.frame
s each
produced by control_charts_pca
,
corresponding to a given instant.
pca_mfd_real_time
, control_charts_pca
library(funcharts) data("air") air1 <- lapply(air, function(x) x[1:8, , drop = FALSE]) air2 <- lapply(air, function(x) x[9:10, , drop = FALSE]) mfdobj_x1_list <- get_mfd_list_real_time(air1[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_x2_list <- get_mfd_list_real_time(air2[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) pca_list <- pca_mfd_real_time(mfdobj_x1_list) cclist <- control_charts_pca_mfd_real_time( pca_list = pca_list, components_list = 1:3, mfdobj_x_test = mfdobj_x2_list) plot_control_charts_real_time(cclist, 1)
library(funcharts) data("air") air1 <- lapply(air, function(x) x[1:8, , drop = FALSE]) air2 <- lapply(air, function(x) x[9:10, , drop = FALSE]) mfdobj_x1_list <- get_mfd_list_real_time(air1[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_x2_list <- get_mfd_list_real_time(air2[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) pca_list <- pca_mfd_real_time(mfdobj_x1_list) cclist <- control_charts_pca_mfd_real_time( pca_list = pca_list, components_list = 1:3, mfdobj_x_test = mfdobj_x2_list) plot_control_charts_real_time(cclist, 1)
This function builds a data frame needed to plot control charts for monitoring a monitoring a scalar quality characteristic adjusted for the effect of multivariate functional covariates based on scalar-on-function regression, as proposed in Capezza et al. (2020).
In particular, this function provides:
the Hotelling's T2 control chart,
the squared prediction error (SPE) control chart,
the scalar regression control chart.
This function calls control_charts_pca
for the control charts on
the multivariate functional covariates and regr_cc_sof
for the scalar regression control chart.
The training data have already been used to fit the model. An optional tuning data set can be provided that is used to estimate the control chart limits. A phase II data set contains the observations to be monitored with the control charts.
control_charts_sof_pc( mod, y_test, mfdobj_x_test, mfdobj_x_tuning = NULL, alpha = list(T2 = 0.0125, spe = 0.0125, y = 0.025), limits = "standard", seed, nfold = NULL, ncores = 1 )
control_charts_sof_pc( mod, y_test, mfdobj_x_test, mfdobj_x_tuning = NULL, alpha = list(T2 = 0.0125, spe = 0.0125, y = 0.025), limits = "standard", seed, nfold = NULL, ncores = 1 )
mod |
A list obtained as output from |
y_test |
A numeric vector containing the observations of the scalar response variable in the phase II data set. |
mfdobj_x_test |
An object of class |
mfdobj_x_tuning |
An object of class |
alpha |
A named list with three elements, named |
limits |
A character value.
If "standard", it estimates the control limits on the tuning
data set. If "cv", the function calculates the control limits only on the
training data using cross-validation
using |
seed |
If |
nfold |
If |
ncores |
If |
A data.frame
with as many rows as the number of
multivariate functional observations in the phase II data set and
the following columns:
one id
column identifying the multivariate functional observation
in the phase II data set,
one T2
column containing the Hotelling T2 statistic calculated
for all observations,
one column per each functional variable, containing its contribution to the T2 statistic,
one spe
column containing the SPE statistic calculated
for all observations,
one column per each functional variable, containing its contribution to the SPE statistic,
T2_lim
gives the upper control limit of the
Hotelling's T2 control chart,
one contribution_T2_*_lim
column per each
functional variable giving the
limits of the contribution of that variable to the
Hotelling's T2 statistic,
spe_lim
gives the upper control limit of the SPE control chart
one contribution_spe*_lim
column per
each functional variable giving the
limits of the contribution of that variable to the SPE statistic.
y_hat
: the predictions of the response variable
corresponding to mfdobj_x_new
,
y
: the same as the argument y_new
given as input to this function,
lwr
: lower limit of the 1-alpha
prediction interval on the response,
pred_err
: prediction error calculated as y-y_hat
,
pred_err_sup
: upper limit of the 1-alpha
prediction interval on the prediction error,
pred_err_inf
: lower limit of the 1-alpha
prediction interval on the prediction error.
C. Capezza
control_charts_pca
, regr_cc_sof
## Not run: #' library(funcharts) data("air") air <- lapply(air, function(x) x[201:300, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:60] y2 <- y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod <- sof_pc(y1, mfdobj_x1) cclist <- control_charts_sof_pc(mod = mod, y_test = y2, mfdobj_x_test = mfdobj_x2, mfdobj_x_tuning = mfdobj_x_tuning) plot_control_charts(cclist) ## End(Not run)
## Not run: #' library(funcharts) data("air") air <- lapply(air, function(x) x[201:300, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:60] y2 <- y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod <- sof_pc(y1, mfdobj_x1) cclist <- control_charts_sof_pc(mod = mod, y_test = y2, mfdobj_x_test = mfdobj_x2, mfdobj_x_tuning = mfdobj_x_tuning) plot_control_charts(cclist) ## End(Not run)
This function is deprecated. Use regr_cc_sof_real_time
.
This function produces a list of data frames,
each of them is produced by control_charts_sof_pc
and is needed to plot control charts for monitoring in real time
a scalar quality characteristic adjusted for
by the effect of multivariate functional covariates.
control_charts_sof_pc_real_time( mod_list, y_test, mfdobj_x_test, mfdobj_x_tuning = NULL, alpha = list(T2 = 0.0125, spe = 0.0125, y = 0.025), limits = "standard", seed, nfold = NULL, ncores = 1 )
control_charts_sof_pc_real_time( mod_list, y_test, mfdobj_x_test, mfdobj_x_tuning = NULL, alpha = list(T2 = 0.0125, spe = 0.0125, y = 0.025), limits = "standard", seed, nfold = NULL, ncores = 1 )
mod_list |
A list of lists produced by |
y_test |
A numeric vector containing the observations of the scalar response variable in the phase II monitoring data set. |
mfdobj_x_test |
A list created using
|
mfdobj_x_tuning |
A list created using
|
alpha |
|
limits |
|
seed |
Deprecated: see |
nfold |
|
ncores |
If you want parallelization, give the number of cores/threads to be used when creating objects separately for different instants. |
A list of data.frame
s each
produced by control_charts_sof_pc
,
corresponding to a given instant.
sof_pc_real_time
, control_charts_sof_pc
## Not run: library(funcharts) data("air") air1 <- lapply(air, function(x) x[1:8, , drop = FALSE]) air2 <- lapply(air, function(x) x[9:10, , drop = FALSE]) mfdobj_x1_list <- get_mfd_list_real_time(air1[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_x2_list <- get_mfd_list_real_time(air2[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) y1 <- rowMeans(air1$NO2) y2 <- rowMeans(air2$NO2) mod_list <- sof_pc_real_time(y1, mfdobj_x1_list) cclist <- control_charts_sof_pc_real_time( mod_list = mod_list, y_test = y2, mfdobj_x_test = mfdobj_x2_list) plot_control_charts_real_time(cclist, 1) ## End(Not run)
## Not run: library(funcharts) data("air") air1 <- lapply(air, function(x) x[1:8, , drop = FALSE]) air2 <- lapply(air, function(x) x[9:10, , drop = FALSE]) mfdobj_x1_list <- get_mfd_list_real_time(air1[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_x2_list <- get_mfd_list_real_time(air2[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) y1 <- rowMeans(air1$NO2) y2 <- rowMeans(air2$NO2) mod_list <- sof_pc_real_time(y1, mfdobj_x1_list) cclist <- control_charts_sof_pc_real_time( mod_list = mod_list, y_test = y2, mfdobj_x_test = mfdobj_x2_list) plot_control_charts_real_time(cclist, 1) ## End(Not run)
Computes the correlation function for two multivariate functional data objects of class mfd
.
cor_mfd(mfdobj1, mfdobj2 = mfdobj1)
cor_mfd(mfdobj1, mfdobj2 = mfdobj1)
mfdobj1 |
An object of class |
mfdobj2 |
An object of class |
The function calculates the correlation between all pairs of dimensions from the two multivariate
functional data objects. The data is first scaled using scale_mfd
, and the correlation
is then computed as the covariance of the scaled data using cov_mfd
.
A bifd object representing the correlation function of the two input objects. The output
is a collection of functional surfaces, each corresponding to the correlation between
two components of the multivariate functional data.
## Not run: library(funcharts) data("air") x <- get_mfd_list(air[1:3]) cor_result <- cor_mfd(x) plot_bifd(cor_result) ## End(Not run)
## Not run: library(funcharts) data("air") x <- get_mfd_list(air[1:3]) cor_result <- cor_mfd(x) plot_bifd(cor_result) ## End(Not run)
Computes the covariance function for two multivariate functional data objects of class mfd
.
cov_mfd(mfdobj1, mfdobj2 = mfdobj1)
cov_mfd(mfdobj1, mfdobj2 = mfdobj1)
mfdobj1 |
An object of class |
mfdobj2 |
An object of class |
The function calculates the covariance between all pairs of dimensions from the two multivariate functional data objects. Each covariance is represented as a functional surface in the resulting bifd object. The covariance function is useful for analyzing relationships between functional variables.
A bifd object representing the covariance function of the two input objects. The output
is a collection of functional surfaces, each corresponding to the covariance between
two components of the multivariate functional data.
## Not run: library(funcharts) data("air") x <- get_mfd_list(air[1:3]) cov_result <- cov_mfd(x) plot_bifd(cov_result) ## End(Not run)
## Not run: library(funcharts) data("air") x <- get_mfd_list(air[1:3]) cov_result <- cov_mfd(x) plot_bifd(cov_result) ## End(Not run)
Simulate random coefficients and create a multivariate functional data
object of class mfd
.
It is mainly for internal use, to check that the package functions
work.
data_sim_mfd(nobs = 5, nbasis = 5, nvar = 2, seed)
data_sim_mfd(nobs = 5, nbasis = 5, nvar = 2, seed)
nobs |
Number of functional observations to be simulated. |
nbasis |
Number of basis functions. |
nvar |
Number of functional covariates. |
seed |
Deprecated: use |
A simulated object of class mfd
.
library(funcharts) data_sim_mfd()
library(funcharts) data_sim_mfd()
Function-on-function linear regression based on principal components. This function performs multivariate functional principal component analysis (MFPCA) to extract multivariate functional principal components from the multivariate functional covariates as well as from the functional response, then it builds a linear regression model of the response scores on the covariate scores. Both functional covariates and response are standardized before the regression. See Centofanti et al. (2021) for additional details.
fof_pc( mfdobj_y, mfdobj_x, tot_variance_explained_x = 0.95, tot_variance_explained_y = 0.95, tot_variance_explained_res = 0.95, components_x = NULL, components_y = NULL, type_residuals = "standard" )
fof_pc( mfdobj_y, mfdobj_x, tot_variance_explained_x = 0.95, tot_variance_explained_y = 0.95, tot_variance_explained_res = 0.95, components_x = NULL, components_y = NULL, type_residuals = "standard" )
mfdobj_y |
A multivariate functional data object of class mfd denoting the functional response variable. Although it is a multivariate functional data object, it must have only one functional variable. |
mfdobj_x |
A multivariate functional data object of class mfd denoting the functional covariates. |
tot_variance_explained_x |
The minimum fraction of variance that has to be explained by the multivariate functional principal components retained into the MFPCA model fitted on the functional covariates. Default is 0.95. |
tot_variance_explained_y |
The minimum fraction of variance that has to be explained by the multivariate functional principal components retained into the MFPCA model fitted on the functional response. Default is 0.95. |
tot_variance_explained_res |
The minimum fraction of variance that has to be explained by the multivariate functional principal components retained into the MFPCA model fitted on the functional residuals of the functional regression model. Default is 0.95. |
components_x |
A vector of integers with the components over which
to project the functional covariates.
If NULL, the first components that explain a minimum fraction of variance
equal to |
components_y |
A vector of integers with the components over which
to project the functional response.
If NULL, the first components that explain a minimum fraction of variance
equal to |
type_residuals |
A character value that can be "standard" or "studentized". If "standard", the MFPCA on functional residuals is calculated on the standardized covariates and response. If "studentized", the MFPCA on studentized version of the functional residuals is calculated on the non-standardized covariates and response. See Centofanti et al. (2021) for additional details. |
A list containing the following arguments:
mod
: an object of class lm
that is a linear regression model
where
the response variables are the MFPCA scores of the response variable and
the covariates are the MFPCA scores of the functional covariates.
mod$coefficients
contains the matrix of coefficients
of the functional regression basis functions,
beta_fd
: a bifd
object containing the
bivariate functional regression coefficients
estimated with the function-on-function linear regression model,
fitted.values
: a multivariate functional data object of
class mfd with the fitted values of the
functional response observations based on the
function-on-function linear regression model,
residuals_original_scale
: a multivariate functional data object
of class mfd
with the functional residuals of the
function-on-function linear regression model on the original scale,
i.e. they are the difference between
mfdobj_y
and fitted.values
,
residuals
: a multivariate functional data object of class mfd
with the functional residuals of the
function-on-function linear regression model,
standardized or studentized depending on
the argument type_residuals
,
type_residuals
: the same as the provided argument,
pca_x
: an object of class pca_mfd
obtained by doing MFPCA on the functional covariates,
pca_y
: an object of class pca_mfd
obtained by doing MFPCA on the functional response,
pca_res
: an object of class pca_mfd
obtained by doing MFPCA on the functional residuals,
components_x
: a vector of integers
with the components selected in the pca_x
model,
components_y
: a vector of integers
with the components selected in the pca_y
model,
components_res
: a vector of integers
with the components selected in the pca_res
model,
y_standardized
: the standardized functional response
obtained doing scale_mfd(mfdobj_y)
,
tot_variance_explained_x
: the same as the provided argument
tot_variance_explained_y
: the same as the provided argument
tot_variance_explained_res
: the same as the provided argument
get_studentized_residuals
: a function that allows
to calculate studentized residuals on new data,
given the estimated function-on-function linear regression model.
C. Capezza, F. Centofanti
Centofanti F, Lepore A, Menafoglio A, Palumbo B, Vantini S. (2021) Functional Regression Control Chart. Technometrics, 63(3), 281–294. doi:10.1080/00401706.2020.1753581
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj <- get_mfd_list(air, lambda = 1e-2) mfdobj_y <- mfdobj[, "NO2"] mfdobj_x <- mfdobj[, fun_covariates] mod <- fof_pc(mfdobj_y, mfdobj_x)
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj <- get_mfd_list(air, lambda = 1e-2) mfdobj_y <- mfdobj[, "NO2"] mfdobj_x <- mfdobj[, fun_covariates] mod <- fof_pc(mfdobj_y, mfdobj_x)
This function produces a list of objects,
each of them contains the result of applying fof_pc
to
a functional response variable and multivariate functional covariates
evolved up to an intermediate domain point.
fof_pc_real_time( mfdobj_y_list, mfdobj_x_list, tot_variance_explained_x = 0.95, tot_variance_explained_y = 0.95, tot_variance_explained_res = 0.95, components_x = NULL, components_y = NULL, type_residuals = "standard", ncores = 1 )
fof_pc_real_time( mfdobj_y_list, mfdobj_x_list, tot_variance_explained_x = 0.95, tot_variance_explained_y = 0.95, tot_variance_explained_res = 0.95, components_x = NULL, components_y = NULL, type_residuals = "standard", ncores = 1 )
mfdobj_y_list |
A list created using
|
mfdobj_x_list |
A list created using
|
tot_variance_explained_x |
See |
tot_variance_explained_y |
See |
tot_variance_explained_res |
See |
components_x |
See |
components_y |
See |
type_residuals |
See |
ncores |
If you want parallelization, give the number of cores/threads to be used when creating objects separately for different instants. |
A list of lists each produced by fof_pc
,
corresponding to a given instant.
C. Capezza, F. Centofanti
fof_pc
,
get_mfd_df_real_time
,
get_mfd_list_real_time
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) mfdobj_y_list <- get_mfd_list_real_time(air["NO2"], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 0.75, 1)) mfdobj_x_list <- get_mfd_list_real_time(air[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 0.75, 1)) mod_list <- fof_pc_real_time(mfdobj_y_list, mfdobj_x_list)
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) mfdobj_y_list <- get_mfd_list_real_time(air["NO2"], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 0.75, 1)) mfdobj_x_list <- get_mfd_list_real_time(air[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 0.75, 1)) mod_list <- fof_pc_real_time(mfdobj_y_list, mfdobj_x_list)
This function implements the design phase (Phase I) of FRTM method.
FRTM_PhaseI( data_tra, data_tun = NULL, alpha = 0.05, n_basis_xall = 30, control.FDTW = list(), control.mFPCA = list(), control.rtr = list(), ncores = 1, print = TRUE )
FRTM_PhaseI( data_tra, data_tun = NULL, alpha = 0.05, n_basis_xall = 30, control.FDTW = list(), control.mFPCA = list(), control.rtr = list(), ncores = 1, print = TRUE )
data_tra |
A list containing the following arguments: |
data_tun |
A list containing the following arguments: |
alpha |
Overall type I error probability to obtain the control chart limits. |
n_basis_xall |
Number of basis to obtain the functional observation via the spline smoothing approach based on cubic B-splines and a roughness penalty on the second derivative. |
control.FDTW |
A list of control parameters for the open-end/open-begin functional dynamic time warping to replace defaults returned by par.FDTW. Values not set assume default values. |
control.mFPCA |
A list of control parameters for the mixed functional principal component analysis to replace defaults returned by par.mFPCA. Values not set assume default values. |
control.rtr |
A list of control parameters for the real-time registration step to replace defaults returned by par.rtr. Values not set assume default values. |
ncores |
If |
print |
If TRUE, some information are printed. Default is TRUE. |
A list containing the following arguments:
T2_fd
List of functions for each observation in the tuning set.
SPE_fd
List of SPE functions for each observation in the tuning set.
CL_T2
Control limit of the Hotelling's control chart.
CL_SPE
Control limit of the SPE control chart.
template_fd
Template function used in the registration.
der_template_fd
First derivative of the template function.
u_fd
Upper extreme of the band constraint.
l_fd
Lower extreme of the band constraint.
x_list_tun
List, for each observation in the tuning set, of partial registered functions.
h_list_tun
List, for each observation in the tuning set, of partial warping functions.
x_list
List, for each observation in the training set, of partial registered functions.
h_list
List, for each observation in the training set, of partial warping functions.
x_err
A list containing the discrete observations for each curve of the training set.
grid_i
A list of vector of time points where the curves of the training set are sampled.
x_list_smooth
Smooth curves from the training set.
lambda
Lambda identified through the average curve distance to obtain the OEB-FDTW solution.
par_reg
Additional parameters to be used in the monitoring phase (Phase II).
F. Centofanti
Centofanti, F., A. Lepore, M. Kulahci, and M. P. Spooner (2024). Real-time monitoring of functional data. Accepted for publication in Journal of Quality Technology.
library(funcharts) data <- simulate_data_FRTM(n_obs = 20) data_oc <- simulate_data_FRTM( n_obs = 2, scenario = "1", shift = "OC_h", severity = 0.5 ) lambda <- 10 ^ -5 max_x <- max(unlist(data$grid_i)) seq_t_tot <- seq(0, 1, length.out = 30)[-1] seq_x <- seq(0.1, max_x, length.out = 10) ## Not run: mod_phaseI_FRTM <- FRTM_PhaseI( data_tra = data, control.FDTW = list( M = 30, N = 30, lambda = lambda, seq_t = seq_t_tot, iter_tem = 1, iter = 1 ), control.rtr = list(seq_x = seq_x) ) mod_phaseII_FRTM <- FRTM_PhaseII(data_oc = data_oc , mod_phaseI = mod_phaseI_FRTM) plot(mod_phaseI_FRTM) plot(mod_phaseII_FRTM) ## End(Not run)
library(funcharts) data <- simulate_data_FRTM(n_obs = 20) data_oc <- simulate_data_FRTM( n_obs = 2, scenario = "1", shift = "OC_h", severity = 0.5 ) lambda <- 10 ^ -5 max_x <- max(unlist(data$grid_i)) seq_t_tot <- seq(0, 1, length.out = 30)[-1] seq_x <- seq(0.1, max_x, length.out = 10) ## Not run: mod_phaseI_FRTM <- FRTM_PhaseI( data_tra = data, control.FDTW = list( M = 30, N = 30, lambda = lambda, seq_t = seq_t_tot, iter_tem = 1, iter = 1 ), control.rtr = list(seq_x = seq_x) ) mod_phaseII_FRTM <- FRTM_PhaseII(data_oc = data_oc , mod_phaseI = mod_phaseI_FRTM) plot(mod_phaseI_FRTM) plot(mod_phaseII_FRTM) ## End(Not run)
This function implements the monitoring phase (Phase II) of FRTM method.
FRTM_PhaseII(data_oc, mod_phaseI, ncores = 1)
FRTM_PhaseII(data_oc, mod_phaseI, ncores = 1)
data_oc |
A list containing the following arguments: |
mod_phaseI |
An object of class |
ncores |
If |
A list containing the following arguments:
T2_fd
List of functions for each observation.
SPE_fd
List of SPE functions for each observation.
CL_T2
Control limit of the Hotelling's control chart.
CL_SPE
Control limit of the SPE control chart.
x_err
A list containing the discrete observations for each curve.
grid_i
A list of vector of time points where the curves are sampled.
x_list_smooth
Smooth curves.
mod_phaseI
An object of class mod_phaseI_FRTM
obtained as output of the function FRTM_PhaseI
.
F. Centofanti
Centofanti, F., A. Lepore, M. Kulahci, and M. P. Spooner (2024). Real-time monitoring of functional data. Accepted for publication in Journal of Quality Technology.
library(funcharts) data <- simulate_data_FRTM(n_obs = 20) data_oc <- simulate_data_FRTM( n_obs = 2, scenario = "1", shift = "OC_h", severity = 0.5 ) lambda <- 10 ^ -5 max_x <- max(unlist(data$grid_i)) seq_t_tot <- seq(0, 1, length.out = 30)[-1] seq_x <- seq(0.1, max_x, length.out = 10) ## Not run: mod_phaseI_FRTM <- FRTM_PhaseI( data_tra = data, control.FDTW = list( M = 30, N = 30, lambda = lambda, seq_t = seq_t_tot, iter_tem = 1, iter = 1 ), control.rtr = list(seq_x = seq_x) ) mod_phaseII_FRTM <- FRTM_PhaseII(data_oc = data_oc , mod_phaseI = mod_phaseI_FRTM) plot(mod_phaseI_FRTM) plot(mod_phaseII_FRTM) ## End(Not run)
library(funcharts) data <- simulate_data_FRTM(n_obs = 20) data_oc <- simulate_data_FRTM( n_obs = 2, scenario = "1", shift = "OC_h", severity = 0.5 ) lambda <- 10 ^ -5 max_x <- max(unlist(data$grid_i)) seq_t_tot <- seq(0, 1, length.out = 30)[-1] seq_x <- seq(0.1, max_x, length.out = 10) ## Not run: mod_phaseI_FRTM <- FRTM_PhaseI( data_tra = data, control.FDTW = list( M = 30, N = 30, lambda = lambda, seq_t = seq_t_tot, iter_tem = 1, iter = 1 ), control.rtr = list(seq_x = seq_x) ) mod_phaseII_FRTM <- FRTM_PhaseII(data_oc = data_oc , mod_phaseI = mod_phaseI_FRTM) plot(mod_phaseI_FRTM) plot(mod_phaseII_FRTM) ## End(Not run)
It finds functional componentwise outliers as described in Capezza et al. (2024).
functional_filter( mfdobj, method_pca = "ROBPCA", alpha = 0.95, fev = 0.999, delta = 0.1, alpha_binom = 0.99, bivariate = TRUE, max_proportion_componentwise = 0.5 )
functional_filter( mfdobj, method_pca = "ROBPCA", alpha = 0.95, fev = 0.999, delta = 0.1, alpha_binom = 0.99, bivariate = TRUE, max_proportion_componentwise = 0.5 )
mfdobj |
A multivariate functional data object of class mfd. |
method_pca |
The method used in |
alpha |
Probability value such that only values of functional distances greater than
the |
fev |
Number between 0 and 1 denoting the fraction
of variability that must be explained by the
principal components to be selected to calculate functional distances after
applying RoMFPCA on |
delta |
Number between 0 and 1 denoting the parameter of the
Binomial distribution whose |
alpha_binom |
Probability value such that the |
bivariate |
If TRUE, both univariate and bivariate filters are applied. If FALSE, only the univariate filter is used. Default is TRUE. |
max_proportion_componentwise |
If the functional filter identifies a proportion of functional
componentwise outliers larger than |
A list with two elements.
The first element is an mfd
object containing
the original observation in the mfdobj
input, but where
the basis coefficients of the components identified as functional
componentwise outliers are replaced by NA.
The second element of the list is a list of numbers, with length equal
to the number of functional variables in mfdobj
.
Each element of this list contains the observations of the flagged
functional componentwise outliers for the corresponding functional variable.
C. Capezza, F. Centofanti
Agostinelli, C., Leung, A., Yohai, V. J., and Zamar, R. H. (2015). Robust estimation of multivariate location and scatter in the presence of cellwise and casewise contamination. Test, 24(3):441–461.
Capezza, C., Centofanti, F., Lepore, A., Palumbo, B. (2024) Robust Multivariate Functional Control Charts. Technometrics, 66(4):531–547, doi:10.1080/00401706.2024.2327346.
Leung, A., Yohai, V., and Zamar, R. (2017). Multivariate location and scatter matrix estimation under cellwise and casewise contamination. Computational Statistics & Data Analysis, 111:59–76.
## Not run: library(funcharts) mfdobj <- get_mfd_list(air, grid = 1:24, n_basis = 13, lambda = 1e-2) plot_mfd(mfdobj) out <- functional_filter(mfdobj) ## End(Not run)
## Not run: library(funcharts) mfdobj <- get_mfd_list(air, grid = 1:24, n_basis = 13, lambda = 1e-2) plot_mfd(mfdobj) out <- functional_filter(mfdobj) ## End(Not run)
Get Multivariate Functional Data from a three-dimensional array
get_mfd_array( data_array, grid = NULL, n_basis = 30, n_order = 4, basisobj = NULL, Lfdobj = 2, lambda = NULL, lambda_grid = 10^seq(-10, 1, length.out = 10), ncores = 1 )
get_mfd_array( data_array, grid = NULL, n_basis = 30, n_order = 4, basisobj = NULL, Lfdobj = 2, lambda = NULL, lambda_grid = 10^seq(-10, 1, length.out = 10), ncores = 1 )
data_array |
A three-dimensional array. The first dimension corresponds to argument values, the second to replications, and the third to variables within replications. |
grid |
See |
n_basis |
See |
n_order |
#' See |
basisobj |
#' See |
Lfdobj |
#' See |
lambda |
See |
lambda_grid |
See |
ncores |
Deprecated. See |
An object of class mfd
.
See also ?mfd
for additional details on the
multivariate functional data class.
library(funcharts) library(fda) data("CanadianWeather") mfdobj <- get_mfd_array(CanadianWeather$dailyAv[, 1:10, ], lambda = 1e-5) plot_mfd(mfdobj)
library(funcharts) library(fda) data("CanadianWeather") mfdobj <- get_mfd_array(CanadianWeather$dailyAv[, 1:10, ], lambda = 1e-5) plot_mfd(mfdobj)
This function produces a list functional data objects, each evolving up to an intermediate domain point, that can be used to estimate models that allow real-time predictions of incomplete functions, from the current functional domain up to the end of the observation, and to build control charts for real-time monitoring.
It calls the function get_mfd_array
for each domain point.
get_mfd_array_real_time( data_array, grid = NULL, n_basis = 30, n_order = 4, basisobj = NULL, Lfdobj = 2, lambda = NULL, lambda_grid = 10^seq(-10, 1, length.out = 10), k_seq = seq(from = 0.25, to = 1, length.out = 10), ncores = 1 )
get_mfd_array_real_time( data_array, grid = NULL, n_basis = 30, n_order = 4, basisobj = NULL, Lfdobj = 2, lambda = NULL, lambda_grid = 10^seq(-10, 1, length.out = 10), k_seq = seq(from = 0.25, to = 1, length.out = 10), ncores = 1 )
data_array |
See |
grid |
See |
n_basis |
See |
n_order |
See |
basisobj |
See |
Lfdobj |
See |
lambda |
See |
lambda_grid |
See |
k_seq |
A vector of values between 0 and 1, containing the domain points over which functional data are to be evaluated in real time. If the domain is the interval (a,b), for each instant k in the sequence, functions are evaluated in (a,k(b-a)). |
ncores |
If you want parallelization, give the number of cores/threads to be used when creating mfd objects separately for different instants. |
A list of mfd
objects as produced by
get_mfd_array
.
library(funcharts) library(fda) data("CanadianWeather") fdobj <- get_mfd_array_real_time(CanadianWeather$dailyAv[, 1:5, 1:2], lambda = 1e-2)
library(funcharts) library(fda) data("CanadianWeather") fdobj <- get_mfd_array_real_time(CanadianWeather$dailyAv[, 1:5, 1:2], lambda = 1e-2)
Get Multivariate Functional Data from a data frame
get_mfd_df( dt, domain, arg, id, variables, n_basis = 30, n_order = 4, basisobj = NULL, Lfdobj = 2, lambda = NULL, lambda_grid = 10^seq(-10, 1, length.out = 10), ncores = 1 )
get_mfd_df( dt, domain, arg, id, variables, n_basis = 30, n_order = 4, basisobj = NULL, Lfdobj = 2, lambda = NULL, lambda_grid = 10^seq(-10, 1, length.out = 10), ncores = 1 )
dt |
A |
domain |
A numeric vector of length 2 defining the interval over which the functional data object can be evaluated. |
arg |
A character variable, which is the name of
the column of the data frame |
id |
A character variable indicating which is the functional observation in each row. |
variables |
A vector of characters of the column names
of the data frame |
n_basis |
An integer variable specifying the number of basis functions; default value is 30. See details on basis functions. |
n_order |
An integer specifying the order of b-splines, which is one higher than their degree. The default of 4 gives cubic splines. |
basisobj |
An object of class |
Lfdobj |
An object of class |
lambda |
A non-negative real number.
If you want to use a single specified smoothing parameter
for all functional data objects in the dataset,
this argument is passed to the function |
lambda_grid |
A vector of non-negative real numbers.
If |
ncores |
If you want parallelization, give the number of cores/threads to be used when doing GCV separately on all observations. |
Basis functions are created with
fda::create.bspline.basis(domain, n_basis)
, i.e.
B-spline basis functions of order 4 with equally spaced knots
are used to create mfd
objects.
The smoothing penalty lambda is provided as
fda::fdPar(bs, 2, lambda)
,
where bs is the basis object and 2 indicates
that the integrated squared second derivative is penalized.
Rather than having a data frame with long format,
i.e. with all functional observations in a single column
for each functional variable,
if all functional observations are observed on a common equally spaced grid,
discrete data may be available in matrix form for each functional variable.
In this case, see get_mfd_list
.
An object of class mfd
.
See also ?mfd
for additional details on the
multivariate functional data class.
library(funcharts) x <- seq(1, 10, length = 25) y11 <- cos(x) y21 <- cos(2 * x) y12 <- sin(x) y22 <- sin(2 * x) df <- data.frame(id = factor(rep(1:2, each = length(x))), x = rep(x, times = 2), y1 = c(y11, y21), y2 = c(y12, y22)) mfdobj <- get_mfd_df(dt = df, domain = c(1, 10), arg = "x", id = "id", variables = c("y1", "y2"), lambda = 1e-5)
library(funcharts) x <- seq(1, 10, length = 25) y11 <- cos(x) y21 <- cos(2 * x) y12 <- sin(x) y22 <- sin(2 * x) df <- data.frame(id = factor(rep(1:2, each = length(x))), x = rep(x, times = 2), y1 = c(y11, y21), y2 = c(y12, y22)) mfdobj <- get_mfd_df(dt = df, domain = c(1, 10), arg = "x", id = "id", variables = c("y1", "y2"), lambda = 1e-5)
This function produces a list functional data objects, each evolving up to an intermediate domain point, that can be used to estimate models that allow real-time predictions of incomplete functions, from the current functional domain up to the end of the observation, and to build control charts for real-time monitoring.
It calls the function get_mfd_df
for each domain point.
get_mfd_df_real_time( dt, domain, arg, id, variables, n_basis = 30, n_order = 4, basisobj = NULL, Lfdobj = 2, lambda = NULL, lambda_grid = 10^seq(-10, 1, length.out = 10), k_seq = seq(from = 0.25, to = 1, length.out = 10), ncores = 1 )
get_mfd_df_real_time( dt, domain, arg, id, variables, n_basis = 30, n_order = 4, basisobj = NULL, Lfdobj = 2, lambda = NULL, lambda_grid = 10^seq(-10, 1, length.out = 10), k_seq = seq(from = 0.25, to = 1, length.out = 10), ncores = 1 )
dt |
See |
domain |
See |
arg |
See |
id |
See |
variables |
See |
n_basis |
See |
n_order |
See |
basisobj |
See |
Lfdobj |
See |
lambda |
See |
lambda_grid |
See |
k_seq |
A vector of values between 0 and 1, containing the domain points over which functional data are to be evaluated in real time. If the domain is the interval (a,b), for each instant k in the sequence, functions are evaluated in (a,k(b-a)). |
ncores |
If you want parallelization, give the number of cores/threads to be used when creating mfd objects separately for different instants. |
A list of mfd
objects as produced by
get_mfd_df
,
corresponding to a given instant.
library(funcharts) x <- seq(1, 10, length = 25) y11 <- cos(x) y21 <- cos(2 * x) y12 <- sin(x) y22 <- sin(2 * x) df <- data.frame(id = factor(rep(1:2, each = length(x))), x = rep(x, times = 2), y1 = c(y11, y21), y2 = c(y12, y22)) mfdobj_list <- get_mfd_df_real_time(dt = df, domain = c(1, 10), arg = "x", id = "id", variables = c("y1", "y2"), lambda = 1e-2)
library(funcharts) x <- seq(1, 10, length = 25) y11 <- cos(x) y21 <- cos(2 * x) y12 <- sin(x) y22 <- sin(2 * x) df <- data.frame(id = factor(rep(1:2, each = length(x))), x = rep(x, times = 2), y1 = c(y11, y21), y2 = c(y12, y22)) mfdobj_list <- get_mfd_df_real_time(dt = df, domain = c(1, 10), arg = "x", id = "id", variables = c("y1", "y2"), lambda = 1e-2)
fd
object into a Multivariate Functional Data object.Convert a fd
object into a Multivariate Functional Data object.
get_mfd_fd(fdobj)
get_mfd_fd(fdobj)
fdobj |
An object of class fd. |
An object of class mfd
.
See also ?mfd
for additional details on the
multivariate functional data class.
mfd
library(funcharts) library(fda) bs <- create.bspline.basis(nbasis = 10) fdobj <- fd(coef = 1:10, basisobj = bs) mfdobj <- get_mfd_fd(fdobj)
library(funcharts) library(fda) bs <- create.bspline.basis(nbasis = 10) fdobj <- fd(coef = 1:10, basisobj = bs) mfdobj <- get_mfd_fd(fdobj)
Get Multivariate Functional Data from a list of matrices
get_mfd_list( data_list, grid = NULL, n_basis = 30, n_order = 4, basisobj = NULL, Lfdobj = 2, lambda = NULL, lambda_grid = 10^seq(-10, 1, length.out = 10), ncores = 1 )
get_mfd_list( data_list, grid = NULL, n_basis = 30, n_order = 4, basisobj = NULL, Lfdobj = 2, lambda = NULL, lambda_grid = 10^seq(-10, 1, length.out = 10), ncores = 1 )
data_list |
A named list of matrices. Names of the elements in the list denote the functional variable names. Each matrix in the list corresponds to a functional variable. All matrices must have the same dimension, where the number of rows corresponds to replications, while the number of columns corresponds to the argument values at which functions are evaluated. |
grid |
A numeric vector, containing the argument values at which functions are evaluated. Its length must be equal to the number of columns in each matrix in data_list. Default is NULL, in this case a vector equally spaced numbers between 0 and 1 is created, with as many numbers as the number of columns in each matrix in data_list. |
n_basis |
An integer variable specifying the number of basis functions; default value is 30. See details on basis functions. |
n_order |
An integer specifying the order of B-splines, which is one higher than their degree. The default of 4 gives cubic splines. |
basisobj |
An object of class |
Lfdobj |
An object of class |
lambda |
A non-negative real number.
If you want to use a single specified smoothing parameter
for all functional data objects in the dataset,
this argument is passed to the function |
lambda_grid |
A vector of non-negative real numbers.
If |
ncores |
Deprecated. |
Basis functions are created with
fda::create.bspline.basis(domain, n_basis)
, i.e.
B-spline basis functions of order 4 with equally spaced knots
are used to create mfd
objects.
The smoothing penalty lambda is provided as
fda::fdPar(bs, 2, lambda)
,
where bs is the basis object and 2 indicates that
the integrated squared second derivative is penalized.
Rather than having a list of matrices,
you may have a data frame with long format,
i.e. with all functional observations in a single column
for each functional variable.
In this case, see get_mfd_df
.
An object of class mfd
.
See also mfd
for additional details
on the multivariate functional data class.
mfd
,
get_mfd_list
,
get_mfd_array
library(funcharts) data("air") # Only take first 5 multivariate functional observations # and only two variables from air air_small <- lapply(air[c("NO2", "CO")], function(x) x[1:5, ]) mfdobj <- get_mfd_list(data_list = air_small)
library(funcharts) data("air") # Only take first 5 multivariate functional observations # and only two variables from air air_small <- lapply(air[c("NO2", "CO")], function(x) x[1:5, ]) mfdobj <- get_mfd_list(data_list = air_small)
This function produces a list functional data objects, each evolving up to an intermediate domain point, that can be used to estimate models that allow real-time predictions of incomplete functions, from the current functional domain up to the end of the observation, and to build control charts for real-time monitoring.
It calls the function get_mfd_list
for each domain point.
get_mfd_list_real_time( data_list, grid = NULL, n_basis = 30, n_order = 4, basisobj = NULL, Lfdobj = 2, lambda = NULL, lambda_grid = 10^seq(-10, 1, length.out = 10), k_seq = seq(from = 0.2, to = 1, by = 0.1), ncores = 1 )
get_mfd_list_real_time( data_list, grid = NULL, n_basis = 30, n_order = 4, basisobj = NULL, Lfdobj = 2, lambda = NULL, lambda_grid = 10^seq(-10, 1, length.out = 10), k_seq = seq(from = 0.2, to = 1, by = 0.1), ncores = 1 )
data_list |
See |
grid |
See |
n_basis |
See |
n_order |
See |
basisobj |
See |
Lfdobj |
See |
lambda |
See |
lambda_grid |
See |
k_seq |
A vector of values between 0 and 1, containing the domain points over which functional data are to be evaluated in real time. If the domain is the interval (a,b), for each instant k in the sequence, functions are evaluated in (a,a+k(b-a)). |
ncores |
If you want parallelization, give the number of cores/threads to be used when creating mfd objects separately for different instants. |
A list of mfd
objects as produced by
get_mfd_list
.
library(funcharts) data("air") # Only take first 5 multivariate functional observations from air air_small <- lapply(air, function(x) x[1:5, ]) # Consider only 3 domain points: 0.5, 0.75, 1 mfdobj <- get_mfd_list_real_time(data_list = air_small, lambda = 1e-2, k_seq = c(0.5, 0.75, 1))
library(funcharts) data("air") # Only take first 5 multivariate functional observations from air air_small <- lapply(air, function(x) x[1:5, ]) # Consider only 3 domain points: 0.5, 0.75, 1 mfdobj <- get_mfd_list_real_time(data_list = air_small, lambda = 1e-2, k_seq = c(0.5, 0.75, 1))
Get out of control observations from control charts
get_ooc(cclist)
get_ooc(cclist)
cclist |
A |
A data.frame
with the same number of rows as cclist,
and the same number of columns
apart from the columns indicating control chart limits.
Each value is TRUE if the corresponding observation is in control
and FALSE otherwise.
library(funcharts) data("air") air <- lapply(air, function(x) x[201:300, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:60] y_tuning <- y[61:90] y2 <- y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod <- sof_pc(y1, mfdobj_x1) cclist <- regr_cc_sof(object = mod, y_new = y2, mfdobj_x_new = mfdobj_x2, y_tuning = y_tuning, mfdobj_x_tuning = mfdobj_x_tuning, include_covariates = TRUE) get_ooc(cclist)
library(funcharts) data("air") air <- lapply(air, function(x) x[201:300, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:60] y_tuning <- y[61:90] y2 <- y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod <- sof_pc(y1, mfdobj_x1) cclist <- regr_cc_sof(object = mod, y_new = y2, mfdobj_x_new = mfdobj_x2, y_tuning = y_tuning, mfdobj_x_tuning = mfdobj_x_tuning, include_covariates = TRUE) get_ooc(cclist)
Get outliers from multivariate functional data
using the functional boxplot with the
modified band depth of Sun et al. (2011, 2012).
This function relies on the fbplot
function
of the roahd
package.
get_outliers_mfd(mfdobj)
get_outliers_mfd(mfdobj)
mfdobj |
A multivariate functional data object of class mfd |
A numeric vector with the indexes of the functional observations signaled as outliers.
Sun, Y., & Genton, M. G. (2011). Functional boxplots. Journal of Computational and Graphical Statistics, 20(2), 316-334.
Sun, Y., & Genton, M. G. (2012). Adjusted functional boxplots for spatio-temporal data visualization and outlier detection. Environmetrics, 23(1), 54-64.
library(funcharts) data("air") air <- lapply(air, function(x) x[1:20, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], lambda = 1e-2) get_outliers_mfd(mfdobj_x)
library(funcharts) data("air") air <- lapply(air, function(x) x[1:20, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], lambda = 1e-2) get_outliers_mfd(mfdobj_x)
Get possible outliers of a training data set of a scalar-on-function regression model. It sets the training data set also as tuning data set for the calculation of control chart limits, and as phase II data set to compare monitoring statistics against the limits and identify possible outliers. This is only an empirical approach. It is advised to use methods appropriately designed for phase I monitoring to identify outliers.
get_sof_pc_outliers(y, mfdobj)
get_sof_pc_outliers(y, mfdobj)
y |
A numeric vector containing the observations of the scalar response variable. |
mfdobj |
A multivariate functional data object of class mfd denoting the functional covariates. |
A character vector with the ids of functional observations signaled as possibly anomalous.
## Not run: library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], lambda = 1e-2) y <- rowMeans(air$NO2) get_sof_pc_outliers(y, mfdobj_x) ## End(Not run)
## Not run: library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], lambda = 1e-2) y <- rowMeans(air$NO2) get_sof_pc_outliers(y, mfdobj_x) ## End(Not run)
mfd
objects.Inner products of functional data contained in mfd
objects.
inprod_mfd(mfdobj1, mfdobj2 = NULL)
inprod_mfd(mfdobj1, mfdobj2 = NULL)
mfdobj1 |
A multivariate functional data object of class |
mfdobj2 |
A multivariate functional data object of class |
Note that L^2 inner products are not calculated for couples of functional data from different functional variables. This function is needed to calculate the inner product in the product Hilbert space in the case of multivariate functional data, which for each observation is the sum of the L^2 inner products obtained for each functional variable.
a three-dimensional array of L^2 inner products. The first dimension is the number of functions in argument mfdobj1, the second dimension is the same thing for argument mfdobj2, the third dimension is the number of functional variables. If you sum values over the third dimension, you get a matrix of inner products in the product Hilbert space of multivariate functional data.
library(funcharts) set.seed(123) mfdobj1 <- data_sim_mfd() mfdobj2 <- data_sim_mfd() inprod_mfd(mfdobj1) inprod_mfd(mfdobj1, mfdobj2)
library(funcharts) set.seed(123) mfdobj1 <- data_sim_mfd() mfdobj2 <- data_sim_mfd() inprod_mfd(mfdobj1) inprod_mfd(mfdobj1, mfdobj2)
Inner product of two multivariate functional data objects, for each observation
inprod_mfd_diag(mfdobj1, mfdobj2 = NULL)
inprod_mfd_diag(mfdobj1, mfdobj2 = NULL)
mfdobj1 |
A multivariate functional data object of class |
mfdobj2 |
A multivariate functional data object of class |
It calculates the inner product of two
multivariate functional data objects.
The main function inprod
of the package fda
calculates inner products among
all possible couples of observations.
This means that, if mfdobj1
has n1
observations
and mfdobj2
has n2
observations,
then for each variable n1 X n2
inner products are calculated.
However, often one is interested only in calculating
the n
inner products
between the n
observations of mfdobj1
and
the corresponding n
observations of mfdobj2
. This function provides
this "diagonal" inner products only,
saving a lot of computation with respect to using
fda::inprod
and then extracting the
diagonal elements.
Note that the code of this function calls a modified version
of fda::inprod()
.
mfdobj <- data_sim_mfd() inprod_mfd_diag(mfdobj)
mfdobj <- data_sim_mfd() inprod_mfd_diag(mfdobj)
mfd
Check that an argument is a multivariate
functional data object of class mfd
.
is.mfd(mfdobj)
is.mfd(mfdobj)
mfdobj |
An object to be checked. |
a logical value: TRUE if the class is correct, FALSE otherwise.
Add the plot of a new multivariate functional data object to an existing plot.
lines_mfd( plot_mfd_obj, mfdobj_new, mapping = NULL, data = NULL, stat = "identity", position = "identity", na.rm = TRUE, orientation = NA, show.legend = NA, inherit.aes = TRUE, type_mfd = "mfd", y_lim_equal = FALSE, ... )
lines_mfd( plot_mfd_obj, mfdobj_new, mapping = NULL, data = NULL, stat = "identity", position = "identity", na.rm = TRUE, orientation = NA, show.legend = NA, inherit.aes = TRUE, type_mfd = "mfd", y_lim_equal = FALSE, ... )
plot_mfd_obj |
A plot produced by |
mfdobj_new |
A new multivariate functional data object of class mfd to be plotted. |
mapping |
See |
data |
See |
stat |
See |
position |
See |
na.rm |
See |
orientation |
See |
show.legend |
See |
inherit.aes |
See |
type_mfd |
See |
y_lim_equal |
See |
... |
See |
A plot of the multivariate functional data object added to the existing one.
library(funcharts) library(ggplot2) mfdobj1 <- data_sim_mfd() mfdobj2 <- data_sim_mfd() p <- plot_mfd(mfdobj1) lines_mfd(p, mfdobj_new = mfdobj2)
library(funcharts) library(ggplot2) mfdobj1 <- data_sim_mfd() mfdobj2 <- data_sim_mfd() p <- plot_mfd(mfdobj1) lines_mfd(p, mfdobj_new = mfdobj2)
Computes the mean function for a multivariate functional data object of class mfd
.
mean_mfd(mfdobj)
mean_mfd(mfdobj)
mfdobj |
An object of class |
This function calculates the mean function for each dimension of the multivariate functional data by averaging the coefficients across all observations. The resulting object is a single observation containing the mean function for each dimension.
An mfd
object representing the mean function of the input data. The output contains
one observation, representing the mean function for each dimension of the multivariate functional variable.
## Not run: library(funcharts) data(air) mfdobj <- get_mfd_list(air) mean_result <- mean_mfd(mfdobj) plot_mfd(mean_result) ## End(Not run)
## Not run: library(funcharts) data(air) mfdobj <- get_mfd_list(air) mean_result <- mean_mfd(mfdobj) plot_mfd(mean_result) ## End(Not run)
This is the constructor function for objects of the mfd class.
It is a wrapper to fda::fd
,
but it forces the coef argument to be
a three-dimensional array of coefficients even if
the functional data is univariate.
Moreover, it allows to include the original raw data from which
you get the smooth functional data.
Finally, it also includes the matrix of precomputed inner products
of the basis functions, which can be useful to speed up computations
when calculating inner products between functional observations
mfd(coef, basisobj, fdnames = NULL, raw = NULL, id_var = NULL, B = NULL)
mfd(coef, basisobj, fdnames = NULL, raw = NULL, id_var = NULL, B = NULL)
coef |
A three-dimensional array of coefficients:
|
basisobj |
A functional basis object defining the basis,
as provided to |
fdnames |
A list of length 3, each member being a string vector containing labels for the levels of the corresponding dimension of the discrete data. The first dimension is for a single character indicating the argument values, i.e. the variable on the functional domain. The second is for replications, i.e. it denotes the functional observations. The third is for functional variables' names. |
raw |
A data frame containing the original discrete data. Default is NULL, however, if provided, it must contain: a column (indicated by the a column named as as many columns as the functional variables,
named as in |
id_var |
A single character value indicating the column
in the |
B |
A matrix with the inner products of the basis functions. If NULL, it is calculated from the basis object provided. Default is NULL. |
To check that an object is of this class, use function is.mfd.
A multivariate functional data object
(i.e., having class mfd
),
which is a list with components named
coefs
, basis
, and fdnames
,
as for class fd
,
with possibly in addition the components raw
and id_var
.
Ramsay, James O., and Silverman, Bernard W. (2006), Functional Data Analysis, 2nd ed., Springer, New York.
Ramsay, James O., and Silverman, Bernard W. (2002), Applied Functional Data Analysis, Springer, New York.
library(funcharts) library(fda) set.seed(0) nobs <- 5 nbasis <- 10 nvar <- 2 coef <- array(rnorm(nobs * nbasis * nvar), dim = c(nbasis, nobs, nvar)) bs <- create.bspline.basis(rangeval = c(0, 1), nbasis = nbasis) mfdobj <- mfd(coef = coef, basisobj = bs) plot_mfd(mfdobj)
library(funcharts) library(fda) set.seed(0) nobs <- 5 nbasis <- 10 nvar <- 2 coef <- array(rnorm(nobs * nbasis * nvar), dim = c(nbasis, nobs, nvar)) bs <- create.bspline.basis(rangeval = c(0, 1), nbasis = nbasis) mfdobj <- mfd(coef = coef, basisobj = bs) plot_mfd(mfdobj)
This function implements the mFPCA.
mFPCA(x_fd, h_fd = NULL, k_weights = "equal", ncom = "ptv", par_ncom = 0.9)
mFPCA(x_fd, h_fd = NULL, k_weights = "equal", ncom = "ptv", par_ncom = 0.9)
x_fd |
An object of class fd corresponding to the registered functions. |
h_fd |
An object of class fd corresponding to the warping functions. |
k_weights |
The vector of the four constants in the inner product computation. If "equal", the choice of Centofanti et al. (2024) is used. |
ncom |
It is the way to select the number of principal components. If "ptv", it is selected considering the percentage of the total variability explained. If "kaiserrule", it is selected considering the Kaiser rule. The number of principal components may be indicated directly as an integer as well. |
par_ncom |
If |
A list containing the following arguments:
eigfun_fd
A List of functions corresponding to the functional part of the principal components.
eigvect_sc
A matrix corresponding to the scalar part of the principal components.
scores
Scores corresponding to x_fd
and h_fd
.
values
Eigenvalues corresponding to the selected principal components.
varprop
Variance proportion explained by each principal component.
k_weights
The vector of the four constants in the inner product computation.
x_fd_list
A List of two elements: the list of the registered functions and the list of the centred log-ratio transformation of
the first derivatives of the normalized warping functions.
sc_mat
Two column matrix corresponding to the scalar part of the observations used.
mean_fd_list
Mean functions of the functional part.
mean_sc_mat
Means of the scalar part.
sd_fd_list
The standard deviation of the functional part.
sd_sc_mat
Standard deviations of the scalar part.
h_fd
An object of class fd corresponding to the warping functions.
x_fd
An object of class fd corresponding to the registered functions.
ind_var
Additional parameter used in FRTM_PhaseI
.
F. Centofanti
Centofanti, F., A. Lepore, M. Kulahci, and M. P. Spooner (2024). Real-time monitoring of functional data. Accepted for publication in Journal of Quality Technology.
library(funcharts) data <- simulate_data_FRTM(n_obs = 100) X <- sapply(1:100, function(ii) data$x_true[[ii]]) x_fd <- fda::smooth.basis(y = X, argvals = data$grid, fda::create.bspline.basis(c(0, 1), 30))$fd H <- sapply(1:100, function(ii) data$h[[ii]]) h_fd <- fda::smooth.basis(y = H, argvals = data$grid, fda::create.bspline.basis(c(0, 1), 30))$fd mod_mFPCA <- mFPCA(x_fd, h_fd, ncom = "ptv", par_ncom = 0.95) plot(mod_mFPCA)
library(funcharts) data <- simulate_data_FRTM(n_obs = 100) X <- sapply(1:100, function(ii) data$x_true[[ii]]) x_fd <- fda::smooth.basis(y = X, argvals = data$grid, fda::create.bspline.basis(c(0, 1), 30))$fd H <- sapply(1:100, function(ii) data$h[[ii]]) h_fd <- fda::smooth.basis(y = H, argvals = data$grid, fda::create.bspline.basis(c(0, 1), 30))$fd mod_mFPCA <- mFPCA(x_fd, h_fd, ncom = "ptv", par_ncom = 0.95) plot(mod_mFPCA)
Norm of multivariate functional data contained
in a mfd
object.
norm.mfd(mfdobj)
norm.mfd(mfdobj)
mfdobj |
A multivariate functional data object of class |
A vector of length equal to the number of replications
in mfdobj
,
containing the norm of each multivariate functional observation
in the product Hilbert space,
i.e. the sum of L^2 norms for each functional variable.
library(funcharts) mfdobj <- data_sim_mfd() norm.mfd(mfdobj)
library(funcharts) mfdobj <- data_sim_mfd() norm.mfd(mfdobj)
This function implements the OEB-FDTW.
OEBFDTW( x_fd, template_fd, der_x_fd, der_template_fd, alpha_vec = c(0, 0.5, 1), fit_c = FALSE, N = 100, M = 50, smin = 0.01, smax = 1000, lambda = 10^-5, eta = 0.5, iter = 3, delta_xs = 0, delta_xe = 0, delta_ys = 0, delta_ye = 0, der_0 = NULL, seq_t = NULL, get_fd = "no", n_basis_x = NULL )
OEBFDTW( x_fd, template_fd, der_x_fd, der_template_fd, alpha_vec = c(0, 0.5, 1), fit_c = FALSE, N = 100, M = 50, smin = 0.01, smax = 1000, lambda = 10^-5, eta = 0.5, iter = 3, delta_xs = 0, delta_xe = 0, delta_ys = 0, delta_ye = 0, der_0 = NULL, seq_t = NULL, get_fd = "no", n_basis_x = NULL )
x_fd |
An object of class fd corresponding to the misaligned function. |
template_fd |
An object of class fd corresponding to the template function. |
der_x_fd |
An object of class fd corresponding to the first derivative of |
der_template_fd |
An object of class fd corresponding to the first derivative of |
alpha_vec |
Grid of values to find the optimal value of |
fit_c |
If TRUE, the value of the objective function without the penalization evaluated at the solution is returned. |
N |
The number |
M |
The number |
smin |
The minimum values allowed for the first derivative of the warping function |
smax |
The maximum values allowed for the first derivative of the warping function |
lambda |
The smoothing parameter |
eta |
Fraction |
iter |
Number of iteration in the iterative refinement to reduce the error associated to the discretization (Deriso and Boyd, 2022). |
delta_xs |
Maximum allowed misalignment at the beginning of the process along the misaligned function domain. |
delta_xe |
Maximum allowed misalignment at the end of the process along the misaligned function domain. |
delta_ys |
Maximum allowed misalignment at the beginning of the process along the template domain. |
delta_ye |
Maximum allowed misalignment at the end of the process along the template domain. |
der_0 |
The target values towards which shrinking the warping function slope. If NULL, it is equal to the ratio between the size of the domain of |
seq_t |
Discretized sequence in the template domain |
get_fd |
If "x_reg", the registered function as a class fd object is returned. If "no", the registered function as a class fd object is not returned. |
n_basis_x |
Number of basis to obtain the registered function. If NULL, it is set as 0.5 the length of the optimal path. |
A list containing the following arguments:
mod
that is a list composed by
h_fd
: The estimated warping function.
x_reg
: The registered function.
h_list
: A list containing the discretized warping function for each iteration of the iterative refinement.
min_cost
: Optimal value of the objective function.
lambda
: The smoothing parameter .
alpha
: Optimal value of the parameter .
obj
Values of the objective function for each value in alpha_vec
.
fit
Values of the objective function without the penalization for each value in alpha_vec
.
obj_opt
Optimal value of the objective function.
fit_opt
Optimal value of the objective function without the penalization.
F. Centofanti
Centofanti, F., A. Lepore, M. Kulahci, and M. P. Spooner (2024). Real-time monitoring of functional data. Accepted for publication in Journal of Quality Technology.
Deriso, D. and S. Boyd (2022). A general optimization framework for dynamic time warping. Optimization and Engineering, 1-22.
set.seed(1) data <- simulate_data_FRTM(n_obs = 100) dom <- c(0, 1) basis_x <- fda::create.bspline.basis(c(0, 1), nbasis = 30) x_fd <- fda::smooth.basis(data$grid_i[[1]] / max(data$grid_i[[1]]), data$x_err[[1]], basis_x)$fd template_fd <- fda::smooth.basis(data$grid_template, data$template, basis_x)$fd der_x_fd <- fda::deriv.fd(x_fd, 1) der_template_fd <- fda::deriv.fd(template_fd, 1) mod <- OEBFDTW(x_fd, template_fd, der_x_fd , der_template_fd, get_fd = "x_reg")
set.seed(1) data <- simulate_data_FRTM(n_obs = 100) dom <- c(0, 1) basis_x <- fda::create.bspline.basis(c(0, 1), nbasis = 30) x_fd <- fda::smooth.basis(data$grid_i[[1]] / max(data$grid_i[[1]]), data$x_err[[1]], basis_x)$fd template_fd <- fda::smooth.basis(data$grid_template, data$template, basis_x)$fd der_x_fd <- fda::deriv.fd(x_fd, 1) der_template_fd <- fda::deriv.fd(template_fd, 1) mod <- OEBFDTW(x_fd, template_fd, der_x_fd , der_template_fd, get_fd = "x_reg")
This is an internal function of package FRTM
which allows controlling the parameters to implement the OEB-FDTW in the FRTM method.
par.FDTW( N = 100, M = 50, smin = NULL, smax = NULL, alpha_vec = c(0, 0.5, 1), frac_oeob = 0.1, eta = 0.5, iter = 3, template = "Procrustes", grid_tem = NULL, index_tem = NULL, iter_tem = 2, lambda = c(0, 10^seq(-8, -2, by = 0.25), 10^5), threshold = 0.01, seq_t = seq(0.01, 1, length.out = 100) )
par.FDTW( N = 100, M = 50, smin = NULL, smax = NULL, alpha_vec = c(0, 0.5, 1), frac_oeob = 0.1, eta = 0.5, iter = 3, template = "Procrustes", grid_tem = NULL, index_tem = NULL, iter_tem = 2, lambda = c(0, 10^seq(-8, -2, by = 0.25), 10^5), threshold = 0.01, seq_t = seq(0.01, 1, length.out = 100) )
N |
The number |
M |
The number |
smin |
The minimum values allowed for the first derivative of the warping function |
smax |
The maximum values allowed for the first derivative of the warping function |
alpha_vec |
Grid of values to find the optimal value of |
frac_oeob |
Fraction of |
eta |
Fraction |
iter |
Number of iteration in the iterative refinement to reduce the error associated to the discretization (Deriso and Boyd, 2022). |
template |
If "Procrustes", the Procrustes fitting process is used to select the template function. If |
grid_tem |
If |
index_tem |
If NULL and |
iter_tem |
Number of iterations in the Procrustes fitting process. |
lambda |
Grid of smoothing parameters to evaluate the average curve distance (ACD). |
threshold |
The fraction |
seq_t |
Discretized sequence in the template domain |
F. Centofanti
Deriso, D. and S. Boyd (2022). A general optimization framework for dynamic time warping. Optimization and Engineering, 1-22.
library(funcharts) par.FDTW()
library(funcharts) par.FDTW()
This is an internal function of package FRTM
which allows controlling the parameters used in the mFPCA in the FRTM method.
par.mFPCA(perc_pca = 0.9, perc_basis_x_pca = 1, perc_basis_h = 0.2)
par.mFPCA(perc_pca = 0.9, perc_basis_x_pca = 1, perc_basis_h = 0.2)
perc_pca |
Percentage of the total variability used to select the number |
perc_basis_x_pca |
Multiplied by the maximum number of basis of the registered functions for each time point in |
perc_basis_h |
Multiplied by the mean number of basis of the warping functions for each time point in |
library(funcharts) par.mFPCA()
library(funcharts) par.mFPCA()
This is an internal function of package FRTM
which allows controlling the parameters to implement real-time registration step in the FRTM method.
par.rtr( seq_x = NULL, delta_d = 0.05, delta_v = 0.03, delta_c = 0.04, Delta = 0.1, length_grid_window = 10, length_grid_owindow = 20, eval_seq_der = seq(0.02, 0.1, length.out = 10), perc_basis_x_reg = 0.3 )
par.rtr( seq_x = NULL, delta_d = 0.05, delta_v = 0.03, delta_c = 0.04, Delta = 0.1, length_grid_window = 10, length_grid_owindow = 20, eval_seq_der = seq(0.02, 0.1, length.out = 10), perc_basis_x_reg = 0.3 )
seq_x |
Discretized sequence in the monitoring domain |
delta_d |
The parameter |
delta_v |
The parameter |
delta_c |
The parameter |
Delta |
The parameter |
length_grid_window |
Number of points to be explored in the interval of the band constraint for each point in |
length_grid_owindow |
Number of points to be explored in the interval of the band constraint for each point in |
eval_seq_der |
If multiplied by the template domain range, the distances from the domain right boundaries over which are calculated the first derivative to mitigate the effects of possible estimation errors in the adaptive band constraint calculation. |
perc_basis_x_reg |
Multiplied by the number of observed discrete points, it is the number of basis functions used in the real-time registration step for each time point.
This latter number cannot be grater than |
F. Centofanti
library(funcharts) par.rtr()
library(funcharts) par.rtr()
Multivariate functional principal components analysis (MFPCA)
performed on an object of class mfd
.
It is a wrapper to fda::pca.fd
,
providing some additional arguments.
pca_mfd(mfdobj, scale = TRUE, nharm = 20)
pca_mfd(mfdobj, scale = TRUE, nharm = 20)
mfdobj |
A multivariate functional data object of class mfd. |
scale |
If TRUE, it scales data before doing MFPCA
using |
nharm |
Number of multivariate functional principal components to be calculated. Default is 20. |
Modified pca.fd
object, with
multivariate functional principal component scores summed over variables
(fda::pca.fd
returns an array of scores
when providing a multivariate functional data object).
Moreover, the multivariate functional principal components
given in harmonics
are converted to the mfd
class.
library(funcharts) mfdobj <- data_sim_mfd() pca_obj <- pca_mfd(mfdobj) plot_pca_mfd(pca_obj)
library(funcharts) mfdobj <- data_sim_mfd() pca_obj <- pca_mfd(mfdobj) plot_pca_mfd(pca_obj)
This function produces a list of objects,
each of them contains the result of applying pca_mfd
to
a multivariate functional data object
evolved up to an intermediate domain point.
pca_mfd_real_time(mfdobj_list, scale = TRUE, nharm = 20, ncores = 1)
pca_mfd_real_time(mfdobj_list, scale = TRUE, nharm = 20, ncores = 1)
mfdobj_list |
A list created using
|
scale |
See |
nharm |
See |
ncores |
If you want parallelization, give the number of cores/threads to be used when creating objects separately for different instants. |
A list of lists each produced by pca_mfd
,
corresponding to a given instant.
C. Capezza
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) mfdobj_list <- get_mfd_list_real_time(air[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = seq(0.25, 1, length = 5)) mod_list <- pca_mfd_real_time(mfdobj_list)
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) mfdobj_list <- get_mfd_list_real_time(air[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = seq(0.25, 1, length = 5)) mod_list <- pca_mfd_real_time(mfdobj_list)
Plot an object of class bifd
using
ggplot2
and geom_tile
.
The object must contain only one single functional replication.
plot_bifd(bifd_obj, type_plot = "raster", phi = 40, theta = 40)
plot_bifd(bifd_obj, type_plot = "raster", phi = 40, theta = 40)
bifd_obj |
A bivariate functional data object of class bifd, containing one single replication. |
type_plot |
a character value If "raster", it plots the bivariate functional data object as a raster image. If "contour", it produces a contour plot. If "perspective", it produces a perspective plot. Default value is "raster". |
phi |
If |
theta |
If |
A ggplot with a geom_tile layer providing a plot of the bivariate functional data object as a heat map.
library(funcharts) mfdobj <- data_sim_mfd(nobs = 1) tp <- tensor_product_mfd(mfdobj) plot_bifd(tp)
library(funcharts) mfdobj <- data_sim_mfd(nobs = 1) tp <- tensor_product_mfd(mfdobj) plot_bifd(tp)
Plot bootstrapped estimates of the scalar-on-function regression coefficient for empirical uncertainty quantification. For each iteration, a data set is sampled with replacement from the training data use to fit the model, and the regression coefficient is estimated.
plot_bootstrap_sof_pc(mod, nboot = 25, ncores = 1)
plot_bootstrap_sof_pc(mod, nboot = 25, ncores = 1)
mod |
A list obtained as output from |
nboot |
Number of bootstrap replicates |
ncores |
If you want estimate the bootstrap replicates in parallel, give the number of cores/threads. |
A ggplot showing several bootstrap replicates of the multivariate functional coefficients estimated fitting the scalar-on-function linear model. Gray lines indicate the different bootstrap estimates, the black line indicate the estimate on the entire dataset.
C. Capezza
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], lambda = 1e-2) y <- rowMeans(air$NO2) mod <- sof_pc(y, mfdobj_x) plot_bootstrap_sof_pc(mod, nboot = 5)
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], lambda = 1e-2) y <- rowMeans(air$NO2) mod <- sof_pc(y, mfdobj_x) plot_bootstrap_sof_pc(mod, nboot = 5)
This function takes as input a data frame produced
with functions such as
control_charts_pca
and control_charts_sof_pc
and
produces a ggplot with the desired control charts, i.e.
it plots a point for each
observation in the phase II data set against
the corresponding control limits.
plot_control_charts(cclist, nobsI = 0)
plot_control_charts(cclist, nobsI = 0)
cclist |
A |
nobsI |
An integer indicating the first observations that are plotted in gray.
It is useful when one wants to plot the phase I data set together
with the phase II data. In that case, one needs to indicate the number
of phase I observations included in |
Out-of-control points are signaled by colouring them in red.
A ggplot with the functional control charts.
library(funcharts) data("air") air <- lapply(air, function(x) x[1:100, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) mfdobj_y <- get_mfd_list(air["NO2"], n_basis = 15, lambda = 1e-2) mfdobj_y1 <- mfdobj_y[1:60] mfdobj_y_tuning <- mfdobj_y[61:90] mfdobj_y2 <- mfdobj_y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod_fof <- fof_pc(mfdobj_y1, mfdobj_x1) cclist <- regr_cc_fof(mod_fof, mfdobj_y_new = mfdobj_y2, mfdobj_x_new = mfdobj_x2, mfdobj_y_tuning = NULL, mfdobj_x_tuning = NULL) plot_control_charts(cclist)
library(funcharts) data("air") air <- lapply(air, function(x) x[1:100, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) mfdobj_y <- get_mfd_list(air["NO2"], n_basis = 15, lambda = 1e-2) mfdobj_y1 <- mfdobj_y[1:60] mfdobj_y_tuning <- mfdobj_y[61:90] mfdobj_y2 <- mfdobj_y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod_fof <- fof_pc(mfdobj_y1, mfdobj_x1) cclist <- regr_cc_fof(mod_fof, mfdobj_y_new = mfdobj_y2, mfdobj_x_new = mfdobj_x2, mfdobj_y_tuning = NULL, mfdobj_x_tuning = NULL) plot_control_charts(cclist)
This function produces a ggplot
with the desired real-time control charts.
It takes as input a list of data frames, produced
with functions such as
regr_cc_fof_real_time
and
control_charts_sof_pc_real_time
,
and the id of the observations for which real-time control charts
are desired to be plotted.
For each control chart, the solid line corresponds to the
profile of the monitoring statistic and it is compared against
control limits plotted as dashed lines.
If a line is outside its limits it is coloured in red.
plot_control_charts_real_time(cclist, id_num)
plot_control_charts_real_time(cclist, id_num)
cclist |
A list of data frames, produced
with functions such as
|
id_num |
An index number giving the observation in the phase II data set to be plotted, i.e. 1 for the first observation, 2 for the second, and so on. |
If the line, representing the profile of the monitoring statistic over the functional domain, is out-of-control, then it is coloured in red.
A ggplot with the real-time functional control charts.
regr_cc_fof_real_time
,
control_charts_sof_pc_real_time
library(funcharts) data("air") air1 <- lapply(air, function(x) x[1:8, , drop = FALSE]) air2 <- lapply(air, function(x) x[9:10, , drop = FALSE]) mfdobj_x1_list <- get_mfd_list_real_time(air1[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_x2_list <- get_mfd_list_real_time(air2[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) y1 <- rowMeans(air1$NO2) y2 <- rowMeans(air2$NO2) mod_list <- sof_pc_real_time(y1, mfdobj_x1_list) cclist <- regr_cc_sof_real_time( mod_list = mod_list, y_new = y2, mfdobj_x_new = mfdobj_x2_list, include_covariates = TRUE) plot_control_charts_real_time(cclist, 1)
library(funcharts) data("air") air1 <- lapply(air, function(x) x[1:8, , drop = FALSE]) air2 <- lapply(air, function(x) x[9:10, , drop = FALSE]) mfdobj_x1_list <- get_mfd_list_real_time(air1[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_x2_list <- get_mfd_list_real_time(air2[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) y1 <- rowMeans(air1$NO2) y2 <- rowMeans(air2$NO2) mod_list <- sof_pc_real_time(y1, mfdobj_x1_list) cclist <- regr_cc_sof_real_time( mod_list = mod_list, y_new = y2, mfdobj_x_new = mfdobj_x2_list, include_covariates = TRUE) plot_control_charts_real_time(cclist, 1)
Plot an object of class mfd
using ggplot2
and patchwork
.
plot_mfd( mfdobj, mapping = NULL, data = NULL, stat = "identity", position = "identity", na.rm = TRUE, orientation = NA, show.legend = NA, inherit.aes = TRUE, type_mfd = "mfd", y_lim_equal = FALSE, ... )
plot_mfd( mfdobj, mapping = NULL, data = NULL, stat = "identity", position = "identity", na.rm = TRUE, orientation = NA, show.legend = NA, inherit.aes = TRUE, type_mfd = "mfd", y_lim_equal = FALSE, ... )
mfdobj |
A multivariate functional data object of class mfd. |
mapping |
Set of aesthetic mappings additional
to |
data |
A |
stat |
See |
position |
See |
na.rm |
See |
orientation |
See |
show.legend |
See |
inherit.aes |
See |
type_mfd |
A character value equal to "mfd" or "raw". If "mfd", the smoothed functional data are plotted, if "raw", the original discrete data are plotted. |
y_lim_equal |
A logical value. If |
... |
See |
A plot of the multivariate functional data object.
library(funcharts) library(ggplot2) mfdobj <- data_sim_mfd() ids <- mfdobj$fdnames[[2]] df <- data.frame(id = ids, first_two_obs = ids %in% c("rep1", "rep2")) plot_mfd(mapping = aes(colour = first_two_obs), data = df, mfdobj = mfdobj)
library(funcharts) library(ggplot2) mfdobj <- data_sim_mfd() ids <- mfdobj$fdnames[[2]] df <- data.frame(id = ids, first_two_obs = ids %in% c("rep1", "rep2")) plot_mfd(mapping = aes(colour = first_two_obs), data = df, mfdobj = mfdobj)
This function plots selected functions in a phase_II monitoring data set against the corresponding training data set to be compared.
plot_mon(cclist, fd_train, fd_test, plot_title = FALSE, print_id = FALSE)
plot_mon(cclist, fd_train, fd_test, plot_title = FALSE, print_id = FALSE)
cclist |
A |
fd_train |
An object of class |
fd_test |
An object of class |
plot_title |
A logical value. If |
print_id |
A logical value. If |
A ggplot of the multivariate functional data.
In particular, the multivariate functional data given in
fd_train
are plotted on
the background in gray, while the multivariate functional data given in
fd_test
are
plotted on the foreground, the colour
of each curve is black or red depending on if that curve
was signal as anomalous by at least a contribution plot.
library(funcharts) data("air") air <- lapply(air, function(x) x[201:300, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:60] y_tuning <- y[61:90] y2 <- y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod <- sof_pc(y1, mfdobj_x1) cclist <- regr_cc_sof(object = mod, y_new = y2, mfdobj_x_new = mfdobj_x2, y_tuning = y_tuning, mfdobj_x_tuning = mfdobj_x_tuning, include_covariates = TRUE) get_ooc(cclist) cont_plot(cclist, 3) plot_mon(cclist, fd_train = mfdobj_x1, fd_test = mfdobj_x2[3])
library(funcharts) data("air") air <- lapply(air, function(x) x[201:300, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:60] y_tuning <- y[61:90] y2 <- y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod <- sof_pc(y1, mfdobj_x1) cclist <- regr_cc_sof(object = mod, y_new = y2, mfdobj_x_new = mfdobj_x2, y_tuning = y_tuning, mfdobj_x_tuning = mfdobj_x_tuning, include_covariates = TRUE) get_ooc(cclist) cont_plot(cclist, 3) plot_mon(cclist, fd_train = mfdobj_x1, fd_test = mfdobj_x2[3])
pca_mfd
objectPlot the harmonics of a pca_mfd
object
plot_pca_mfd(pca, harm = 0, scaled = FALSE)
plot_pca_mfd(pca, harm = 0, scaled = FALSE)
pca |
A fitted multivariate functional principal component analysis
(MFPCA) object of class |
harm |
A vector of integers with the harmonics to plot. If 0, all harmonics are plotted. Default is 0. |
scaled |
If TRUE, eigenfunctions are multiplied by the square root of the corresponding eigenvalues, if FALSE the are not scaled and the all have unit norm. Default is FALSE |
A ggplot of the harmonics/multivariate functional
principal components contained in the object pca
.
library(funcharts) mfdobj <- data_sim_mfd() pca_obj <- pca_mfd(mfdobj) plot_pca_mfd(pca_obj)
library(funcharts) mfdobj <- data_sim_mfd() pca_obj <- pca_mfd(mfdobj) plot_pca_mfd(pca_obj)
This function provides plots of the Hotelling's and SPE control charts.
## S3 method for class 'FRTM_PhaseI' plot(x, ...) ## S3 method for class 'FRTM_PhaseII' plot(x, ...)
## S3 method for class 'FRTM_PhaseI' plot(x, ...) ## S3 method for class 'FRTM_PhaseII' plot(x, ...)
x |
The output of either |
... |
A variable |
No return value, called for side effects.
library(funcharts) data <- simulate_data_FRTM(n_obs = 20) data_oc <- simulate_data_FRTM( n_obs = 2, scenario = "1", shift = "OC_h", severity = 0.5 ) lambda <- 10 ^ -5 max_x <- max(unlist(data$grid_i)) seq_t_tot <- seq(0, 1, length.out = 30)[-1] seq_x <- seq(0.1, max_x, length.out = 10) ## Not run: mod_phaseI_FRTM <- FRTM_PhaseI( data_tra = data, control.FDTW = list( M = 30, N = 30, lambda = lambda, seq_t = seq_t_tot, iter_tem = 1, iter = 1 ), control.rtr = list(seq_x = seq_x) ) mod_phaseII_FRTM <- FRTM_PhaseII(data_oc = data_oc , mod_phaseI = mod_phaseI_FRTM) plot(mod_phaseI_FRTM) plot(mod_phaseII_FRTM) ## End(Not run)
library(funcharts) data <- simulate_data_FRTM(n_obs = 20) data_oc <- simulate_data_FRTM( n_obs = 2, scenario = "1", shift = "OC_h", severity = 0.5 ) lambda <- 10 ^ -5 max_x <- max(unlist(data$grid_i)) seq_t_tot <- seq(0, 1, length.out = 30)[-1] seq_x <- seq(0.1, max_x, length.out = 10) ## Not run: mod_phaseI_FRTM <- FRTM_PhaseI( data_tra = data, control.FDTW = list( M = 30, N = 30, lambda = lambda, seq_t = seq_t_tot, iter_tem = 1, iter = 1 ), control.rtr = list(seq_x = seq_x) ) mod_phaseII_FRTM <- FRTM_PhaseII(data_oc = data_oc , mod_phaseI = mod_phaseI_FRTM) plot(mod_phaseI_FRTM) plot(mod_phaseII_FRTM) ## End(Not run)
This function provides plots of the principal components of the mFPCA.
## S3 method for class 'mFPCA' plot(x, ...)
## S3 method for class 'mFPCA' plot(x, ...)
x |
The output of |
... |
A variable |
No return value, called for side effects.
library(funcharts) data <- simulate_data_FRTM(n_obs = 100) X <- sapply(1:100, function(ii) data$x_true[[ii]]) x_fd <- fda::smooth.basis(y = X, argvals = data$grid, fda::create.bspline.basis(c(0, 1), 30))$fd H <- sapply(1:100, function(ii) data$h[[ii]]) h_fd <- fda::smooth.basis(y = H, argvals = data$grid, fda::create.bspline.basis(c(0, 1), 30))$fd mod_mFPCA <- mFPCA(x_fd, h_fd, ncom = "ptv", par_ncom = 0.95) plot(mod_mFPCA)
library(funcharts) data <- simulate_data_FRTM(n_obs = 100) X <- sapply(1:100, function(ii) data$x_true[[ii]]) x_fd <- fda::smooth.basis(y = X, argvals = data$grid, fda::create.bspline.basis(c(0, 1), 30))$fd H <- sapply(1:100, function(ii) data$h[[ii]]) h_fd <- fda::smooth.basis(y = H, argvals = data$grid, fda::create.bspline.basis(c(0, 1), 30))$fd mod_mFPCA <- mFPCA(x_fd, h_fd, ncom = "ptv", par_ncom = 0.95) plot(mod_mFPCA)
Predict new observations of the functional response variable and calculate the corresponding prediction error (and their standardized or studentized version) given new observations of functional covariates and a fitted function-on-function linear regression model.
predict_fof_pc(object, mfdobj_y_new, mfdobj_x_new)
predict_fof_pc(object, mfdobj_y_new, mfdobj_x_new)
object |
A list obtained as output from |
mfdobj_y_new |
An object of class |
mfdobj_x_new |
An object of class |
A list of mfd objects. It contains:
pred_error
: the prediction error of the
standardized functional response variable,
pred_error_original_scale
:
the prediction error of the functional
response variable on the original scale,
y_hat_new
: the prediction of the
functional response observations on the original scale,
y_z_new
: the standardized version of the
functional response observations provided in mfdobj_y_new
,
y_hat_z_new
: the prediction of the
functional response observations on the standardized/studentized scale.
C. Capezza, F. Centofanti
Centofanti F, Lepore A, Menafoglio A, Palumbo B, Vantini S. (2021) Functional Regression Control Chart. Technometrics, 63(3), 281–294. doi:10.1080/00401706.2020.1753581
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], lambda = 1e-2) mfdobj_y <- get_mfd_list(air["NO2"], lambda = 1e-2) mod <- fof_pc(mfdobj_y, mfdobj_x) predict_fof_pc(mod, mfdobj_y_new = mfdobj_y, mfdobj_x_new = mfdobj_x)
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], lambda = 1e-2) mfdobj_y <- get_mfd_list(air["NO2"], lambda = 1e-2) mod <- fof_pc(mfdobj_y, mfdobj_x) predict_fof_pc(mod, mfdobj_y_new = mfdobj_y, mfdobj_x_new = mfdobj_x)
Predict new observations of the scalar response variable and calculate the corresponding prediction error, with prediction interval limits, given new observations of functional covariates and a fitted scalar-on-function linear regression model
predict_sof_pc( object, y_new = NULL, mfdobj_x_new = NULL, alpha = 0.05, newdata )
predict_sof_pc( object, y_new = NULL, mfdobj_x_new = NULL, alpha = 0.05, newdata )
object |
A list obtained as output from |
y_new |
A numeric vector containing the new observations of the scalar response variable to be predicted. |
mfdobj_x_new |
An object of class |
alpha |
A numeric value indicating the Type I error
for the regression control chart
and such that this function returns the |
newdata |
Deprecated, use |
A data.frame
with as many rows as the
number of functional replications in newdata
,
with the following columns:
fit
: the predictions of the response variable
corresponding to new_data
,
lwr
:
lower limit of the 1-alpha
prediction interval
on the response, based on the assumption that it is normally distributed.
upr
:
upper limit of the 1-alpha
prediction interval
on the response, based on the assumption that it is normally distributed.
res
:
the residuals obtained as the values of y_new
minus their
fitted values. If the scalar-on-function model has been fitted with
type_residual == "studentized"
, then the studentized residuals
are calculated.
C. Capezza
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], lambda = 1e-2) y <- rowMeans(air$NO2) mod <- sof_pc(y, mfdobj_x) predict_sof_pc(mod)
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], lambda = 1e-2) y <- rowMeans(air$NO2) mod <- sof_pc(y, mfdobj_x) predict_sof_pc(mod)
Bind replications of two Multivariate Functional Data Objects
rbind_mfd(mfdobj1, mfdobj2)
rbind_mfd(mfdobj1, mfdobj2)
mfdobj1 |
An object of class mfd, with the same variables of mfdobj2 and different replication names with respect to mfdobj2. |
mfdobj2 |
An object of class mfd, with the same variables of mfdobj1, and different replication names with respect to mfdobj1. |
An object of class mfd, whose variables are the same of mfdobj1 and mfdobj2 and whose replications are the union of the replications in mfdobj1 and mfdobj2.
library(funcharts) mfdobj1 <- data_sim_mfd(nvar = 3, nobs = 4) mfdobj2 <- data_sim_mfd(nvar = 3, nobs = 5) dimnames(mfdobj2$coefs)[[2]] <- mfdobj2$fdnames[[2]] <- c("rep11", "rep12", "rep13", "rep14", "rep15") mfdobj_rbind <- rbind_mfd(mfdobj1, mfdobj2) plot_mfd(mfdobj_rbind)
library(funcharts) mfdobj1 <- data_sim_mfd(nvar = 3, nobs = 4) mfdobj2 <- data_sim_mfd(nvar = 3, nobs = 5) dimnames(mfdobj2$coefs)[[2]] <- mfdobj2$fdnames[[2]] <- c("rep11", "rep12", "rep13", "rep14", "rep15") mfdobj_rbind <- rbind_mfd(mfdobj1, mfdobj2) plot_mfd(mfdobj_rbind)
It builds a data frame needed to plot the Functional Regression Control Chart introduced in Centofanti et al. (2021), for monitoring a functional quality characteristic adjusted for by the effect of multivariate functional covariates, based on a fitted function-on-function linear regression model. The training data have already been used to fit the model. An optional tuning data set can be provided that is used to estimate the control chart limits. A phase II data set contains the observations to be monitored with the control charts. It also allows to jointly monitor the multivariate functional covariates.
regr_cc_fof( object, mfdobj_y_new, mfdobj_x_new, mfdobj_y_tuning = NULL, mfdobj_x_tuning = NULL, alpha = 0.05, include_covariates = FALSE, absolute_error = FALSE )
regr_cc_fof( object, mfdobj_y_new, mfdobj_x_new, mfdobj_y_tuning = NULL, mfdobj_x_tuning = NULL, alpha = 0.05, include_covariates = FALSE, absolute_error = FALSE )
object |
A list obtained as output from |
mfdobj_y_new |
An object of class |
mfdobj_x_new |
An object of class |
mfdobj_y_tuning |
An object of class |
mfdobj_x_tuning |
An object of class |
alpha |
If it is a number between 0 and 1,
it defines the overall type-I error probability.
By default, it is equal to 0.05 and the Bonferroni correction
is applied by setting the type-I error probabilities equal to
|
include_covariates |
If TRUE, also functional covariates are monitored through
|
absolute_error |
A logical value that, if |
A data.frame
containing the output of the
function control_charts_pca
applied to
the prediction errors.
F. Centofanti
Centofanti F, Lepore A, Menafoglio A, Palumbo B, Vantini S. (2021) Functional Regression Control Chart. Technometrics, 63(3), 281–294. doi:10.1080/00401706.2020.1753581
library(funcharts) data("air") air <- lapply(air, function(x) x[1:100, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) mfdobj_y <- get_mfd_list(air["NO2"], n_basis = 15, lambda = 1e-2) mfdobj_y1 <- mfdobj_y[1:60] mfdobj_y_tuning <- mfdobj_y[61:90] mfdobj_y2 <- mfdobj_y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod_fof <- fof_pc(mfdobj_y1, mfdobj_x1) cclist <- regr_cc_fof(mod_fof, mfdobj_y_new = mfdobj_y2, mfdobj_x_new = mfdobj_x2, mfdobj_y_tuning = NULL, mfdobj_x_tuning = NULL) plot_control_charts(cclist)
library(funcharts) data("air") air <- lapply(air, function(x) x[1:100, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) mfdobj_y <- get_mfd_list(air["NO2"], n_basis = 15, lambda = 1e-2) mfdobj_y1 <- mfdobj_y[1:60] mfdobj_y_tuning <- mfdobj_y[61:90] mfdobj_y2 <- mfdobj_y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod_fof <- fof_pc(mfdobj_y1, mfdobj_x1) cclist <- regr_cc_fof(mod_fof, mfdobj_y_new = mfdobj_y2, mfdobj_x_new = mfdobj_x2, mfdobj_y_tuning = NULL, mfdobj_x_tuning = NULL) plot_control_charts(cclist)
This function produces a list of data frames,
each of them is produced by regr_cc_fof
and is needed to plot control charts for monitoring in real time
a functional quality characteristic adjusted for
by the effect of multivariate functional covariates.
regr_cc_fof_real_time( mod_list, mfdobj_y_new_list, mfdobj_x_new_list, mfdobj_y_tuning_list = NULL, mfdobj_x_tuning_list = NULL, alpha = 0.05, include_covariates = FALSE, absolute_error = FALSE, ncores = 1 )
regr_cc_fof_real_time( mod_list, mfdobj_y_new_list, mfdobj_x_new_list, mfdobj_y_tuning_list = NULL, mfdobj_x_tuning_list = NULL, alpha = 0.05, include_covariates = FALSE, absolute_error = FALSE, ncores = 1 )
mod_list |
A list of lists produced by |
mfdobj_y_new_list |
A list created using
|
mfdobj_x_new_list |
A list created using
|
mfdobj_y_tuning_list |
A list created using
|
mfdobj_x_tuning_list |
A list created using
|
alpha |
See |
include_covariates |
See |
absolute_error |
See |
ncores |
If you want parallelization, give the number of cores/threads to be used when creating objects separately for different instants. |
A list of data.frame
s each
produced by regr_cc_fof
,
corresponding to a given instant.
library(funcharts) data("air") air1 <- lapply(air, function(x) x[1:8, , drop = FALSE]) air2 <- lapply(air, function(x) x[9:10, , drop = FALSE]) mfdobj_x1_list <- get_mfd_list_real_time(air1[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_x2_list <- get_mfd_list_real_time(air2[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_y1_list <- get_mfd_list_real_time(air1["NO2"], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_y2_list <- get_mfd_list_real_time(air2["NO2"], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mod_list <- fof_pc_real_time(mfdobj_y1_list, mfdobj_x1_list) cclist <- regr_cc_fof_real_time( mod_list = mod_list, mfdobj_y_new_list = mfdobj_y2_list, mfdobj_x_new_list = mfdobj_x2_list) plot_control_charts_real_time(cclist, 1)
library(funcharts) data("air") air1 <- lapply(air, function(x) x[1:8, , drop = FALSE]) air2 <- lapply(air, function(x) x[9:10, , drop = FALSE]) mfdobj_x1_list <- get_mfd_list_real_time(air1[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_x2_list <- get_mfd_list_real_time(air2[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_y1_list <- get_mfd_list_real_time(air1["NO2"], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_y2_list <- get_mfd_list_real_time(air2["NO2"], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mod_list <- fof_pc_real_time(mfdobj_y1_list, mfdobj_x1_list) cclist <- regr_cc_fof_real_time( mod_list = mod_list, mfdobj_y_new_list = mfdobj_y2_list, mfdobj_x_new_list = mfdobj_x2_list) plot_control_charts_real_time(cclist, 1)
This function is deprecated. Use regr_cc_sof
.
This function builds a data frame needed
to plot the scalar-on-function regression control chart,
based on a fitted function-on-function linear regression model and
proposed in Capezza et al. (2020).
If include_covariates
is TRUE
,
it also plots the Hotelling's T2 and
squared prediction error control charts built on the
multivariate functional covariates.
regr_cc_sof( object, y_new, mfdobj_x_new, y_tuning = NULL, mfdobj_x_tuning = NULL, alpha = 0.05, parametric_limits = FALSE, include_covariates = FALSE, absolute_error = FALSE )
regr_cc_sof( object, y_new, mfdobj_x_new, y_tuning = NULL, mfdobj_x_tuning = NULL, alpha = 0.05, parametric_limits = FALSE, include_covariates = FALSE, absolute_error = FALSE )
object |
A list obtained as output from |
y_new |
A numeric vector containing the observations of the scalar response variable in the phase II data set. |
mfdobj_x_new |
An object of class |
y_tuning |
A numeric vector containing the observations of the scalar response variable in the tuning data set. If NULL, the training data, i.e. the data used to fit the scalar-on-function regression model, are also used as the tuning data set. Default is NULL. |
mfdobj_x_tuning |
An object of class |
alpha |
If it is a number between 0 and 1,
it defines the overall type-I error probability.
If |
parametric_limits |
If |
include_covariates |
If TRUE, also functional covariates are monitored through
|
absolute_error |
A logical value that, if |
The training data have already been used to fit the model. An additional tuning data set can be provided that is used to estimate the control chart limits. A phase II data set contains the observations to be monitored with the built control charts.
A data.frame
with as many rows as the
number of functional replications in mfdobj_x_new
,
with the following columns:
y_hat
: the predictions of the response variable
corresponding to mfdobj_x_new
,
y
: the same as the argument y_new
given as input
to this function,
lwr
: lower limit of the 1-alpha
prediction interval
on the response,
pred_err
: prediction error calculated as y-y_hat
,
pred_err_sup
: upper limit of the 1-alpha
prediction interval
on the prediction error,
pred_err_inf
: lower limit of the 1-alpha
prediction interval
on the prediction error.
C. Capezza
Capezza C, Lepore A, Menafoglio A, Palumbo B, Vantini S. (2020) Control charts for monitoring ship operating conditions and CO2 emissions based on scalar-on-function regression. Applied Stochastic Models in Business and Industry, 36(3):477–500. doi:10.1002/asmb.2507
library(funcharts) air <- lapply(air, function(x) x[1:100, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:80] y2 <- y[81:100] mfdobj_x1 <- mfdobj_x[1:80] mfdobj_x2 <- mfdobj_x[81:100] mod <- sof_pc(y1, mfdobj_x1) cclist <- regr_cc_sof(object = mod, y_new = y2, mfdobj_x_new = mfdobj_x2) plot_control_charts(cclist)
library(funcharts) air <- lapply(air, function(x) x[1:100, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:80] y2 <- y[81:100] mfdobj_x1 <- mfdobj_x[1:80] mfdobj_x2 <- mfdobj_x[81:100] mod <- sof_pc(y1, mfdobj_x1) cclist <- regr_cc_sof(object = mod, y_new = y2, mfdobj_x_new = mfdobj_x2) plot_control_charts(cclist)
This function builds a list of data frames,
each of them is produced by regr_cc_sof
and is needed to plot control charts for monitoring in real time
a scalar quality characteristic adjusted for
by the effect of multivariate functional covariates.
The training data have already been used to fit the model.
An additional tuning data set can be provided that is used to estimate
the control chart limits.
A phase II data set contains the observations to be monitored
with the built control charts.
regr_cc_sof_real_time( mod_list, y_new, mfdobj_x_new_list, y_tuning = NULL, mfdobj_x_tuning_list = NULL, alpha = 0.05, parametric_limits = TRUE, include_covariates = FALSE, absolute_error = FALSE, ncores = 1 )
regr_cc_sof_real_time( mod_list, y_new, mfdobj_x_new_list, y_tuning = NULL, mfdobj_x_tuning_list = NULL, alpha = 0.05, parametric_limits = TRUE, include_covariates = FALSE, absolute_error = FALSE, ncores = 1 )
mod_list |
A list of lists produced by |
y_new |
A numeric vector containing the observations of the scalar response variable in the phase II monitoring data set. |
mfdobj_x_new_list |
A list created using
|
y_tuning |
An optional numeric vector containing the observations of
the scalar response variable in the tuning data set.
If NULL, the training data, i.e. the scalar response
in |
mfdobj_x_tuning_list |
A list created using
|
alpha |
See |
parametric_limits |
See |
include_covariates |
See |
absolute_error |
See |
ncores |
If you want parallelization, give the number of cores/threads to be used when creating objects separately for different instants. |
A list of data.frame
s each
produced by regr_cc_sof
,
corresponding to a given instant.
library(funcharts) data("air") air1 <- lapply(air, function(x) x[1:8, , drop = FALSE]) air2 <- lapply(air, function(x) x[9:10, , drop = FALSE]) mfdobj_x1_list <- get_mfd_list_real_time(air1[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_x2_list <- get_mfd_list_real_time(air2[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_y1_list <- get_mfd_list_real_time(air1["NO2"], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_y2_list <- get_mfd_list_real_time(air2["NO2"], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mod_list <- fof_pc_real_time(mfdobj_y1_list, mfdobj_x1_list) cclist <- regr_cc_fof_real_time( mod_list = mod_list, mfdobj_y_new_list = mfdobj_y2_list, mfdobj_x_new_list = mfdobj_x2_list) plot_control_charts_real_time(cclist, 1)
library(funcharts) data("air") air1 <- lapply(air, function(x) x[1:8, , drop = FALSE]) air2 <- lapply(air, function(x) x[9:10, , drop = FALSE]) mfdobj_x1_list <- get_mfd_list_real_time(air1[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_x2_list <- get_mfd_list_real_time(air2[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_y1_list <- get_mfd_list_real_time(air1["NO2"], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mfdobj_y2_list <- get_mfd_list_real_time(air2["NO2"], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 1)) mod_list <- fof_pc_real_time(mfdobj_y1_list, mfdobj_x1_list) cclist <- regr_cc_fof_real_time( mod_list = mod_list, mfdobj_y_new_list = mfdobj_y2_list, mfdobj_x_new_list = mfdobj_x2_list) plot_control_charts_real_time(cclist, 1)
It performs Phase I of the Robust Multivariate Functional Control Chart (RoMFCC) as proposed by Capezza et al. (2024).
RoMFCC_PhaseI( mfdobj, mfdobj_tuning = NULL, functional_filter_par = list(filter = TRUE), imputation_par = list(method_imputation = "RoMFDI"), pca_par = list(fev = 0.7), alpha = 0.05 )
RoMFCC_PhaseI( mfdobj, mfdobj_tuning = NULL, functional_filter_par = list(filter = TRUE), imputation_par = list(method_imputation = "RoMFDI"), pca_par = list(fev = 0.7), alpha = 0.05 )
mfdobj |
A multivariate functional data object of class mfd. A functional filter is applied to this data set, then flagged functional componentwise outliers are imputed in the robust imputation step. Finally robust multivariate functional principal component analysis is applied to the imputed data set for dimension reduction. |
mfdobj_tuning |
An additional functional data object of class mfd. After applying the filter and imputation steps on this data set, it is used to robustly estimate the distribution of the Hotelling's T2 and SPE statistics in order to calculate control limits to prevent overfitting issues that could reduce the monitoring performance of the RoMFCC. Default is NULL, but it is strongly recommended to use a tuning data set. |
functional_filter_par |
A list with an argument |
imputation_par |
A list with an argument |
pca_par |
A list with an argument |
alpha |
The overall nominal type-I error probability used to set control chart limits. Default value is 0.05. |
A list of the following elements that are needed in Phase II:
T2
the Hotelling's T2 statistic values for the Phase I data set,
SPE
the SPE statistic values for the Phase I data set,
T2_tun
the Hotelling's T2 statistic values for the tuning data set,
SPE_tun
the SPE statistic values for the tuning data set,
T2_lim
the Phase II control limit of
the Hotelling's T2 control chart,
spe_lim
the Phase II control limit of
the SPE control chart,
tuning
TRUE if the tuning data set is provided, FALSE otherwise,
mod_pca
the final RoMFPCA model fitted on the Phase I data set,
K
= K the number of selected principal components,
T_T2_inv
if a tuning data set is provided,
it returns the inverse of the covariance matrix
of the first K
scores, needed to calculate the Hotelling's T2
statistic for the Phase II observations.
mean_scores_tuning_rob_mean
if a tuning data set is provided,
it returns the robust location estimate of the scores, needed to calculate
the Hotelling's T2 and SPE
statistics for the Phase II observations.
C. Capezza, F. Centofanti
Capezza, C., Centofanti, F., Lepore, A., Palumbo, B. (2024) Robust Multivariate Functional Control Charts. Technometrics, 66(4):531–547, doi:10.1080/00401706.2024.2327346.
## Not run: library(funcharts) mfdobj <- get_mfd_list(air, n_basis = 5) nobs <- dim(mfdobj$coefs)[2] set.seed(0) ids <- sample(1:nobs) mfdobj1 <- mfdobj[ids[1:100]] mfdobj_tuning <- mfdobj[ids[101:300]] mfdobj2 <- mfdobj[ids[-(1:300)]] mod_phase1 <- RoMFCC_PhaseI(mfdobj = mfdobj1, mfdobj_tuning = mfdobj_tuning) phase2 <- RoMFCC_PhaseII(mfdobj_new = mfdobj2, mod_phase1 = mod_phase1) plot_control_charts(phase2) ## End(Not run)
## Not run: library(funcharts) mfdobj <- get_mfd_list(air, n_basis = 5) nobs <- dim(mfdobj$coefs)[2] set.seed(0) ids <- sample(1:nobs) mfdobj1 <- mfdobj[ids[1:100]] mfdobj_tuning <- mfdobj[ids[101:300]] mfdobj2 <- mfdobj[ids[-(1:300)]] mod_phase1 <- RoMFCC_PhaseI(mfdobj = mfdobj1, mfdobj_tuning = mfdobj_tuning) phase2 <- RoMFCC_PhaseII(mfdobj_new = mfdobj2, mod_phase1 = mod_phase1) plot_control_charts(phase2) ## End(Not run)
It calculates the Hotelling's and SPE monitoring statistics needed to plot the Robust Multivariate Functional Control Chart in Phase II.
RoMFCC_PhaseII(mfdobj_new, mod_phase1)
RoMFCC_PhaseII(mfdobj_new, mod_phase1)
mfdobj_new |
A multivariate functional data object of class mfd, containing the Phase II observations to be monitored. |
mod_phase1 |
Output obtained by applying the function |
A data.frame
with as many rows as the number of
multivariate functional observations in the phase II data set and
the following columns:
one id
column identifying the multivariate functional observation
in the phase II data set,
one T2
column containing the Hotelling T2 statistic
calculated for all observations,
one column per each functional variable, containing its contribution to the T2 statistic,
one spe
column containing the SPE statistic calculated
for all observations,
T2_lim
gives the upper control limit of
the Hotelling's T2 control chart,
spe_lim
gives the upper control limit of the SPE control chart
C. Capezza, F. Centofanti
Capezza, C., Centofanti, F., Lepore, A., Palumbo, B. (2024) Robust Multivariate Functional Control Charts. Technometrics, 66(4):531–547, doi:10.1080/00401706.2024.2327346.
## Not run: library(funcharts) mfdobj <- get_mfd_list(air, n_basis = 5) nobs <- dim(mfdobj$coefs)[2] set.seed(0) ids <- sample(1:nobs) mfdobj1 <- mfdobj[ids[1:100]] mfdobj_tuning <- mfdobj[ids[101:300]] mfdobj2 <- mfdobj[ids[-(1:300)]] mod_phase1 <- RoMFCC_PhaseI(mfdobj = mfdobj1, mfdobj_tuning = mfdobj_tuning) phase2 <- RoMFCC_PhaseII(mfdobj_new = mfdobj2, mod_phase1 = mod_phase1) plot_control_charts(phase2) ## End(Not run)
## Not run: library(funcharts) mfdobj <- get_mfd_list(air, n_basis = 5) nobs <- dim(mfdobj$coefs)[2] set.seed(0) ids <- sample(1:nobs) mfdobj1 <- mfdobj[ids[1:100]] mfdobj_tuning <- mfdobj[ids[101:300]] mfdobj2 <- mfdobj[ids[-(1:300)]] mod_phase1 <- RoMFCC_PhaseI(mfdobj = mfdobj1, mfdobj_tuning = mfdobj_tuning) phase2 <- RoMFCC_PhaseII(mfdobj_new = mfdobj2, mod_phase1 = mod_phase1) plot_control_charts(phase2) ## End(Not run)
It performs Robust Multivariate Functional Data Imputation (RoMFDI) as in Capezza et al. (2024).
RoMFDI( mfdobj, method_pca = "ROBPCA", fev = 0.999, n_dataset = 3, update = TRUE, niter_update = 10, alpha = 0.8 )
RoMFDI( mfdobj, method_pca = "ROBPCA", fev = 0.999, n_dataset = 3, update = TRUE, niter_update = 10, alpha = 0.8 )
mfdobj |
A multivariate functional data object of class mfd. |
method_pca |
The method used in |
fev |
Number between 0 and 1 denoting the proportion of variability that must be explained by the principal components to be selected for dimension reduction after applying RoMFPCA on the observed components to impute the missing ones. Default is 0.999. |
n_dataset |
To take into account the increased noise due to single imputation, the proposed RoMFDI allows multiple imputation. Due to the presence of the stochastic component in the imputation, it is worth explicitly noting that the imputed data set is not deterministically assigned. Therefore, by performing several times the RoMFDI in the imputation step of the RoMFCC implementation, the corresponding multiple estimated RoMFPCA models could be combined by averaging the robustly estimated covariance functions, thus performing a multiple imputation strategy as suggested by Van Ginkel et al. (2007). Default is 3. |
update |
The RoMFDI performs sequential imputation of missing functional
components.
If TRUE, Robust Multivariate Functional
Principal Component Analysis (RoMFPCA) |
niter_update |
The number of times the RoMFPCA is updated during the algorithm. It applies only if update is TRUE. Default value is 10. |
alpha |
This parameter measures the fraction of outliers the
RoMFPCA algorithm should resist and is used only
if |
A list with n_dataset
elements.
Each element is an mfd
object containing mfdobj
with
stochastic imputation of the missing components.
C. Capezza, F. Centofanti
Capezza, C., Centofanti, F., Lepore, A., Palumbo, B. (2024) Robust Multivariate Functional Control Charts. Technometrics, 66(4):531–547, doi:10.1080/00401706.2024.2327346.
Van Ginkel, J. R., Van der Ark, L. A., Sijtsma, K., and Vermunt, J. K. (2007). Two-way imputation: a Bayesian method for estimating missing scores in tests and questionnaires, and an accurate approximation. Computational Statistics & Data Analysis, 51(8):4013–-4027.
## Not run: library(funcharts) mfdobj <- get_mfd_list(air, grid = 1:24, n_basis = 13, lambda = 1e-2) out <- functional_filter(mfdobj) mfdobj_imp <- RoMFDI(out$mfdobj) ## End(Not run)
## Not run: library(funcharts) mfdobj <- get_mfd_list(air, grid = 1:24, n_basis = 13, lambda = 1e-2) out <- functional_filter(mfdobj) mfdobj_imp <- RoMFDI(out$mfdobj) ## End(Not run)
It performs robust MFPCA as described in Capezza et al. (2024).
rpca_mfd( mfdobj, center = "fusem", scale = "funmad", nharm = 20, method = "ROBPCA", alpha = 0.8 )
rpca_mfd( mfdobj, center = "fusem", scale = "funmad", nharm = 20, method = "ROBPCA", alpha = 0.8 )
mfdobj |
A multivariate functional data object of class mfd. |
center |
If TRUE, it centers the data before doing MFPCA with respect
to the functional mean of the input data.
If |
scale |
If |
nharm |
Number of multivariate functional principal components to be calculated. Default is 20. |
method |
If |
alpha |
This parameter measures the fraction of outliers the algorithm
should resist and is used only if |
An object of pca_mfd
class, as returned by the pca_mfd
function when performing non robust multivariate
functional principal component analysis.
C. Capezza, F. Centofanti
Capezza, C., Centofanti, F., Lepore, A., Palumbo, B. (2024) Robust Multivariate Functional Control Charts. Technometrics, 66(4):531–547, doi:10.1080/00401706.2024.2327346.
Centofanti, F., Colosimo, B.M., Grasso, M.L., Menafoglio, A., Palumbo, B., Vantini, S. (2023) Robust functional ANOVA with application to additive manufacturing. Journal of the Royal Statistical Society Series C: Applied Statistics 72(5), 1210–1234 doi:10.1093/jrsssc/qlad074
Croux, C., Ruiz-Gazen, A. (2005). High breakdown estimators for principal components: The projection-pursuit approach revisited. Journal of Multivariate Analysis, 95, 206–226, doi:10.1016/j.jmva.2004.08.002.
Hubert, M., Rousseeuw, P.J., Branden, K.V. (2005) ROBPCA: A New Approach to Robust Principal Component Analysis, Technometrics 47(1), 64–79, doi:10.1198/004017004000000563
Locantore, N., Marron, J., Simpson, D., Tripoli, N., Zhang, J., Cohen K., K. (1999), Robust principal components for functional data. Test, 8, 1-28. doi:10.1007/BF02595862
library(funcharts) dat <- simulate_mfd(nobs = 20, p = 1, correlation_type_x = "Bessel") mfdobj <- get_mfd_list(dat$X_list, n_basis = 5) # contaminate first observation mfdobj$coefs[, 1, ] <- mfdobj$coefs[, 1, ] + 0.05 # plot_mfd(mfdobj) # plot functions to see the outlier # pca <- pca_mfd(mfdobj) # non robust MFPCA rpca <- rpca_mfd(mfdobj) # robust MFPCA # plot_pca_mfd(pca, harm = 1) # plot first eigenfunction, affected by outlier # plot_pca_mfd(rpca, harm = 1) # plot first eigenfunction in robust case
library(funcharts) dat <- simulate_mfd(nobs = 20, p = 1, correlation_type_x = "Bessel") mfdobj <- get_mfd_list(dat$X_list, n_basis = 5) # contaminate first observation mfdobj$coefs[, 1, ] <- mfdobj$coefs[, 1, ] + 0.05 # plot_mfd(mfdobj) # plot functions to see the outlier # pca <- pca_mfd(mfdobj) # non robust MFPCA rpca <- rpca_mfd(mfdobj) # robust MFPCA # plot_pca_mfd(pca, harm = 1) # plot first eigenfunction, affected by outlier # plot_pca_mfd(rpca, harm = 1) # plot first eigenfunction in robust case
Scale multivariate functional data contained
in an object of class mfd
by subtracting the mean function and dividing
by the standard deviation function.
scale_mfd(mfdobj, center = TRUE, scale = TRUE)
scale_mfd(mfdobj, center = TRUE, scale = TRUE)
mfdobj |
A multivariate functional data object of class |
center |
A logical value, or a |
scale |
A logical value, or a |
This function has been written to work similarly
as the function scale
for matrices.
When calculated, attributes center
and scale
are of class fd
and have the same structure you get
when you use fda::mean.fd
and fda::sd.fd
.
A standardized object of class mfd
, with two attributes,
if calculated,
center
and scale
, storing the mean and
standard deviation functions used for standardization.
library(funcharts) mfdobj <- data_sim_mfd() mfdobj_scaled <- scale_mfd(mfdobj)
library(funcharts) mfdobj <- data_sim_mfd() mfdobj_scaled <- scale_mfd(mfdobj)
Function used to simulate three data sets to illustrate the use
of funcharts
.
It uses the function simulate_mfd
,
which creates a data set with three functional covariates,
a functional response generated as a function of the
three functional covariates,
and a scalar response generated as a function of the
three functional covariates.
This function generates three data sets, one for phase I,
one for tuning, i.e.,
to estimate the control chart limits, and one for phase II monitoring.
see also simulate_mfd
.
sim_funcharts(nobs1 = 1000, nobs_tun = 1000, nobs2 = 60)
sim_funcharts(nobs1 = 1000, nobs_tun = 1000, nobs2 = 60)
nobs1 |
The number of observation to simulate in phase I. Default is 1000. |
nobs_tun |
The number of observation to simulate the tuning data set. Default is 1000. |
nobs2 |
The number of observation to simulate in phase II. Default is 60. |
A list with three objects, datI
contains the phase I data,
datI_tun
contains the tuning data,
datII
contains the phase II data.
In the phase II data, the first group of observations are in control,
the second group of observations contains a moderate mean shift,
while the third group of observations contains a severe mean shift.
The shift types are described in the paper from Capezza et al. (2023).
Centofanti F, Lepore A, Menafoglio A, Palumbo B, Vantini S. (2021) Functional Regression Control Chart. Technometrics, 63(3), 281–294. doi:10.1080/00401706.2020.1753581
Capezza, C., Centofanti, F., Lepore, A., Menafoglio, A., Palumbo, B., & Vantini, S. (2023). funcharts: Control charts for multivariate functional data in R. Journal of Quality Technology, 55(5), 566–583. doi:10.1080/00224065.2023.2219012
Generate synthetic data as in the simulation study of Centofanti et al. (2024).
simulate_data_FRTM( n_obs = 100, scenario = "1", shift = "IC", alignemnt_level = "M1", t_out_type = "0.3", severity = 0.5, grid = seq(0, 1, length.out = 100) )
simulate_data_FRTM( n_obs = 100, scenario = "1", shift = "IC", alignemnt_level = "M1", t_out_type = "0.3", severity = 0.5, grid = seq(0, 1, length.out = 100) )
n_obs |
Number of curves generated. |
scenario |
A character string indicating the scenario considered. It could be "1", and "2". |
shift |
A character string indicating the shift considered. It could be "IC", in-control data, "OC_h", Shift A (Phase),"OC_x", Shift B (Amplitude) and "OC_xh", Shift C (Amplitude and Phase). |
alignemnt_level |
A character string indicating the alignment level considered. It could be "M1", "M2", and "M3". |
t_out_type |
If "0.3", change point at the 30% of the process. If "0.6", change point at the 60% of the process. |
severity |
Severity level. |
grid |
Grid of evaluation points. |
A list containing the following arguments:
x_err
: A list containing the discrete observations for each curve.
grid_i
: A list of vector of time points where the curves are sampled.
h
: A list containing the discrete observations of the warping function for each curve.
template
: The discrete observations of the true template function.
grid_template
: Time points where the template is sampled.
x_true
: A list containing the discrete observations of the amplitude function for each curve.
grid
: Grid of evaluation points.
out_control_t
: Time of the change point.
Centofanti, F., A. Lepore, M. Kulahci, and M. P. Spooner (2024). Real-time monitoring of functional data. Accepted for publication in Journal of Quality Technology.
library(funcharts) data<-simulate_data_FRTM(n_obs=20)
library(funcharts) data<-simulate_data_FRTM(n_obs=20)
Function used to simulate a data set to illustrate
the use of funcharts
.
By default, it creates a data set with three functional covariates,
a functional response generated as a function of the
three functional covariates
through a function-on-function linear model,
and a scalar response generated as a function of the
three functional covariates
through a scalar-on-function linear model.
This function covers the simulation study in Centofanti et al. (2021)
for the function-on-function case and also simulates data in a similar way
for the scalar response case.
It is possible to select the number of functional covariates,
the correlation function type for each functional covariate
and the functional response, moreover
it is possible to provide manually the mean and variance functions
for both functional covariates and the response.
In the default case, the function generates in-control data.
Additional arguments can be used to generate additional
data that are out of control,
with mean shifts according to the scenarios proposed
by Centofanti et al. (2021).
Each simulated observation of a functional variable consists of
a vector of discrete points equally spaced between 0 and 1 (by default
150 points),
generated with noise.
simulate_mfd( nobs = 1000, p = 3, R2 = 0.97, shift_type_y = "0", shift_type_x = c("0", "0", "0"), correlation_type_y = "Bessel", correlation_type_x = c("Bessel", "Gaussian", "Exponential"), d_y = 0, d_y_scalar = 0, d_x = c(0, 0, 0), n_comp_y = 10, n_comp_x = 50, P = 500, ngrid = 150, save_beta = FALSE, mean_y = NULL, mean_x = NULL, variance_y = NULL, variance_x = NULL, sd_y = 0.3, sd_x = c(0.3, 0.05, 0.3), seed )
simulate_mfd( nobs = 1000, p = 3, R2 = 0.97, shift_type_y = "0", shift_type_x = c("0", "0", "0"), correlation_type_y = "Bessel", correlation_type_x = c("Bessel", "Gaussian", "Exponential"), d_y = 0, d_y_scalar = 0, d_x = c(0, 0, 0), n_comp_y = 10, n_comp_x = 50, P = 500, ngrid = 150, save_beta = FALSE, mean_y = NULL, mean_x = NULL, variance_y = NULL, variance_x = NULL, sd_y = 0.3, sd_x = c(0.3, 0.05, 0.3), seed )
nobs |
The number of observation to simulate |
p |
The number of functional covariates to simulate. Default value is 3. |
R2 |
The desired coefficient of determination in the regression in both the scalar and functional response cases, Default is 0.97. |
shift_type_y |
The shift type for the functional response. There are five possibilities: "0" if there is no shift, "A", "B", "C" or "D" for the corresponding shift types shown in Centofanti et al. (2021). Default is "0". |
shift_type_x |
A list of length |
correlation_type_y |
A character vector indicating the type of correlation function for
the functional response.
See Centofanti et al. (2021)
for more details. Three possible values are available,
namely |
correlation_type_x |
A list of |
d_y |
A number indicating the severity of the shift type for the functional response. Default is 0. |
d_y_scalar |
A number indicating the severity of the shift type for the scalar response. Default is 0. |
d_x |
A list of |
n_comp_y |
A positive integer number indicating how many principal components obtained after the eigendecomposiiton of the covariance function of the functional response variable to retain. Default value is 10. |
n_comp_x |
A positive integer number indicating how many principal components obtained after the eigendecomposiiton of the covariance function of the multivariate functional covariates variable to retain. Default value is 50. |
P |
A positive integer number indicating the number of equally spaced grid points over which the covariance functions are discretized. Default value is 500. |
ngrid |
A positive integer number indicating the number of equally spaced grid points between zero and one over which all functional observations are discretized before adding noise. Default value is 150. |
save_beta |
If TRUE, the true regression coefficients of both the function-on-function and the scalar-on-function models are saved. Default is FALSE. |
mean_y |
The mean function of the functional response can be set manually
through this argument. If not NULL, it must be a vector of length
equal to |
mean_x |
The mean function of the functional covariates can be set manually
through this argument. If not NULL, it must be a list of vectors,
each with length equal to |
variance_y |
The variance function of the functional response can be set manually
through this argument. If not NULL, it must be a vector of length
equal to |
variance_x |
The variance function of the functional covariates can be set manually
through this argument. If not NULL, it must be a list of vectors,
each with length equal to |
sd_y |
A positive number indicating the standard deviation of the generated noise with which the functional response discretized values are observed. Default value is 0.3 |
sd_x |
A vector of |
seed |
Deprecated: use |
A list with the following elements:
X_list
is a list of p
matrices, each with dimension
nobs
xngrid
, containing the simulated
observations of the multivariate functional covariate
Y
is a nobs
xngrid
matrix with the simulated
observations of the functional response
y_scalar
is a vector of length nobs
with the simulated
observations of the scalar response
beta_fof
, if save_beta = TRUE
, is a
list of p
matrices, each with dimension P
xP
with the discretized functional coefficients of the
function-on-function regression
beta_sof
, if save_beta = TRUE
, is a
list of p
vectors, each with length P
,
with the discretized functional coefficients of the
scalar-on-function regression
Centofanti F, Lepore A, Menafoglio A, Palumbo B, Vantini S. (2021) Functional Regression Control Chart. Technometrics, 63(3), 281–294. doi:10.1080/00401706.2020.1753581
Scalar-on-function linear regression based on principal components. This function performs multivariate functional principal component analysis (MFPCA) to extract multivariate functional principal components from the multivariate functional covariates, then it builds a linear regression model of a scalar response variable on the covariate scores. Functional covariates are standardized before the regression. See Capezza et al. (2020) for additional details.
sof_pc( y, mfdobj_x, tot_variance_explained = 0.9, selection = "variance", single_min_variance_explained = 0, components = NULL )
sof_pc( y, mfdobj_x, tot_variance_explained = 0.9, selection = "variance", single_min_variance_explained = 0, components = NULL )
y |
A numeric vector containing the observations of the scalar response variable. |
mfdobj_x |
A multivariate functional data object of class mfd denoting the functional covariates. |
tot_variance_explained |
The minimum fraction of variance that has to be explained by the set of multivariate functional principal components retained into the MFPCA model fitted on the functional covariates. Default is 0.9. |
selection |
A character value with one of three possible values: if "variance", the first M multivariate functional principal components
are retained into the MFPCA model such
that together they explain a fraction of variance greater
than if "PRESS", each j-th functional principal component is retained
into the MFPCA model if,
by adding it to the
set of the first j-1 functional principal components,
then the predicted residual error sum of squares (PRESS) statistic decreases,
and at the same time the fraction of variance explained
by that single component
is greater than if "gcv", the criterion is equal as in the previous "PRESS" case, but the "PRESS" statistic is substituted by the generalized cross-validation (GCV) score. Default value is "variance". |
single_min_variance_explained |
The minimum fraction of variance that has to be explained by each multivariate functional principal component into the MFPCA model fitted on the functional covariates such that it is retained into the MFPCA model. Default is 0. |
components |
A vector of integers with the components over which
to project the functional covariates.
If this is not NULL, the criteria to select components are ignored.
If NULL, components are selected according to
the criterion defined by |
a list containing the following arguments:
mod
: an object of class lm
that is a linear regression
model where
the scalar response variable is y
and
the covariates are the MFPCA scores of the functional covariates,
mod$coefficients
contains the matrix of coefficients of the
functional regression basis functions,
pca
: an object of class pca_mfd
obtained by doing MFPCA
on the functional covariates,
beta_fd
: an object of class mfd
object containing
the functional regression coefficient
estimated with the
scalar-on-function linear regression model,
components
: a vector of integers with the components
selected in the pca
model,
selection
: the same as the provided argument
single_min_variance_explained
: the same as the provided argument
tot_variance_explained
: the same as the provided argument
gcv
: a vector whose j-th element is the GCV score obtained
when retaining the first j components
in the MFPCA model.
PRESS
: a vector whose j-th element is the PRESS statistic
obtained when retaining the first j components
in the MFPCA model.
C. Capezza
Capezza C, Lepore A, Menafoglio A, Palumbo B, Vantini S. (2020) Control charts for monitoring ship operating conditions and CO2 emissions based on scalar-on-function regression. Applied Stochastic Models in Business and Industry, 36(3):477–500. doi:10.1002/asmb.2507
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], lambda = 1e-2) y <- rowMeans(air$NO2) mod <- sof_pc(y, mfdobj_x)
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], lambda = 1e-2) y <- rowMeans(air$NO2) mod <- sof_pc(y, mfdobj_x)
This function produces a list of objects,
each of them contains the result of applying sof_pc
to
a scalar response variable and multivariate functional covariates
evolved up to an intermediate domain point.
See Capezza et al. (2020) for additional details on real-time monitoring.
sof_pc_real_time( y, mfd_real_time_list, single_min_variance_explained = 0, tot_variance_explained = 0.9, selection = "PRESS", components = NULL, ncores = 1 )
sof_pc_real_time( y, mfd_real_time_list, single_min_variance_explained = 0, tot_variance_explained = 0.9, selection = "PRESS", components = NULL, ncores = 1 )
y |
A numeric vector containing the observations of the scalar response variable. |
mfd_real_time_list |
A list created using
|
single_min_variance_explained |
See |
tot_variance_explained |
See |
selection |
See |
components |
See |
ncores |
If you want parallelization, give the number of cores/threads to be used when creating objects separately for different instants. |
A list of lists each produced by sof_pc
,
corresponding to a given instant.
C. Capezza
Capezza C, Lepore A, Menafoglio A, Palumbo B, Vantini S. (2020) Control charts for monitoring ship operating conditions and CO2 emissions based on scalar-on-function regression. Applied Stochastic Models in Business and Industry, 36(3):477–500. doi:10.1002/asmb.2507
sof_pc
,
get_mfd_df_real_time
,
get_mfd_list_real_time
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) mfdobj_list <- get_mfd_list_real_time(air[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 0.75, 1)) y <- rowMeans(air$NO2) mod_list <- sof_pc_real_time(y, mfdobj_list)
library(funcharts) data("air") air <- lapply(air, function(x) x[1:10, , drop = FALSE]) mfdobj_list <- get_mfd_list_real_time(air[c("CO", "temperature")], n_basis = 15, lambda = 1e-2, k_seq = c(0.5, 0.75, 1)) y <- rowMeans(air$NO2) mod_list <- sof_pc_real_time(y, mfdobj_list)
This function returns the tensor product of two Multivariate Functional Data objects. Each object must contain only one replication.
tensor_product_mfd(mfdobj1, mfdobj2 = NULL)
tensor_product_mfd(mfdobj1, mfdobj2 = NULL)
mfdobj1 |
A multivariate functional data object, of class |
mfdobj2 |
A multivariate functional data object, of class |
An object of class bifd
.
If we denote with x(s)=(x_1(s),...,x_p(s))
the vector of p functions represented by mfdobj1
and
with y(t)=(y_1(t),...,y_q(t)) the vector of q functions
represented by mfdobj2
,
the output is the
vector of pq bivariate functions
f(s,t)=(x_1(s)y_1(t),...,x_1(s)y_q(t), ...,x_p(s)y_1(t),...,x_p(s)y_q(t)).
library(funcharts) mfdobj1 <- data_sim_mfd(nobs = 1, nvar = 3) mfdobj2 <- data_sim_mfd(nobs = 1, nvar = 2) tensor_product_mfd(mfdobj1) tensor_product_mfd(mfdobj1, mfdobj2)
library(funcharts) mfdobj1 <- data_sim_mfd(nobs = 1, nvar = 3) mfdobj2 <- data_sim_mfd(nobs = 1, nvar = 2) tensor_product_mfd(mfdobj1) tensor_product_mfd(mfdobj1, mfdobj2)
This function returns a list for each control chart and returns the id of all observations that are out of control in that control chart.
which_ooc(cclist)
which_ooc(cclist)
cclist |
A |
A list of as many data.frame
objects as
the control charts in cclist
.
Each data frame has two columns, the n
contains
an index number giving the observation in the
phase II data set, i.e. 1 for the first observation,
2 for the second, and so on,
while the id
column contains the id of the observation,
which can be general and
depends on the specific data set.
library(funcharts) data("air") air <- lapply(air, function(x) x[201:300, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:60] y_tuning <- y[61:90] y2 <- y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod <- sof_pc(y1, mfdobj_x1) cclist <- regr_cc_sof(object = mod, y_new = y2, mfdobj_x_new = mfdobj_x2, y_tuning = y_tuning, mfdobj_x_tuning = mfdobj_x_tuning, include_covariates = TRUE) which_ooc(cclist)
library(funcharts) data("air") air <- lapply(air, function(x) x[201:300, , drop = FALSE]) fun_covariates <- c("CO", "temperature") mfdobj_x <- get_mfd_list(air[fun_covariates], n_basis = 15, lambda = 1e-2) y <- rowMeans(air$NO2) y1 <- y[1:60] y_tuning <- y[61:90] y2 <- y[91:100] mfdobj_x1 <- mfdobj_x[1:60] mfdobj_x_tuning <- mfdobj_x[61:90] mfdobj_x2 <- mfdobj_x[91:100] mod <- sof_pc(y1, mfdobj_x1) cclist <- regr_cc_sof(object = mod, y_new = y2, mfdobj_x_new = mfdobj_x2, y_tuning = y_tuning, mfdobj_x_tuning = mfdobj_x_tuning, include_covariates = TRUE) which_ooc(cclist)