Description Usage Arguments Details Value Author(s) See Also Examples
RDA R function within 'deco' R package. This function allows user to subsampling a omic data matrix to find out significant differential features characterizing any hidden subclass or group of samples included.
1 2 3 4 |
data |
matrix of normalized omic data with 'f' features (rows) by 'n' samples (columns). |
classes |
factor or character vector of 's' size with two ('Supervised' or 'Binary' analysis) or more classes ('Multiclass' analysis) to contrast. Names of vector must match with colnames of 'data'. If any vector of classes is given, 'Unsupervised' analysis will be run with all samples. |
control |
character label defining 'control' or '0' class for LIMMA contrast design. |
r |
number of samples of each class to take for subsampling. Same number of samples will be taken from each class. |
q.val |
p.value threshold for each iteration of subsampling process. It corresponds to adj.P.value of LIMMA and is set as default as 0.01. |
iterations |
number of iterations to subsample 'data', set as default as 10000. If this value exceeds number of all possible combinations, it would be replaced. |
bpparam |
registered parallelization using BiocParallel R functions: SerialParam(), MulticoreParam(), SnowParam(), etc. Further information available in vignette. |
annot |
logical value indicating if annotation of IDs provided by 'data' as rownames should be done. |
id.type |
character indicating what ID is provided by user in 'data'. This value must match any of distinct possibles values of R package used to annotate. |
attributes |
character vector with distinct fields to return by annotation package. |
rm.xy |
logical indicating if features located on chromosomes 'X' or 'Y' have to be removed. Features depending on these location could be an artefact of unbalanced contrasts by gender of patients or samples, so removing it should clear final results due to an appropiated subsampling of samples. |
pack.db |
character naming annotation package to be used. Homo.sapiens annotation package set as default, try first 'AnnotateDECO' R function with any other annotation package from Bioconductor to find out any problem. |
The RDA step is primarly conditioned by contrast design. Our capacity to highlight majority or minority features will vary depending on how much we want focusing the analyisis on classes or individual samples, or what is the same, the granularity of RDA.
In this way, it is necessary to highlight that two RDA strategies could be: (a) a majority one trying to improve our generic differential expression with higher subsampling size; and (b) a minority strategy to find out all possible hidden subclasses. By default, decoRDA()
defines an optimal subsample size r. Let n be the number of samples included in the analysis or
n_1,n_2,...,n_k
in case of two or more k classes, then based on previous analysis done by Babu et al.:
r = √{n}
or in case of 'Supervised' or 'Multiclass' design:
r = √{min(n_1,n_2,...,n_k)}
The analysis can be set to find differences among two populations or classes and to find differences within the whole cohort of samples. Besides, decoRDA()
can work under both scenarios: binary analysis with two classes or unsupervised analysis contrasting all samples. The classes input is used to define it. If the user introduces any vector with labels of two classes for each sample, a binary analysis will be run. Otherwise, without any classes vector all samples will be compared with each other.
Returns a list containing:
data |
input matrix of normalized data with 'f' features (rows) by 's' samples (columns). |
subStatFeature |
table of differential features with statistical and annotation information, if it was required. |
incidenceMatrix |
absolute frequency matrix of 'd' features by 's' samples size that summarizes differential events for each feature per sample. It will be essential for Non-Symmetrical Correspondence Analysis. |
classes |
factor or character vector of 's' size provided by user. |
resampleSize |
number of samples of each class to take for subsampling provided by user in 'r'. |
control |
character label defining 'control' or '0' class for LIMMA contrast design. |
pos.iter |
number of subsampling iterations showing at least 1 differential event. |
q.val |
adj.p.value threshold used in each LIMMA iteration within subsampling. |
Francisco Jose Campos Laborie. <fjcamlab@usal.es>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 | #### ALCL EXAMPLE (Scarfo et al., 2015. Blood) ####
########################
# Loading example data #
########################
## Data from two subtypes (ALK+ and ALK-) of Anaplastic Large Cell Leukemia (ALCL).
data(ALCLdata)
## Classes vector to run a binary analysis to compare both classes.
classes.ALCL <- colData(ALCL)[,"Alk.positivity"]
names(classes.ALCL) <- colnames(ALCL)
#######################################################################
# RUNNING SUBSAMPLING OF DATA: BINARY design (two classes of samples) #
#######################################################################
# library(Homo.sapiens) # for gene annotation
## Not run as example
# sub.ma.3r.1K <- decoRDA(data = assay(ALCL), classes = classes.ALCL, q.val = 0.01,
# rm.xy = TRUE, r = NULL, control = "pos", annot = TRUE,
# id.type = "ENSEMBL", iterations = 1000,
# pack.db = "Homo.sapiens")
## Slots included in returned R object.
# names(sub.ma.3r.1K)
# [1] "data" "results" "subStatFeature" "incidenceMatrix" "classes"
# [6] "resampleSize" "control" "pos.iter" "q.val" "call"
## Top-10 RDA features.
# head(sub.ma.3r.1K$subStatFeature, 10)
#################################################################
# RUNNING SUBSAMPLING OF DATA: UNSUPERVISED design (no classes) #
#################################################################
## Not run as example
# sub.ma.3r.1K.uns <- decoRDA(data = assay(ALCL), q.val = 0.01,
# rm.xy = TRUE, r = 3, annot = TRUE,
# id.type = "ENSEMBL", iterations = 1000,
# pack.db = "Homo.sapiens")
#################################################################
# RUNNING SUBSAMPLING OF DATA: MULTICLASS design (no classes) #
#################################################################
# 3 classes: ALK+, PTCL and ALK- without PTCLs
multiclasses.ALCL <- factor(apply(
as.data.frame(colData(ALCL)[, c("Alk.positivity", "Type")]), 1,
function(x) paste(x, collapse = ".")
))
head(multiclasses.ALCL)
## Not run as example
# sub.ma.3r.1K.multi <- decoRDA(data = assay(ALCL), classes = multiclasses.ALCL,
# q.val = 0.01, rm.xy = TRUE, r = 3, annot = TRUE,
# id.type = "ENSEMBL", iterations = 1000,
# pack.db = "Homo.sapiens")
|
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.