Function to combine multiple independent studies measured on the same variables or predictors (P-integration) using variants of multi-group PLS-DA for supervised classification.
mint.plsda(X,
Y,
ncomp = 2,
mode = c("regression", "canonical", "invariant", "classic"),
study,
scale = TRUE,
tol = 1e-06,
max.iter = 100,
near.zero.var = FALSE,
all.outputs = TRUE)
numeric matrix of predictors combining multiple independent studies on the same set of predictors. NA
s are allowed.
A factor or a class vector indicating the discrete outcome of each sample.
Number of components to include in the model (see Details). Default to 2
character string. What type of algorithm to use, (partially) matching
one of "regression"
or "canonical"
. See Details.
factor indicating the membership of each sample to each of the studies being combined
boleean. If scale = TRUE, each block is standardized
to zero means and unit variances. Default = TRUE
.
Convergence stopping value.
integer, the maximum number of iterations.
boolean, see the internal nearZeroVar
function (should be set to TRUE in particular for data with many zero values). Default = FALSE
.
boolean. Computation can be faster when some specific (and non-essential) outputs are not calculated. Default = TRUE
.
mint.plsda
returns an object of class "mint.plsda", "plsda"
, a list
that contains the following components:
the centered and standardized original predictor matrix.
original factor
the centered and standardized original response vector or matrix.
the number of components included in the model.
The study grouping factor
the algorithm used to fit the model.
list containing the variates of X - global variates.
list containing the estimated loadings for the variates - global loadings.
list containing the variates of X relative to each study - partial variates.
list containing the estimated loadings for the partial variates - partial loadings.
list containing the names to be used for individuals and variables.
list containing the zero- or near-zero predictors information.
Number of iterations of the algorthm for each component
Percentage of explained variance for each component and each study (note that contrary to PCA, this amount may not decrease as the aim of the method is not to maximise the variance, but the covariance between X and the dummy matrix Y).
mint.plsda
function fits a vertical PLS-DA models with ncomp
components in which several independent studies measured on the same variables are integrated. The aim is to classify the discrete outcome Y
. The study
factor indicates the membership of each sample in each study. We advise to only combine studies with more than 3 samples as the function performs internal scaling per study, and where all outcome categories are represented.
X
can contain missing values. Missing values are handled by being disregarded during the cross product computations in the algorithm mint.plsda
without having to delete rows with missing data. Alternatively, missing data can be imputed prior using the nipals
function.
The type of algorithm to use is specified with the mode
argument. Four PLS
algorithms are available: PLS regression ("regression")
, PLS canonical analysis
("canonical")
, redundancy analysis ("invariant")
and the classical PLS
algorithm ("classic")
(see References and more details in ?pls
).
Useful graphical outputs are available, e.g. plotIndiv
, plotLoadings
, plotVar
.
Rohart F, Eslami A, Matigian, N, Bougeard S, Le Cao K-A (2017). MINT: A multivariate integrative approach to identify a reproducible biomarker signature across multiple experiments and platforms. BMC Bioinformatics 18:128.
Eslami, A., Qannari, E. M., Kohler, A., and Bougeard, S. (2014). Algorithms for multi-group PLS. J. Chemometrics, 28(3), 192-201.
mixOmics manuscript:
Rohart F, Gautier B, Singh A, Le Cao K-A. mixOmics: an R package for 'omics feature selection and multiple data integration. BioRxiv available here: http://biorxiv.org/content/early/2017/02/14/108597
spls
, summary
,
plotIndiv
, plotVar
, predict
, perf
, mint.pls
, mint.spls
, mint.splsda
and http://www.mixOmics.org/mixMINT for more details.
# NOT RUN {
data(stemcells)
res = mint.plsda(X = stemcells$gene, Y = stemcells$celltype, ncomp = 3,
study = stemcells$study)
plotIndiv(res)
#plot study-specific outputs for all studies
plotIndiv(res, study = "all.partial")
#plot study-specific outputs for study "2"
plotIndiv(res, study = "2", col = 1:3, legend = TRUE)
# }
Run the code above in your browser using DataLab