Title: | Visualizations of expressionSet Bioconductor object |
---|---|
Description: | Utility functions for visualization of expressionSet (or SummarizedExperiment) Bioconductor object, including spectral map, tsne and linear discriminant analysis. Static plot via the ggplot2 package or interactive via the ggvis or rbokeh packages are available. |
Authors: | Laure Cougnaud <[email protected]> |
Maintainer: | Laure Cougnaud <[email protected]> |
License: | GPL-3 |
Version: | 1.33.0 |
Built: | 2025-01-22 06:15:35 UTC |
Source: | https://github.com/bioc/esetVis |
esetLda
reduces the dimension of the data contained in the eSet via a linear discriminant analysis
on the specified grouping variable with the lda
function and plot the subsequent biplot,
possibly with sample annotation and gene annotation contained in the eSet.
esetLda( eset, ldaVar, psids = 1:nrow(eset), dim = c(1, 2), colorVar = character(), color = if (length(colorVar) == 0) "black" else character(), shapeVar = character(), shape = if (length(shapeVar) == 0) 15 else numeric(), sizeVar = character(), size = if (length(sizeVar) == 0) { ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 20, 2.5) } else { numeric() }, sizeRange = numeric(), alphaVar = character(), alpha = if (length(alphaVar) == 0) 1 else numeric(), alphaRange = numeric(), title = "", symmetryAxes = c("combine", "separate", "none"), packageTextLabel = c("ggrepel", "ggplot2"), cloudGenes = TRUE, cloudGenesColor = "black", cloudGenesNBins = sqrt(length(psids)), cloudGenesIncludeLegend = FALSE, cloudGenesTitleLegend = "nGenes", topGenes = 10, topGenesCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topGenesVar = character(), topGenesJust = c(0.5, 0.5), topGenesColor = "black", topSamples = 10, topSamplesCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topSamplesVar = character(), topSamplesJust = c(0.5, 0.5), topSamplesColor = "black", geneSets = list(), geneSetsVar = character(), geneSetsMaxNChar = numeric(), topGeneSets = 10, topGeneSetsCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topGeneSetsJust = c(0.5, 0.5), topGeneSetsColor = "black", includeLegend = TRUE, includeLineOrigin = TRUE, typePlot = c("static", "interactive"), packageInteractivity = c("plotly", "ggvis"), figInteractiveSize = c(600, 400), ggvisAdjustLegend = TRUE, interactiveTooltip = TRUE, interactiveTooltipExtraVars = character(), returnAnalysis = FALSE, returnEsetPlot = FALSE )
esetLda( eset, ldaVar, psids = 1:nrow(eset), dim = c(1, 2), colorVar = character(), color = if (length(colorVar) == 0) "black" else character(), shapeVar = character(), shape = if (length(shapeVar) == 0) 15 else numeric(), sizeVar = character(), size = if (length(sizeVar) == 0) { ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 20, 2.5) } else { numeric() }, sizeRange = numeric(), alphaVar = character(), alpha = if (length(alphaVar) == 0) 1 else numeric(), alphaRange = numeric(), title = "", symmetryAxes = c("combine", "separate", "none"), packageTextLabel = c("ggrepel", "ggplot2"), cloudGenes = TRUE, cloudGenesColor = "black", cloudGenesNBins = sqrt(length(psids)), cloudGenesIncludeLegend = FALSE, cloudGenesTitleLegend = "nGenes", topGenes = 10, topGenesCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topGenesVar = character(), topGenesJust = c(0.5, 0.5), topGenesColor = "black", topSamples = 10, topSamplesCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topSamplesVar = character(), topSamplesJust = c(0.5, 0.5), topSamplesColor = "black", geneSets = list(), geneSetsVar = character(), geneSetsMaxNChar = numeric(), topGeneSets = 10, topGeneSetsCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topGeneSetsJust = c(0.5, 0.5), topGeneSetsColor = "black", includeLegend = TRUE, includeLineOrigin = TRUE, typePlot = c("static", "interactive"), packageInteractivity = c("plotly", "ggvis"), figInteractiveSize = c(600, 400), ggvisAdjustLegend = TRUE, interactiveTooltip = TRUE, interactiveTooltipExtraVars = character(), returnAnalysis = FALSE, returnEsetPlot = FALSE )
eset |
expressionSet (or SummarizedExperiment) object with data |
ldaVar |
name of variable (in varLabels of the |
psids |
featureNames of genes to include in the plot, all by default |
dim |
dimensions of the analysis to represent, first two dimensions by default |
colorVar |
name of variable (in varLabels of the |
color |
character or factor with specified color(s) for the points,
replicated if needed. This is used only if |
shapeVar |
name of variable (in varLabels of the |
shape |
character or factor with specified shape(s) (pch) for the points,
replicated if needed. This is used only if |
sizeVar |
name of variable (in varLabels of the |
size |
character or factor with specified size(s) (cex) for the points,
replicated if needed.
This is used only if |
sizeRange |
size (cex) range used in the plot, possible only
if the |
alphaVar |
name of variable (in varLabels of the |
alpha |
character or factor with specified transparency(s) for the points,
replicated if needed. This is used only if |
alphaRange |
transparency (alpha) range used in the plot,
possible only if the |
title |
plot title, ” by default |
symmetryAxes |
set symmetry for axes, either:
|
packageTextLabel |
package used to label the outlying genes/samples/gene sets,
either |
cloudGenes |
logical, if TRUE (by default), include the cloud of genes in the plot |
cloudGenesColor |
if |
cloudGenesNBins |
number of bins to used for the clouds of genes, by default the square root of the number of genes |
cloudGenesIncludeLegend |
logical, if TRUE (FALSE by default) include the legend for the cloud of genes (in the top position if multiple legends) |
cloudGenesTitleLegend |
string with title for the legend for the cloud of genes 'nGenes' by default |
topGenes |
numeric indicating which percentile (if <1) or number (if >=1) of genes most distant to the origin of the plot to annotate, by default: 10 genes are selected If no genes should be annotated, set this parameter to 0 Currently only available for static plot. |
topGenesCex |
cex for gene annotation (used when |
topGenesVar |
variable of the featureData used to label the genes,
by default: empty, the featureNames are used for labelling (used when |
topGenesJust |
text justification for the genes
(used when |
topGenesColor |
text color for the genes
(used when |
topSamples |
numeric indicating which percentile (if <1) or number (if >=1) of samples most distant to the origin of the plot to annotate, by default: 10 samples are selected If no samples should be annotated, set this parameter to 0. Currently available for static plot. |
topSamplesCex |
cex for sample annotation (used when |
topSamplesVar |
variable of the phenoData used to label the samples,
by default: empty, the sampleNames are used for labelling
(used when |
topSamplesJust |
text justification for the samples
(used when |
topSamplesColor |
text color for the samples
(used when |
geneSets |
list of gene sets/pathways, each containing
identifiers of genes contained in the set.
E.g. pathways from Gene Ontology databases output from the
|
geneSetsVar |
variable of the featureData used to
match the genes contained in geneSets,
most probably ENTREZID, if not specified the featureNames
of the eSet are used
Only used when |
geneSetsMaxNChar |
maximum number of characters for pathway names,
by default keep entire names
Only used when |
topGeneSets |
numeric indicating which percentile (if <=1) or number (if >1) of gene sets
most distant to the origin of the plot to annotate, by default: 10 gene sets are selected
If no gene sets should be annotated, set this parameter to 0.
Currently available for static plot.
Only used when |
topGeneSetsCex |
cex for gene sets annotation
Only used when |
topGeneSetsJust |
text justification for the gene sets
by default: c(0.5, 0.5) so centered
Only used when |
topGeneSetsColor |
color for the gene sets
(used when |
includeLegend |
logical if TRUE (by default) include a legend, otherwise not |
includeLineOrigin |
if TRUE (by default) include vertical line at x = 0 and horizontal line at y = 0 |
typePlot |
type of the plot returned, either 'static' (static) or interactive' (potentially interactive) |
packageInteractivity |
if |
figInteractiveSize |
vector containing the size of the interactive plot,
as [width, height]
by default: c(600, 400). This is passed to the
|
ggvisAdjustLegend |
logical, if TRUE (by default) adjust the legends in |
interactiveTooltip |
logical, if TRUE, add hoover functionality showing sample annotation (variables used in the plot) in the plot |
interactiveTooltipExtraVars |
name of extra variable(s)
(in varLabels of the |
returnAnalysis |
logical, if TRUE (FALSE by default), return also the output of the analysis, and the outlying samples in the topElements element if any, otherwise only the plot object |
returnEsetPlot |
logical, if TRUE return also the esetPlot object |
if returnAnalysis
is TRUE, return a list:
analysis: output of the spectral map analysis, whose parameters
can be given as input to the esetPlotWrapper
function
dataPlotSamples: coordinates of the samples
dataPlotGenes: coordinates of the genes
esetUsed: expressionSet used in the plot
topElements: list with top outlying elements if any, possibly genes, samples and gene sets
plot: the plot output
otherwise return only the plot
Laure Cougnaud
Fisher, R. A. (1936). The Use of Multiple Measurements in Taxonomic Problems. Annals of Eugenics, 7 (2), 179–188
the function used internally: lda
# load data library(ALL) data(ALL) # specify several variables in ldaVar (this might take a few minutes to run...) # sample subsetting: currently cannot deal with missing values samplesToRemove <- which(apply(pData(ALL)[, c("sex", "BT")], 1, anyNA)) # extract random features, because analysis is quite time consuming retainedFeatures <- sample(featureNames(ALL), size = floor(nrow(ALL)/5)) # create the plot esetLda(eset = ALL[retainedFeatures, -samplesToRemove], ldaVar = "BT", colorVar = "BT", shapeVar = "sex", sizeVar = "age", title = "Linear discriminant analysis on the ALL dataset")
# load data library(ALL) data(ALL) # specify several variables in ldaVar (this might take a few minutes to run...) # sample subsetting: currently cannot deal with missing values samplesToRemove <- which(apply(pData(ALL)[, c("sex", "BT")], 1, anyNA)) # extract random features, because analysis is quite time consuming retainedFeatures <- sample(featureNames(ALL), size = floor(nrow(ALL)/5)) # create the plot esetLda(eset = ALL[retainedFeatures, -samplesToRemove], ldaVar = "BT", colorVar = "BT", shapeVar = "sex", sizeVar = "age", title = "Linear discriminant analysis on the ALL dataset")
Wrapper function used for all plots of the visualizations contained in the package.
esetPlotWrapper( dataPlotSamples, dataPlotGenes = data.frame(), esetUsed, xlab = "", ylab = "", colorVar = character(0), color = if (length(colorVar) == 0) "black" else character(0), shapeVar = character(0), shape = if (length(shapeVar) == 0) 15 else numeric(0), sizeVar = character(0), size = if (length(sizeVar) == 0) { ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 20, 2.5) } else { numeric() }, sizeRange = numeric(0), alphaVar = character(0), alpha = if (length(alphaVar) == 0) 1 else numeric(0), alphaRange = numeric(0), title = "", symmetryAxes = c("combine", "separate", "none"), cloudGenes = TRUE, cloudGenesColor = "black", cloudGenesNBins = if (nrow(dataPlotGenes) > 0) sqrt(nrow(dataPlotGenes)) else numeric(), cloudGenesIncludeLegend = FALSE, cloudGenesTitleLegend = "nGenes", packageTextLabel = c("ggrepel", "ggplot2"), topGenes = 10, topGenesCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topGenesVar = character(0), topGenesJust = c(0.5, 0.5), topGenesColor = "black", topSamples = 10, topSamplesCex = 2.5, topSamplesVar = character(0), topSamplesJust = c(0.5, 0.5), topSamplesColor = "black", geneSets = list(), geneSetsVar = character(0), geneSetsMaxNChar = numeric(0), topGeneSets = 10, topGeneSetsCex = 2.5, topGeneSetsJust = c(0.5, 0.5), topGeneSetsColor = "black", includeLegend = TRUE, includeLineOrigin = TRUE, typePlot = c("static", "interactive"), figInteractiveSize = c(600, 400), ggvisAdjustLegend = TRUE, interactiveTooltip = TRUE, interactiveTooltipExtraVars = character(0), packageInteractivity = c("plotly", "ggvis"), returnTopElements = FALSE, returnEsetPlot = FALSE )
esetPlotWrapper( dataPlotSamples, dataPlotGenes = data.frame(), esetUsed, xlab = "", ylab = "", colorVar = character(0), color = if (length(colorVar) == 0) "black" else character(0), shapeVar = character(0), shape = if (length(shapeVar) == 0) 15 else numeric(0), sizeVar = character(0), size = if (length(sizeVar) == 0) { ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 20, 2.5) } else { numeric() }, sizeRange = numeric(0), alphaVar = character(0), alpha = if (length(alphaVar) == 0) 1 else numeric(0), alphaRange = numeric(0), title = "", symmetryAxes = c("combine", "separate", "none"), cloudGenes = TRUE, cloudGenesColor = "black", cloudGenesNBins = if (nrow(dataPlotGenes) > 0) sqrt(nrow(dataPlotGenes)) else numeric(), cloudGenesIncludeLegend = FALSE, cloudGenesTitleLegend = "nGenes", packageTextLabel = c("ggrepel", "ggplot2"), topGenes = 10, topGenesCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topGenesVar = character(0), topGenesJust = c(0.5, 0.5), topGenesColor = "black", topSamples = 10, topSamplesCex = 2.5, topSamplesVar = character(0), topSamplesJust = c(0.5, 0.5), topSamplesColor = "black", geneSets = list(), geneSetsVar = character(0), geneSetsMaxNChar = numeric(0), topGeneSets = 10, topGeneSetsCex = 2.5, topGeneSetsJust = c(0.5, 0.5), topGeneSetsColor = "black", includeLegend = TRUE, includeLineOrigin = TRUE, typePlot = c("static", "interactive"), figInteractiveSize = c(600, 400), ggvisAdjustLegend = TRUE, interactiveTooltip = TRUE, interactiveTooltipExtraVars = character(0), packageInteractivity = c("plotly", "ggvis"), returnTopElements = FALSE, returnEsetPlot = FALSE )
dataPlotSamples |
data.frame with columns 'X', 'Y' with coordinates
for the samples and with rownames which
should correspond and be in the same order as the sampleNames of
|
dataPlotGenes |
data.frame with two columns 'X' and 'Y' with coordinates for the genes |
esetUsed |
expressionSet (or SummarizedExperiment) object with data |
xlab |
label for the x axis |
ylab |
label for the y axis |
colorVar |
name of variable (in varLabels of the |
color |
character or factor with specified color(s) for the points,
replicated if needed. This is used only if |
shapeVar |
name of variable (in varLabels of the |
shape |
character or factor with specified shape(s) (pch) for the points,
replicated if needed. This is used only if |
sizeVar |
name of variable (in varLabels of the |
size |
character or factor with specified size(s) (cex) for the points,
replicated if needed.
This is used only if |
sizeRange |
size (cex) range used in the plot, possible only
if the |
alphaVar |
name of variable (in varLabels of the |
alpha |
character or factor with specified transparency(s) for the points,
replicated if needed. This is used only if |
alphaRange |
transparency (alpha) range used in the plot,
possible only if the |
title |
plot title, ” by default |
symmetryAxes |
set symmetry for axes, either:
|
cloudGenes |
logical, if TRUE (by default), include the cloud of genes in the plot |
cloudGenesColor |
if |
cloudGenesNBins |
number of bins to used for the clouds of genes, by default the square root of the number of genes |
cloudGenesIncludeLegend |
logical, if TRUE (FALSE by default) include the legend for the cloud of genes (in the top position if multiple legends) |
cloudGenesTitleLegend |
string with title for the legend for the cloud of genes 'nGenes' by default |
packageTextLabel |
package used to label the outlying genes/samples/gene sets,
either |
topGenes |
numeric indicating which percentile (if <1) or number (if >=1) of genes most distant to the origin of the plot to annotate, by default: 10 genes are selected If no genes should be annotated, set this parameter to 0 Currently only available for static plot. |
topGenesCex |
cex for gene annotation (used when |
topGenesVar |
variable of the featureData used to label the genes,
by default: empty, the featureNames are used for labelling (used when |
topGenesJust |
text justification for the genes
(used when |
topGenesColor |
text color for the genes
(used when |
topSamples |
numeric indicating which percentile (if <1) or number (if >=1) of samples most distant to the origin of the plot to annotate, by default: 10 samples are selected If no samples should be annotated, set this parameter to 0. Currently available for static plot. |
topSamplesCex |
cex for sample annotation (used when |
topSamplesVar |
variable of the phenoData used to label the samples,
by default: empty, the sampleNames are used for labelling
(used when |
topSamplesJust |
text justification for the samples
(used when |
topSamplesColor |
text color for the samples
(used when |
geneSets |
list of gene sets/pathways, each containing
identifiers of genes contained in the set.
E.g. pathways from Gene Ontology databases output from the
|
geneSetsVar |
variable of the featureData used to
match the genes contained in geneSets,
most probably ENTREZID, if not specified the featureNames
of the eSet are used
Only used when |
geneSetsMaxNChar |
maximum number of characters for pathway names,
by default keep entire names
Only used when |
topGeneSets |
numeric indicating which percentile (if <=1) or number (if >1) of gene sets
most distant to the origin of the plot to annotate, by default: 10 gene sets are selected
If no gene sets should be annotated, set this parameter to 0.
Currently available for static plot.
Only used when |
topGeneSetsCex |
cex for gene sets annotation
Only used when |
topGeneSetsJust |
text justification for the gene sets
by default: c(0.5, 0.5) so centered
Only used when |
topGeneSetsColor |
color for the gene sets
(used when |
includeLegend |
logical if TRUE (by default) include a legend, otherwise not |
includeLineOrigin |
if TRUE (by default) include vertical line at x = 0 and horizontal line at y = 0 |
typePlot |
type of the plot returned, either 'static' (static) or interactive' (potentially interactive) |
figInteractiveSize |
vector containing the size of the interactive plot,
as [width, height]
by default: c(600, 400). This is passed to the
|
ggvisAdjustLegend |
logical, if TRUE (by default) adjust the legends in |
interactiveTooltip |
logical, if TRUE, add hoover functionality showing sample annotation (variables used in the plot) in the plot |
interactiveTooltipExtraVars |
name of extra variable(s)
(in varLabels of the |
packageInteractivity |
if |
returnTopElements |
logical, if TRUE return also the top elements |
returnEsetPlot |
logical, if TRUE return also the esetPlot object |
if typePlot
is:
static
:
if returnTopElements
is TRUE, and top elements can be displayed, a list with:
'topElements': the top elements labelled in the plot
'plot': the ggplot
object
otherwise, the ggplot
object only
interactive
: a ggvis
or plotly
object,
depending on the packageInteractivity
parameter
Laure Cougnaud
library(ALL) data(ALL) ## run one spectral map analysis # create custom color palette colorPalette <- c("dodgerblue", colorRampPalette(c("white","dodgerblue2", "darkblue"))(5)[-1], "red", colorRampPalette(c("white", "red3", "darkred"))(5)[-1]) # run the analysis # with 'returnAnalysis' set to TRUE to have all objects required for the esetPlotWrapper outputEsetSPM <- esetSpectralMap(eset = ALL, title = "Acute lymphoblastic leukemia dataset \n Spectral map complete", colorVar = "BT", color = colorPalette, shapeVar = "sex", shape = 15:16, sizeVar = "age", sizeRange = c(2, 6), symmetryAxes = "separate", topGenes = 10, topGenesJust = c(1, 0), topGenesCex = 2, topGenesColor = "darkgrey", topSamples = 15, topSamplesVar = "cod", topSamplesColor = "black", topSamplesJust = c(1, 0), topSamplesCex = 3, returnAnalysis = TRUE) # plot the biplot print(outputEsetSPM$plot) ## re-call the plot function, to change some visualizations parameters esetPlotWrapper( dataPlotSamples = outputEsetSPM$analysis$dataPlotSamples, dataPlotGenes = outputEsetSPM$analysis$dataPlotGenes, esetUsed = outputEsetSPM$analysis$esetUsed, title = paste("Acute lymphoblastic leukemia dataset \n Spectral map"), colorVar = "BT", color = colorPalette, shapeVar = "relapse", sizeVar = "age", sizeRange = c(2, 6), topSamplesVar = "cod", topGenesVar = "SYMBOL" )
library(ALL) data(ALL) ## run one spectral map analysis # create custom color palette colorPalette <- c("dodgerblue", colorRampPalette(c("white","dodgerblue2", "darkblue"))(5)[-1], "red", colorRampPalette(c("white", "red3", "darkred"))(5)[-1]) # run the analysis # with 'returnAnalysis' set to TRUE to have all objects required for the esetPlotWrapper outputEsetSPM <- esetSpectralMap(eset = ALL, title = "Acute lymphoblastic leukemia dataset \n Spectral map complete", colorVar = "BT", color = colorPalette, shapeVar = "sex", shape = 15:16, sizeVar = "age", sizeRange = c(2, 6), symmetryAxes = "separate", topGenes = 10, topGenesJust = c(1, 0), topGenesCex = 2, topGenesColor = "darkgrey", topSamples = 15, topSamplesVar = "cod", topSamplesColor = "black", topSamplesJust = c(1, 0), topSamplesCex = 3, returnAnalysis = TRUE) # plot the biplot print(outputEsetSPM$plot) ## re-call the plot function, to change some visualizations parameters esetPlotWrapper( dataPlotSamples = outputEsetSPM$analysis$dataPlotSamples, dataPlotGenes = outputEsetSPM$analysis$dataPlotGenes, esetUsed = outputEsetSPM$analysis$esetUsed, title = paste("Acute lymphoblastic leukemia dataset \n Spectral map"), colorVar = "BT", color = colorPalette, shapeVar = "relapse", sizeVar = "age", sizeRange = c(2, 6), topSamplesVar = "cod", topGenesVar = "SYMBOL" )
esetSpectralMap
reduces the dimension of the data contained in the eSet with the mpm
function
and plot the subsequent biplot of the specified dimensions, possibly with gene and sample annotation contained in the eSet.
A spectral map with the default parameters is equivalent to a
principal component analysis on the log-transformed, double centered and
global normalized data (from documentation of the mpm
function).
esetSpectralMap( eset, psids = 1:nrow(eset), dim = c(1, 2), colorVar = character(), color = if (length(colorVar) == 0) "black" else character(), shapeVar = character(), shape = if (length(shapeVar) == 0) 15 else numeric(), sizeVar = character(), size = if (length(sizeVar) == 0) { ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 20, 2.5) } else { numeric() }, sizeRange = numeric(), alphaVar = character(), alpha = if (length(alphaVar) == 0) 1 else numeric(), alphaRange = numeric(), title = "", mpm.args = list(closure = "none", center = "double", normal = "global", row.weight = "mean", col.weight = "constant", logtrans = FALSE), plot.mpm.args = list(scale = "uvc"), symmetryAxes = c("combine", "separate", "none"), packageTextLabel = c("ggrepel", "ggplot2"), cloudGenes = TRUE, cloudGenesColor = "black", cloudGenesNBins = sqrt(length(psids)), cloudGenesIncludeLegend = FALSE, cloudGenesTitleLegend = "nGenes", topGenes = 10, topGenesCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topGenesVar = character(), topGenesJust = c(0.5, 0.5), topGenesColor = "black", topSamples = 10, topSamplesCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topSamplesVar = character(), topSamplesJust = c(0.5, 0.5), topSamplesColor = "black", geneSets = list(), geneSetsVar = character(), geneSetsMaxNChar = numeric(), topGeneSets = 10, topGeneSetsCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topGeneSetsJust = c(0.5, 0.5), topGeneSetsColor = "black", includeLegend = TRUE, includeLineOrigin = TRUE, typePlot = c("static", "interactive"), packageInteractivity = c("plotly", "ggvis"), figInteractiveSize = c(600, 400), ggvisAdjustLegend = TRUE, interactiveTooltip = TRUE, interactiveTooltipExtraVars = character(), returnAnalysis = FALSE, returnEsetPlot = FALSE )
esetSpectralMap( eset, psids = 1:nrow(eset), dim = c(1, 2), colorVar = character(), color = if (length(colorVar) == 0) "black" else character(), shapeVar = character(), shape = if (length(shapeVar) == 0) 15 else numeric(), sizeVar = character(), size = if (length(sizeVar) == 0) { ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 20, 2.5) } else { numeric() }, sizeRange = numeric(), alphaVar = character(), alpha = if (length(alphaVar) == 0) 1 else numeric(), alphaRange = numeric(), title = "", mpm.args = list(closure = "none", center = "double", normal = "global", row.weight = "mean", col.weight = "constant", logtrans = FALSE), plot.mpm.args = list(scale = "uvc"), symmetryAxes = c("combine", "separate", "none"), packageTextLabel = c("ggrepel", "ggplot2"), cloudGenes = TRUE, cloudGenesColor = "black", cloudGenesNBins = sqrt(length(psids)), cloudGenesIncludeLegend = FALSE, cloudGenesTitleLegend = "nGenes", topGenes = 10, topGenesCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topGenesVar = character(), topGenesJust = c(0.5, 0.5), topGenesColor = "black", topSamples = 10, topSamplesCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topSamplesVar = character(), topSamplesJust = c(0.5, 0.5), topSamplesColor = "black", geneSets = list(), geneSetsVar = character(), geneSetsMaxNChar = numeric(), topGeneSets = 10, topGeneSetsCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topGeneSetsJust = c(0.5, 0.5), topGeneSetsColor = "black", includeLegend = TRUE, includeLineOrigin = TRUE, typePlot = c("static", "interactive"), packageInteractivity = c("plotly", "ggvis"), figInteractiveSize = c(600, 400), ggvisAdjustLegend = TRUE, interactiveTooltip = TRUE, interactiveTooltipExtraVars = character(), returnAnalysis = FALSE, returnEsetPlot = FALSE )
eset |
expressionSet (or SummarizedExperiment) object with data |
psids |
featureNames of genes to include in the plot, all by default |
dim |
dimensions of the analysis to represent, first two dimensions by default |
colorVar |
name of variable (in varLabels of the |
color |
character or factor with specified color(s) for the points,
replicated if needed. This is used only if |
shapeVar |
name of variable (in varLabels of the |
shape |
character or factor with specified shape(s) (pch) for the points,
replicated if needed. This is used only if |
sizeVar |
name of variable (in varLabels of the |
size |
character or factor with specified size(s) (cex) for the points,
replicated if needed.
This is used only if |
sizeRange |
size (cex) range used in the plot, possible only
if the |
alphaVar |
name of variable (in varLabels of the |
alpha |
character or factor with specified transparency(s) for the points,
replicated if needed. This is used only if |
alphaRange |
transparency (alpha) range used in the plot,
possible only if the |
title |
plot title, ” by default |
mpm.args |
list with input parameters for the |
plot.mpm.args |
list with input parameters for the |
symmetryAxes |
set symmetry for axes, either:
|
packageTextLabel |
package used to label the outlying genes/samples/gene sets,
either |
cloudGenes |
logical, if TRUE (by default), include the cloud of genes in the plot |
cloudGenesColor |
if |
cloudGenesNBins |
number of bins to used for the clouds of genes, by default the square root of the number of genes |
cloudGenesIncludeLegend |
logical, if TRUE (FALSE by default) include the legend for the cloud of genes (in the top position if multiple legends) |
cloudGenesTitleLegend |
string with title for the legend for the cloud of genes 'nGenes' by default |
topGenes |
numeric indicating which percentile (if <1) or number (if >=1) of genes most distant to the origin of the plot to annotate, by default: 10 genes are selected If no genes should be annotated, set this parameter to 0 Currently only available for static plot. |
topGenesCex |
cex for gene annotation (used when |
topGenesVar |
variable of the featureData used to label the genes,
by default: empty, the featureNames are used for labelling (used when |
topGenesJust |
text justification for the genes
(used when |
topGenesColor |
text color for the genes
(used when |
topSamples |
numeric indicating which percentile (if <1) or number (if >=1) of samples most distant to the origin of the plot to annotate, by default: 10 samples are selected If no samples should be annotated, set this parameter to 0. Currently available for static plot. |
topSamplesCex |
cex for sample annotation (used when |
topSamplesVar |
variable of the phenoData used to label the samples,
by default: empty, the sampleNames are used for labelling
(used when |
topSamplesJust |
text justification for the samples
(used when |
topSamplesColor |
text color for the samples
(used when |
geneSets |
list of gene sets/pathways, each containing
identifiers of genes contained in the set.
E.g. pathways from Gene Ontology databases output from the
|
geneSetsVar |
variable of the featureData used to
match the genes contained in geneSets,
most probably ENTREZID, if not specified the featureNames
of the eSet are used
Only used when |
geneSetsMaxNChar |
maximum number of characters for pathway names,
by default keep entire names
Only used when |
topGeneSets |
numeric indicating which percentile (if <=1) or number (if >1) of gene sets
most distant to the origin of the plot to annotate, by default: 10 gene sets are selected
If no gene sets should be annotated, set this parameter to 0.
Currently available for static plot.
Only used when |
topGeneSetsCex |
cex for gene sets annotation
Only used when |
topGeneSetsJust |
text justification for the gene sets
by default: c(0.5, 0.5) so centered
Only used when |
topGeneSetsColor |
color for the gene sets
(used when |
includeLegend |
logical if TRUE (by default) include a legend, otherwise not |
includeLineOrigin |
if TRUE (by default) include vertical line at x = 0 and horizontal line at y = 0 |
typePlot |
type of the plot returned, either 'static' (static) or interactive' (potentially interactive) |
packageInteractivity |
if |
figInteractiveSize |
vector containing the size of the interactive plot,
as [width, height]
by default: c(600, 400). This is passed to the
|
ggvisAdjustLegend |
logical, if TRUE (by default) adjust the legends in |
interactiveTooltip |
logical, if TRUE, add hoover functionality showing sample annotation (variables used in the plot) in the plot |
interactiveTooltipExtraVars |
name of extra variable(s)
(in varLabels of the |
returnAnalysis |
logical, if TRUE (FALSE by default), return also the output of the analysis, and the outlying samples in the topElements element if any, otherwise only the plot object |
returnEsetPlot |
logical, if TRUE return also the esetPlot object |
if returnAnalysis
is TRUE, return a list:
analysis: output of the spectral map analysis, can be given as input to the esetPlotWrapper
function
dataPlotSamples: coordinates of the samples
dataPlotGenes: coordinates of the genes
esetUsed: expressionSet used in the plot
axisLabels: axes labels indicating percentage of variance explained by the selected axes
axesContributionsPercentages: percentages of variance explained by each axis (not only the ones specified in dim
)
topElements: list with top outlying elements if any, possibly genes, samples and gene sets
plot: the plot output
otherwise return only the plot
Laure Cougnaud
Lewi, P.J. (1976). Spectral mapping, a technique for classifying biological activity profiles of chemical compounds. Arzneimittel Forschung (Drug Research), 26, 1295–1300
the function used internally: mpm
and
spectralMap
for spectral map in base R graphics
library(ALL) data(ALL) ## complete example (most of the parameters are optional) # create custom color palette colorPalette <- c("dodgerblue", colorRampPalette(c("white","dodgerblue2", "darkblue"))(5)[-1], "red", colorRampPalette(c("white", "red3", "darkred"))(5)[-1]) # plot the spectral map print(esetSpectralMap(eset = ALL, title = "Acute lymphoblastic leukemia dataset \n Spectral map complete", colorVar = "BT", color = colorPalette, shapeVar = "sex", shape = 15:16, sizeVar = "age", sizeRange = c(2, 6), symmetryAxes = "separate", topGenes = 10, topGenesJust = c(1, 0), topGenesCex = 2, topGenesColor = "darkgrey", topSamples = 15, topSamplesVar = "cod", topSamplesColor = "black", topSamplesJust = c(1, 0), topSamplesCex = 3) ) # see vignette for other examples, especially one with gene sets specification
library(ALL) data(ALL) ## complete example (most of the parameters are optional) # create custom color palette colorPalette <- c("dodgerblue", colorRampPalette(c("white","dodgerblue2", "darkblue"))(5)[-1], "red", colorRampPalette(c("white", "red3", "darkred"))(5)[-1]) # plot the spectral map print(esetSpectralMap(eset = ALL, title = "Acute lymphoblastic leukemia dataset \n Spectral map complete", colorVar = "BT", color = colorPalette, shapeVar = "sex", shape = 15:16, sizeVar = "age", sizeRange = c(2, 6), symmetryAxes = "separate", topGenes = 10, topGenesJust = c(1, 0), topGenesCex = 2, topGenesColor = "darkgrey", topSamples = 15, topSamplesVar = "cod", topSamplesColor = "black", topSamplesJust = c(1, 0), topSamplesCex = 3) ) # see vignette for other examples, especially one with gene sets specification
esetTsne
reduces the dimension of the data contained in the eSet via t-Distributed Stochastic Neighbor Embedding
with the Rtsne
function and plot the subsequent biplot, possibly with sample annotation contained in the eSet.
esetTsne( eset, psids = 1:nrow(eset), trace = TRUE, colorVar = character(), color = if (length(colorVar) == 0) "black" else character(), shapeVar = character(), shape = if (length(shapeVar) == 0) 15 else numeric(), sizeVar = character(), size = if (length(sizeVar) == 0) { ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 20, 2.5) } else { numeric() }, sizeRange = numeric(), alphaVar = character(), alpha = if (length(alphaVar) == 0) 1 else numeric(), alphaRange = numeric(), title = "", Rtsne.args = list(perplexity = floor((ncol(eset) - 1)/3), theta = 0.5, dims = 2, initial_dims = 50), fctTransformDataForInputTsne = NULL, symmetryAxes = c("combine", "separate", "none"), packageTextLabel = c("ggrepel", "ggplot2"), topSamples = 10, topSamplesCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topSamplesVar = character(), topSamplesJust = c(0.5, 0.5), topSamplesColor = "black", includeLegend = TRUE, includeLineOrigin = TRUE, typePlot = c("static", "interactive"), packageInteractivity = c("plotly", "ggvis"), figInteractiveSize = c(600, 400), ggvisAdjustLegend = TRUE, interactiveTooltip = TRUE, interactiveTooltipExtraVars = character(), returnAnalysis = FALSE, returnEsetPlot = FALSE )
esetTsne( eset, psids = 1:nrow(eset), trace = TRUE, colorVar = character(), color = if (length(colorVar) == 0) "black" else character(), shapeVar = character(), shape = if (length(shapeVar) == 0) 15 else numeric(), sizeVar = character(), size = if (length(sizeVar) == 0) { ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 20, 2.5) } else { numeric() }, sizeRange = numeric(), alphaVar = character(), alpha = if (length(alphaVar) == 0) 1 else numeric(), alphaRange = numeric(), title = "", Rtsne.args = list(perplexity = floor((ncol(eset) - 1)/3), theta = 0.5, dims = 2, initial_dims = 50), fctTransformDataForInputTsne = NULL, symmetryAxes = c("combine", "separate", "none"), packageTextLabel = c("ggrepel", "ggplot2"), topSamples = 10, topSamplesCex = ifelse(typePlot[1] == "interactive" && packageInteractivity[1] == "plotly", 10, 2.5), topSamplesVar = character(), topSamplesJust = c(0.5, 0.5), topSamplesColor = "black", includeLegend = TRUE, includeLineOrigin = TRUE, typePlot = c("static", "interactive"), packageInteractivity = c("plotly", "ggvis"), figInteractiveSize = c(600, 400), ggvisAdjustLegend = TRUE, interactiveTooltip = TRUE, interactiveTooltipExtraVars = character(), returnAnalysis = FALSE, returnEsetPlot = FALSE )
eset |
expressionSet (or SummarizedExperiment) object with data |
psids |
featureNames of genes to include in the plot, all by default |
trace |
logical, if TRUE (by default), print some messages during tsne is running |
colorVar |
name of variable (in varLabels of the |
color |
character or factor with specified color(s) for the points,
replicated if needed. This is used only if |
shapeVar |
name of variable (in varLabels of the |
shape |
character or factor with specified shape(s) (pch) for the points,
replicated if needed. This is used only if |
sizeVar |
name of variable (in varLabels of the |
size |
character or factor with specified size(s) (cex) for the points,
replicated if needed.
This is used only if |
sizeRange |
size (cex) range used in the plot, possible only
if the |
alphaVar |
name of variable (in varLabels of the |
alpha |
character or factor with specified transparency(s) for the points,
replicated if needed. This is used only if |
alphaRange |
transparency (alpha) range used in the plot,
possible only if the |
title |
plot title, ” by default |
Rtsne.args |
arguments for the Rtsne function, by default: perplexite parameter = optimal number of neighbours, theta = speed/accuracy trade-off (increase for less accuracy), set to 0.0 for exact TSNE |
fctTransformDataForInputTsne |
function which transform the data in the eSet object before
calling the |
symmetryAxes |
set symmetry for axes, either:
|
packageTextLabel |
package used to label the outlying genes/samples/gene sets,
either |
topSamples |
numeric indicating which percentile (if <1) or number (if >=1) of samples most distant to the origin of the plot to annotate, by default: 10 samples are selected If no samples should be annotated, set this parameter to 0. Currently available for static plot. |
topSamplesCex |
cex for sample annotation (used when |
topSamplesVar |
variable of the phenoData used to label the samples,
by default: empty, the sampleNames are used for labelling
(used when |
topSamplesJust |
text justification for the samples
(used when |
topSamplesColor |
text color for the samples
(used when |
includeLegend |
logical if TRUE (by default) include a legend, otherwise not |
includeLineOrigin |
if TRUE (by default) include vertical line at x = 0 and horizontal line at y = 0 |
typePlot |
type of the plot returned, either 'static' (static) or interactive' (potentially interactive) |
packageInteractivity |
if |
figInteractiveSize |
vector containing the size of the interactive plot,
as [width, height]
by default: c(600, 400). This is passed to the
|
ggvisAdjustLegend |
logical, if TRUE (by default) adjust the legends in |
interactiveTooltip |
logical, if TRUE, add hoover functionality showing sample annotation (variables used in the plot) in the plot |
interactiveTooltipExtraVars |
name of extra variable(s)
(in varLabels of the |
returnAnalysis |
logical, if TRUE (FALSE by default), return also the output of the analysis, and the outlying samples in the topElements element if any, otherwise only the plot object |
returnEsetPlot |
logical, if TRUE return also the esetPlot object |
if returnAnalysis
is TRUE, return a list:
analysis: output of the spectral map analysis, whose elements can be given
to the esetPlotWrapper
function
dataPlotSamples: coordinates of the samples
esetUsed: expressionSet used in the plot
topElements: list with top outlying elements if any, possibly genes, samples and gene sets
plot: the plot output
otherwise return only the plot
Laure Cougnaud
L.J.P. van der Maaten and G.E. Hinton (2008). Visualizing High-Dimensional Data Using t-SNE. Journal of Machine Learning Research, 2579–2605
the function used internally: Rtsne
or http://homepage.tudelft.nl/19j49/t-SNE.html
for further explanations about this technique.
library(ALL) data(ALL) ## complete example (most of the parameters are optional) # create custom color palette colorPalette <- c("dodgerblue", colorRampPalette(c("white","dodgerblue2", "darkblue"))(5)[-1], "red", colorRampPalette(c("white", "red3", "darkred"))(5)[-1]) # create tsne print(esetTsne(eset = ALL, title = "Acute lymphoblastic leukemia dataset \n Tsne complete", colorVar = "BT", color = colorPalette, shapeVar = "sex", shape = 15:16, sizeVar = "age", sizeRange = c(2, 6), symmetryAxes = "separate", topSamples = 15, topSamplesVar = "cod", topSamplesColor = "black", topSamplesJust = c(1, 0), topSamplesCex = 3) )
library(ALL) data(ALL) ## complete example (most of the parameters are optional) # create custom color palette colorPalette <- c("dodgerblue", colorRampPalette(c("white","dodgerblue2", "darkblue"))(5)[-1], "red", colorRampPalette(c("white", "red3", "darkred"))(5)[-1]) # create tsne print(esetTsne(eset = ALL, title = "Acute lymphoblastic leukemia dataset \n Tsne complete", colorVar = "BT", color = colorPalette, shapeVar = "sex", shape = 15:16, sizeVar = "age", sizeRange = c(2, 6), symmetryAxes = "separate", topSamples = 15, topSamplesVar = "cod", topSamplesColor = "black", topSamplesJust = c(1, 0), topSamplesCex = 3) )
get and format gene sets to be used as geneSets
for the functions:
esetSpectralMap
, esetLda
, or esetPlotWrapper
Use the getGeneSets
function to get the gene sets,
combine all databases, and format the gene sets name if required.
getGeneSetsForPlot( entrezIdentifiers, species = "Human", geneSetSource = c("GOBP", "GOMF", "GOCC", "KEGG"), useDescription = TRUE, trace = TRUE )
getGeneSetsForPlot( entrezIdentifiers, species = "Human", geneSetSource = c("GOBP", "GOMF", "GOCC", "KEGG"), useDescription = TRUE, trace = TRUE )
entrezIdentifiers |
string with Entrez Gene identifiers of the genes of interest |
species |
species to use, given to the |
geneSetSource |
gene set source, either 'GOBP', 'GOMF', 'GOCC' or 'KEGG'. Multiple choices are available |
useDescription |
logical, if TRUE (by default) use the description to label the gene sets, otherwise use the original gene set identifiers Function 'substr' is used. |
trace |
logical, if TRUE (by default) a few extra information are printed during the process |
list with gene sets, each element is a gene set and
contains the ENTREZ IDs of the genes contained in this set.
If useDescription
is:
FALSE: pathways are labelled with identifiers (Gene Ontology IDs for GOBP, GOMF and GOCC, KEGG IDs for KEGG)
TRUE: pathways are labelled with gene sets descriptions
Laure Cougnaud
the function used internally: getGeneSets
# example dataset library(ALL) data(ALL) # get gene annotation from probe IDs library("hgu95av2.db") probeIDs <- featureNames(ALL) geneInfo <- select(hgu95av2.db, probeIDs,"ENTREZID", "PROBEID") # get pathway annotation for the genes contained in the ALL dataset (can take a few minutes) geneSets <- getGeneSetsForPlot(entrezIdentifiers = geneInfo$ENTREZID, species = "Human", geneSetSource = 'GOBP', useDescription = FALSE, trace = TRUE) head(geneSets) # returns a pathway list of genes # gene sets labelled with gene sets description geneSets <- getGeneSetsForPlot(entrezIdentifiers = geneInfo$ENTREZID, species = "Human", geneSetSource = 'GOBP', useDescription = TRUE, trace = TRUE) head(geneSets) # returns a pathway list of genes # see also vignette for an example of the use of this function as input for the esetSpectralMap, esetLda or esetPlotWrapper functions
# example dataset library(ALL) data(ALL) # get gene annotation from probe IDs library("hgu95av2.db") probeIDs <- featureNames(ALL) geneInfo <- select(hgu95av2.db, probeIDs,"ENTREZID", "PROBEID") # get pathway annotation for the genes contained in the ALL dataset (can take a few minutes) geneSets <- getGeneSetsForPlot(entrezIdentifiers = geneInfo$ENTREZID, species = "Human", geneSetSource = 'GOBP', useDescription = FALSE, trace = TRUE) head(geneSets) # returns a pathway list of genes # gene sets labelled with gene sets description geneSets <- getGeneSetsForPlot(entrezIdentifiers = geneInfo$ENTREZID, species = "Human", geneSetSource = 'GOBP', useDescription = TRUE, trace = TRUE) head(geneSets) # returns a pathway list of genes # see also vignette for an example of the use of this function as input for the esetSpectralMap, esetLda or esetPlotWrapper functions
ggplot
plotsa S4 class to represent ggplot
plots
S4 object of class ggplotEsetPlot
returnTopElements
logical, if TRUE (FALSE by default) return the outlying elements labelled in the plot (if any)
title
string or expression with plot title, ” by default
xlab
string or expression with label for the x axis
ylab
string or expression with label for the y axis
Laure Cougnaud