Title: | single-cell higher order testing |
---|---|
Description: | Single cell Higher Order Testing (scHOT) is an R package that facilitates testing changes in higher order structure of gene expression along either a developmental trajectory or across space. scHOT is general and modular in nature, can be run in multiple data contexts such as along a continuous trajectory, between discrete groups, and over spatial orientations; as well as accommodate any higher order measurement such as variability or correlation. scHOT meaningfully adds to first order effect testing, such as differential expression, and provides a framework for interrogating higher order interactions from single cell data. |
Authors: | Shila Ghazanfar [aut, cre], Yingxin Lin [aut] |
Maintainer: | Shila Ghazanfar <[email protected]> |
License: | GPL-3 |
Version: | 1.19.0 |
Built: | 2025-01-22 06:15:08 UTC |
Source: | https://github.com/bioc/scHOT |
A liver data set contains two branches (hepatocyte and cholangiocyte).
data(liver, package = 'scHOT')
data(liver, package = 'scHOT')
A 'list' object.
A MOB spatial data set.
data(MOB_subset, package = 'scHOT')
data(MOB_subset, package = 'scHOT')
An object of class list
of length 1.
Setter functions for scHOT objects
params(x) <- value
params(x) <- value
x |
A scHOT object |
value |
The value the slot should take |
A scHOT object
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) params = list(higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted") params(scHOT_spatial) <- params
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) params = list(higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted") params(scHOT_spatial) <- params
the plotColouredExpression function plots an n-panel scatterplot of the gene pairs split by early, mid, and late in the sample ordering.
plotColouredExpression( scHOT, genes, genes_delimeter = "_", branches = NULL, ranked_by = NULL, subsetBranch = NULL, n = 3, fittedline = TRUE, assayName = NULL )
plotColouredExpression( scHOT, genes, genes_delimeter = "_", branches = NULL, ranked_by = NULL, subsetBranch = NULL, n = 3, fittedline = TRUE, assayName = NULL )
scHOT |
A scHOT object. |
genes |
is either a single character string with a delimeter, or a length two character vector |
genes_delimeter |
is the delimeter to split into two gene names if genes is provided as a single character |
branches |
A character indicates that the colnames stored the branch information in colData |
ranked_by |
A character indicates that the colnames stored the ranking information of the cells in colData, such as trajectory time, if it is NULL, it will be ranked based on the branch information. |
subsetBranch |
subsetBranch is a character vector containing the names of the branches to be plotted. If NULL it will plot all branches |
n |
number of panels to split ranked samples into, default 3. |
fittedline |
logical default TRUE, add a lm straight line to the plot |
assayName |
the name of the assay that are used to plot. |
ggplot
a ggplot object of scatterplots of expression
split by sample ordering
data(liver) scHOT_traj <- scHOT_buildFromMatrix( mat = liver$liver_branch_hep, cellData = list(pseudotime = liver$liver_pseudotime_hep), positionType = "trajectory", positionColData = "pseudotime") scHOT_traj plotColouredExpression(scHOT_traj, c("Cdt1","Top2a"), n = 5)
data(liver) scHOT_traj <- scHOT_buildFromMatrix( mat = liver$liver_branch_hep, cellData = list(pseudotime = liver$liver_pseudotime_hep), positionType = "trajectory", positionColData = "pseudotime") scHOT_traj plotColouredExpression(scHOT_traj, c("Cdt1","Top2a"), n = 5)
the plotEgoNetwork function plots network graphs with edges coloured by weights in the network
plotEgoNetwork( scHOT, hubnode, network, weight = "higherOrderStatistic", subset = FALSE, thresh = NULL )
plotEgoNetwork( scHOT, hubnode, network, weight = "higherOrderStatistic", subset = FALSE, thresh = NULL )
scHOT |
a scHOT object |
hubnode |
is a character vector of node(s) to include as hub nodes |
network |
is an igraph network |
weight |
A string indicates the column name stored in scHOT_output slot that are used as the weights of the network |
subset |
is a logical asking if you should subset based on the weight (default FALSE) |
thresh |
is the subset weight threshold |
igraph
object containing the network graphed.
Produces an igraph plot
the plotHigherOrderSequence function plots weighted higher order statistic vectors (stored in higherOrderSequence) as line plots
plotHigherOrderSequence( scHOT, gene, positionType = NULL, branches = NULL, positionColData = NULL )
plotHigherOrderSequence( scHOT, gene, positionType = NULL, branches = NULL, positionColData = NULL )
scHOT |
A scHOT object with higherOrderSequence in scHOT_output slot |
gene |
is either a logical vector matching rows of entries in wcorsList, or a character of a gene |
positionType |
A string indicates the position type, either trajectory or spatial |
branches |
A character indicates that the colnames stored the branch information in colData (for trajectory type of data) |
positionColData |
A vector indicates column names of colData that stored the postion informaton (for spatial type of data) |
ggplot
object with line plots
data(liver) scHOT_traj <- scHOT_buildFromMatrix( mat = liver$liver_branch_hep, cellData = list(pseudotime = liver$liver_pseudotime_hep), positionType = "trajectory", positionColData = "pseudotime") scHOT_traj plotColouredExpression(scHOT_traj, c("Cdt1","Top2a"), n = 5) scHOT_traj <- scHOT_addTestingScaffold(scHOT_traj, t(as.matrix(c("Cdt1", "Top2a")))) scHOT_traj <- scHOT_setWeightMatrix(scHOT_traj, positionColData = c("pseudotime"), positionType = "trajectory", nrow.out = NULL, span = 0.25) scHOT_traj <- scHOT_calculateGlobalHigherOrderFunction(scHOT_traj, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted") scHOT_traj <- scHOT_calculateHigherOrderTestStatistics(scHOT_traj, higherOrderSummaryFunction = sd) slot(scHOT_traj, "scHOT_output") plotHigherOrderSequence(scHOT_traj, c("Cdt1_Top2a"))
data(liver) scHOT_traj <- scHOT_buildFromMatrix( mat = liver$liver_branch_hep, cellData = list(pseudotime = liver$liver_pseudotime_hep), positionType = "trajectory", positionColData = "pseudotime") scHOT_traj plotColouredExpression(scHOT_traj, c("Cdt1","Top2a"), n = 5) scHOT_traj <- scHOT_addTestingScaffold(scHOT_traj, t(as.matrix(c("Cdt1", "Top2a")))) scHOT_traj <- scHOT_setWeightMatrix(scHOT_traj, positionColData = c("pseudotime"), positionType = "trajectory", nrow.out = NULL, span = 0.25) scHOT_traj <- scHOT_calculateGlobalHigherOrderFunction(scHOT_traj, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted") scHOT_traj <- scHOT_calculateHigherOrderTestStatistics(scHOT_traj, higherOrderSummaryFunction = sd) slot(scHOT_traj, "scHOT_output") plotHigherOrderSequence(scHOT_traj, c("Cdt1_Top2a"))
the plotOrderedExpression function plots expression vectors along branches and genes as ribbon plots
plotOrderedExpression( scHOT, genes, positionType = NULL, branches = NULL, ranked_by = NULL, xvals = NULL, subsetBranch = NULL, facet = FALSE, positionColData = NULL, assayName = NULL )
plotOrderedExpression( scHOT, genes, positionType = NULL, branches = NULL, ranked_by = NULL, xvals = NULL, subsetBranch = NULL, facet = FALSE, positionColData = NULL, assayName = NULL )
scHOT |
A scHOT object, where the expression data is stored in the assay slot, with assay name "expression". |
genes |
is a character vector for gene names |
positionType |
A string indicates the position type, either trajectory or spatial |
branches |
A character indicates that the colnames stored the branch information in colData |
ranked_by |
A character indicates that the colnames stored the ranking information of the cells in colData, such as trajectory time |
xvals |
A character indicates that the colnames stored in colData of the x-values associated with the samples in branchData |
subsetBranch |
subsetBranch is a character vector containing the names of the branches to be plotted. If NULL it will plot all branches |
facet |
can either be FALSE, "branch", "gene", or "both" |
positionColData |
A vector indicates column names of colData that stored the postion informaton (for spatial type of data) |
assayName |
the name of the assay that are used to plot. |
ggplot
a ggplot object for ribbon plot with points
Setter functions for scHOT objects
positionColData(x) <- value
positionColData(x) <- value
x |
A scHOT object |
value |
The value the slot should take |
A scHOT object
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) positionColData(scHOT_spatial) <- c("x", "y")
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) positionColData(scHOT_spatial) <- c("x", "y")
Setter functions for scHOT objects
positionType(x) <- value
positionType(x) <- value
x |
A scHOT object |
value |
The value the slot should take |
A scHOT object
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) positionType(scHOT_spatial) <- "spatial"
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) positionType(scHOT_spatial) <- "spatial"
A wrapper function to perform scHOT
scHOT( scHOT, testingScaffold = NULL, weightMatrix = NULL, positionType = NULL, positionColData = NULL, nrow.out = NULL, averageAcrossTrajectoryTies = FALSE, higherOrderFunction = NULL, higherOrderFunctionType = NULL, numberPermutations = 1000, numberScaffold = 100, storePermutations = TRUE, higherOrderSummaryFunction = sd, parallel = FALSE, BPPARAM = BiocParallel::SerialParam(), usenperm_estimate = FALSE, nperm_estimate = 10000, maxDist = 0.1, plot = FALSE, verbose = TRUE, ... )
scHOT( scHOT, testingScaffold = NULL, weightMatrix = NULL, positionType = NULL, positionColData = NULL, nrow.out = NULL, averageAcrossTrajectoryTies = FALSE, higherOrderFunction = NULL, higherOrderFunctionType = NULL, numberPermutations = 1000, numberScaffold = 100, storePermutations = TRUE, higherOrderSummaryFunction = sd, parallel = FALSE, BPPARAM = BiocParallel::SerialParam(), usenperm_estimate = FALSE, nperm_estimate = 10000, maxDist = 0.1, plot = FALSE, verbose = TRUE, ... )
scHOT |
A scHOT object |
testingScaffold |
A matrix with rows for each testing combination |
weightMatrix |
A matrix indicates the weight matrix for scHOT analysis |
positionType |
A string indicating the position type, either "trajectory" or "spatial" |
positionColData |
Either trajectory or spatial information for each sample. If positionType is "trajectory" then positionColData should be a character or numeric indicating the subset of colData of the scHOT object. If positionType is "spatial" then positionColData should be a character or numeric vector indicating the subset of colData that give the full spatial coordinates. |
nrow.out |
The number of weightings to include for testing, a smaller value is faster for computation |
averageAcrossTrajectoryTies |
Logical indicating whether ties in the trajectory should be given the same local weights |
higherOrderFunction |
A function object indicates the higher order function |
higherOrderFunctionType |
is "weighted" or "unweighted", determines if there is a weighting argument in the higher order function |
numberPermutations |
The number of permutations, set as 1000 by default |
numberScaffold |
The number of testing scaffolds to perform permutations, set as 100 by default |
storePermutations |
a logical flag on whether permutation values should be saved |
higherOrderSummaryFunction |
A functon indicating the higher order summary function (default is standard deviation 'sd') |
parallel |
A logical input indicating whether to run the permutation test using multiple cores in parallel. |
BPPARAM |
A |
usenperm_estimate |
Logical (default FALSE) if number of neighbouring permutations should be used to estimate P-values, or if difference of global higher order statistic should be used |
nperm_estimate |
Number of neighbouring permutations to use for p-value estimation |
maxDist |
max difference of global higher order statistic to use for p-value estimation (default 0.1) |
plot |
A logical input indicating whether the results are plotted |
verbose |
A logical input indicating whether the intermediate steps will be printed |
... |
parameters for function trajectoryWeightMatrix or spatialWeightMatrix |
A scHOT object
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT(scHOT_spatial, testingScaffold = pairs, positionType = "spatial", positionColData = c("x", "y"), nrow.out = NULL, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted", numberPermutations = 100, higherOrderSummaryFunction = sd, parallel = FALSE, verbose = TRUE, span = 0.05)
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT(scHOT_spatial, testingScaffold = pairs, positionType = "spatial", positionColData = c("x", "y"), nrow.out = NULL, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted", numberPermutations = 100, higherOrderSummaryFunction = sd, parallel = FALSE, verbose = TRUE, span = 0.05)
Add a testing scaffold to a scHOT object
scHOT_addTestingScaffold(scHOT, testingScaffold)
scHOT_addTestingScaffold(scHOT, testingScaffold)
scHOT |
A scHOT object |
testingScaffold |
A matrix with rows for each testing combination, and columns for level of dimensionality (1 for single gene etc.) |
A scHOT object with slot testingScaffold saved
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs)
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs)
Create scHOT object from a matrix
scHOT_buildFromMatrix( mat, cellData = NULL, positionType = NULL, positionColData = NULL )
scHOT_buildFromMatrix( mat, cellData = NULL, positionType = NULL, positionColData = NULL )
mat |
A matrix with rows for genes and columns for cells |
cellData |
A dataframe or DataFrame object with rows for cells |
positionType |
A string indicating the position type, either "trajectory" or "spatial" |
positionColData |
Strings indicate the position information stored in colData. If positionType is "trajectory" then positionColData should be a sortable vector if positionType is "spatial" then positionColData should be a matrix type object. |
A scHOT object
dat <- rbind(rnorm(50), rnorm(50), rnorm(50)) colnames(dat) <- paste0("cell_", 1:ncol(dat)) rownames(dat) <- c("gene_1","gene_2", "gene_2") scHOT <- scHOT_buildFromMatrix(dat, cellData = data.frame(1:ncol(dat)))
dat <- rbind(rnorm(50), rnorm(50), rnorm(50)) colnames(dat) <- paste0("cell_", 1:ncol(dat)) rownames(dat) <- c("gene_1","gene_2", "gene_2") scHOT <- scHOT_buildFromMatrix(dat, cellData = data.frame(1:ncol(dat)))
Create scHOT object from a SingleCellExperiment object
scHOT_buildFromSCE( sce, assayName = "counts", positionType = NULL, positionColData = NULL )
scHOT_buildFromSCE( sce, assayName = "counts", positionType = NULL, positionColData = NULL )
sce |
A SingleCellExperiment object |
assayName |
is a single assay to pull out from sce as the expression matrix input of scHOT |
positionType |
A string indicates the position type, either trajectory or spatial |
positionColData |
Strings indicate the position information stored in colData. If positionType is "trajectory" then positionColData should be a sortable vector if positionType is "spatial" then positionColData should be a matrix type object. |
A scHOT object
library(SingleCellExperiment) dat <- rbind(rnorm(50), rnorm(50), rnorm(50)) colnames(dat) <- paste0("cell_", 1:ncol(dat)) rownames(dat) <- c("gene_1","gene_2", "gene_2") sce <- SingleCellExperiment::SingleCellExperiment(assays = S4Vectors::SimpleList(counts = dat)) scHOT <- scHOT_buildFromSCE(sce)
library(SingleCellExperiment) dat <- rbind(rnorm(50), rnorm(50), rnorm(50)) colnames(dat) <- paste0("cell_", 1:ncol(dat)) rownames(dat) <- c("gene_1","gene_2", "gene_2") sce <- SingleCellExperiment::SingleCellExperiment(assays = S4Vectors::SimpleList(counts = dat)) scHOT <- scHOT_buildFromSCE(sce)
this calculates the global higher order function and stores it in the output if these aren't found in the params slot then they need to be specified here
scHOT_calculateGlobalHigherOrderFunction( scHOT, higherOrderFunction = NULL, higherOrderFunctionType = NULL )
scHOT_calculateGlobalHigherOrderFunction( scHOT, higherOrderFunction = NULL, higherOrderFunctionType = NULL )
scHOT |
A scHOT object |
higherOrderFunction |
A function object indicating the higher order function |
higherOrderFunctionType |
is "weighted" or "unweighted", determines if there is a weighting argument in the higher order function |
Calculates the global higher order function
A scHOT object with scHOT_output$globalHigherOrderFunction in slot scHOT_output saved
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs) scHOT_spatial <- scHOT_setWeightMatrix(scHOT_spatial, positionColData = c("x","y"), positionType = "spatial", nrow.out = NULL, span = 0.05) scHOT_spatial <- scHOT_calculateGlobalHigherOrderFunction( scHOT_spatial, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted")
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs) scHOT_spatial <- scHOT_setWeightMatrix(scHOT_spatial, positionColData = c("x","y"), positionType = "spatial", nrow.out = NULL, span = 0.05) scHOT_spatial <- scHOT_calculateGlobalHigherOrderFunction( scHOT_spatial, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted")
Calculate and store the higherOrderSequence and higherOrderTestStatistic
scHOT_calculateHigherOrderTestStatistics( scHOT, higherOrderSummaryFunction = stats::sd, ... )
scHOT_calculateHigherOrderTestStatistics( scHOT, higherOrderSummaryFunction = stats::sd, ... )
scHOT |
A scHOT object |
higherOrderSummaryFunction |
A function which indicates how the higher order sequence is summarised, default is sd |
... |
parameters for higherOrderSummaryFunction |
scHOT A scHOT object with results stored in scHOT_output slot
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs) scHOT_spatial <- scHOT_setWeightMatrix(scHOT_spatial, positionColData = c("x","y"), positionType = "spatial", nrow.out = NULL, span = 0.05) scHOT_spatial <- scHOT_calculateGlobalHigherOrderFunction( scHOT_spatial, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted") scHOT_spatial <- scHOT_setPermutationScaffold(scHOT_spatial, numberPermutations = 100) scHOT_spatial <- scHOT_calculateHigherOrderTestStatistics( scHOT_spatial, higherOrderSummaryFunction = sd)
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs) scHOT_spatial <- scHOT_setWeightMatrix(scHOT_spatial, positionColData = c("x","y"), positionType = "spatial", nrow.out = NULL, span = 0.05) scHOT_spatial <- scHOT_calculateGlobalHigherOrderFunction( scHOT_spatial, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted") scHOT_spatial <- scHOT_setPermutationScaffold(scHOT_spatial, numberPermutations = 100) scHOT_spatial <- scHOT_calculateHigherOrderTestStatistics( scHOT_spatial, higherOrderSummaryFunction = sd)
Estimate p-values based on already run permutation tests
scHOT_estimatePvalues( scHOT, usenperm_estimate = FALSE, nperm_estimate = 10000, maxDist = 0.1, plot = FALSE, verbose = FALSE )
scHOT_estimatePvalues( scHOT, usenperm_estimate = FALSE, nperm_estimate = 10000, maxDist = 0.1, plot = FALSE, verbose = FALSE )
scHOT |
A scHOT object |
usenperm_estimate |
Logical (default FALSE) if number of neighbouring permutations should be used, or if difference of global higher order statistic should be used |
nperm_estimate |
Number of neighbouring permutations to use for p-value estimation |
maxDist |
max difference of global higher order statistic to use for p-value estimation (default 0.1) |
plot |
A logical input indicating whether the results are plotted |
verbose |
A logical input indicating whether the intermediate steps will be printed |
scHOT A scHOT object with results stored in scHOT_output slot
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs) scHOT_spatial <- scHOT_setWeightMatrix(scHOT_spatial, positionColData = c("x","y"), positionType = "spatial", nrow.out = NULL, span = 0.05) scHOT_spatial <- scHOT_calculateGlobalHigherOrderFunction( scHOT_spatial, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted") scHOT_spatial <- scHOT_setPermutationScaffold(scHOT_spatial, numberPermutations = 100) scHOT_spatial <- scHOT_calculateHigherOrderTestStatistics( scHOT_spatial, higherOrderSummaryFunction = sd) scHOT_spatial <- scHOT_performPermutationTest( scHOT_spatial, verbose = TRUE, parallel = FALSE) scHOT_spatial <- scHOT_estimatePvalues(scHOT_spatial)
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs) scHOT_spatial <- scHOT_setWeightMatrix(scHOT_spatial, positionColData = c("x","y"), positionType = "spatial", nrow.out = NULL, span = 0.05) scHOT_spatial <- scHOT_calculateGlobalHigherOrderFunction( scHOT_spatial, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted") scHOT_spatial <- scHOT_setPermutationScaffold(scHOT_spatial, numberPermutations = 100) scHOT_spatial <- scHOT_calculateHigherOrderTestStatistics( scHOT_spatial, higherOrderSummaryFunction = sd) scHOT_spatial <- scHOT_performPermutationTest( scHOT_spatial, verbose = TRUE, parallel = FALSE) scHOT_spatial <- scHOT_estimatePvalues(scHOT_spatial)
Setter functions for scHOT objects
scHOT_output(x) <- value
scHOT_output(x) <- value
x |
A scHOT object |
value |
The value the slot should take |
A scHOT object
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) scHOT_output(scHOT_spatial) <- data.frame()
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) scHOT_output(scHOT_spatial) <- data.frame()
Perform permutation test
scHOT_performPermutationTest( scHOT, verbose = FALSE, parallel = FALSE, BPPARAM = BiocParallel::SerialParam() )
scHOT_performPermutationTest( scHOT, verbose = FALSE, parallel = FALSE, BPPARAM = BiocParallel::SerialParam() )
scHOT |
A scHOT object |
verbose |
A logical input indicates whether the intermediate steps will be printed |
parallel |
A logical input indicates whether run the permutation test using multiple cores in parallel. |
BPPARAM |
A |
scHOT A scHOT object with results stored in scHOT_output slot
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs) scHOT_spatial <- scHOT_setWeightMatrix(scHOT_spatial, positionColData = c("x","y"), positionType = "spatial", nrow.out = NULL, span = 0.05) scHOT_spatial <- scHOT_calculateGlobalHigherOrderFunction( scHOT_spatial, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted") scHOT_spatial <- scHOT_setPermutationScaffold(scHOT_spatial, numberPermutations = 100) scHOT_spatial <- scHOT_calculateHigherOrderTestStatistics( scHOT_spatial, higherOrderSummaryFunction = sd) scHOT_spatial <- scHOT_performPermutationTest( scHOT_spatial, verbose = TRUE, parallel = FALSE)
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs) scHOT_spatial <- scHOT_setWeightMatrix(scHOT_spatial, positionColData = c("x","y"), positionType = "spatial", nrow.out = NULL, span = 0.05) scHOT_spatial <- scHOT_calculateGlobalHigherOrderFunction( scHOT_spatial, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted") scHOT_spatial <- scHOT_setPermutationScaffold(scHOT_spatial, numberPermutations = 100) scHOT_spatial <- scHOT_calculateHigherOrderTestStatistics( scHOT_spatial, higherOrderSummaryFunction = sd) scHOT_spatial <- scHOT_performPermutationTest( scHOT_spatial, verbose = TRUE, parallel = FALSE)
the scHOT_plotPermutationDistributions function plots the permutation test statistics as a diagnostic plot for estimating p-values
scHOT_plotPermutationDistributions(scHOT)
scHOT_plotPermutationDistributions(scHOT)
scHOT |
a scHOT object |
ggplot
graph of global higher order function and the
permutation scHOT test statistics. This should have a continuous pattern
to be reliably used for p-value estimation
Set permutation scaffold
scHOT_setPermutationScaffold( scHOT, numberPermutations = 1000, numberScaffold = 100, storePermutations = TRUE )
scHOT_setPermutationScaffold( scHOT, numberPermutations = 1000, numberScaffold = 100, storePermutations = TRUE )
scHOT |
A scHOT object |
numberPermutations |
The number of permutations, set as 1000 by default |
numberScaffold |
The number of scaffold, set as 100 by default, minimum 6. if you want all combinations to do permutations then set, numberScaffold much higher than the testingScaffold |
storePermutations |
a logical flag on whether Permutations should be stored, or discarded once used |
A scHOT object with storePermutations in slot scHOT_output saved
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs) scHOT_spatial <- scHOT_setWeightMatrix(scHOT_spatial, positionColData = c("x","y"), positionType = "spatial", nrow.out = NULL, span = 0.05) scHOT_spatial <- scHOT_calculateGlobalHigherOrderFunction( scHOT_spatial, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted") scHOT_spatial <- scHOT_setPermutationScaffold(scHOT_spatial, numberPermutations = 100)
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs) scHOT_spatial <- scHOT_setWeightMatrix(scHOT_spatial, positionColData = c("x","y"), positionType = "spatial", nrow.out = NULL, span = 0.05) scHOT_spatial <- scHOT_calculateGlobalHigherOrderFunction( scHOT_spatial, higherOrderFunction = weightedSpearman, higherOrderFunctionType = "weighted") scHOT_spatial <- scHOT_setPermutationScaffold(scHOT_spatial, numberPermutations = 100)
Create scHOT object from a SingleCellExperiment object
scHOT_setWeightMatrix( scHOT, weightMatrix = NULL, positionType = NULL, positionColData = NULL, nrow.out = NULL, averageAcrossTrajectoryTies = FALSE, ... )
scHOT_setWeightMatrix( scHOT, weightMatrix = NULL, positionType = NULL, positionColData = NULL, nrow.out = NULL, averageAcrossTrajectoryTies = FALSE, ... )
scHOT |
A scHOT object |
weightMatrix |
A matrix indicating the weight matrix for scHOT analysis, such as the output from 'trajectoryWeightMatrix' or 'spatialWeightMatrix'. If this is not NULL then other parameters are ignored. |
positionType |
A string indicating the position type, either "trajectory" or "spatial" |
positionColData |
Either trajectory or spatial information for each sample. If positionType is "trajectory" then positionColData should be a character or numeric indicating the subset of colData of the scHOT object. If positionType is "spatial" then positionColData should be a character or numeric vector indicating the subset of colData that give the full spatial coordinates. |
nrow.out |
The number of weightings to include for testing, a smaller value is faster for computation |
averageAcrossTrajectoryTies |
Logical indicating whether ties in the trajectory should be given the same local weights |
... |
parameters for function trajectoryWeightMatrix or spatialWeightMatrix |
A scHOT object with slot weightMatrix saved
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs) scHOT_spatial <- scHOT_setWeightMatrix(scHOT_spatial, positionColData = c("x","y"), positionType = "spatial", nrow.out = NULL, span = 0.05)
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- matrix(c("Arrb1", "Mtor", "Dnm1l", "Gucy1b3"), ncol = 2, byrow = TRUE) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") scHOT_spatial <- scHOT_addTestingScaffold(scHOT_spatial, pairs) scHOT_spatial <- scHOT_setWeightMatrix(scHOT_spatial, positionColData = c("x","y"), positionType = "spatial", nrow.out = NULL, span = 0.05)
Strip the scHOT output
scHOT_stripOutput(scHOT, force = TRUE, store = FALSE, file_name = NULL)
scHOT_stripOutput(scHOT, force = TRUE, store = FALSE, file_name = NULL)
scHOT |
A scHOT object |
force |
A logical indicates whther forcing stripping the scHOT output |
store |
A logical flag on whether the scHOT should be stored as .rds file |
file_name |
A string indicates the file name of the scHOT will be stored |
A scHOT object with scHOT_output striped
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) scHOT_spatial <- scHOT_stripOutput(scHOT_spatial)
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) scHOT_spatial <- scHOT_stripOutput(scHOT_spatial)
scHOT class
testingScaffold
A matrix with rows for each testing combination
weightMatrix
A matrix or dgCMatrix indicates the weight matrix
scHOT_output
A data.frame or DtatFrame to store output from scHOT
params
A list of parameters
positionType
A character indicates the type of the position, either trajectory or spatial
positionColData
A vector indicates column names of colData that stored the postion informaton
Create weight matrix for spatial data
spatialWeightMatrix(x, span = NULL)
spatialWeightMatrix(x, span = NULL)
x |
a matrix with rows corresponding to cells and columns corresponding to dimensions to calculate Euclidean distance |
span |
proportion of samples to include on either side, default is 13/(number of rows in 'x'), corresponding roughly to points within a diamond shape distance away |
A weighted matrix
spat_x <- rnorm(50) spat_y <- rnorm(50) spat_coord <- cbind(spat_x, spat_y) W <- spatialWeightMatrix(spat_coord)
spat_x <- rnorm(50) spat_y <- rnorm(50) spat_coord <- cbind(spat_x, spat_y) W <- spatialWeightMatrix(spat_coord)
Setter functions for scHOT objects
testingScaffold(x) <- value
testingScaffold(x) <- value
x |
A scHOT object |
value |
The value the slot should take |
A scHOT object
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- t(combn(rownames(sce_MOB_subset),2)) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") testingScaffold(scHOT_spatial) <- pairs
data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) pairs <- t(combn(rownames(sce_MOB_subset),2)) rownames(pairs) <- apply(pairs,1,paste0,collapse = "_") testingScaffold(scHOT_spatial) <- pairs
The thin function extracts the rows of a matrix evenly so that roughly n number of rows remain. Used for thinning down the weight matrix to speed up overall computation.
thin(W, n = 100)
thin(W, n = 100)
W |
matrix |
n |
rough number of rows to keep |
matrix
of thinned matrix keeping only roughly n rows.
W = trajectoryWeightMatrix(500) W_small = thin(W, n = 100)
W = trajectoryWeightMatrix(500) W_small = thin(W, n = 100)
Create weight matrix for trajectory data
trajectoryWeightMatrix(n, type = NULL, span = NULL)
trajectoryWeightMatrix(n, type = NULL, span = NULL)
n |
indicates the number of cels |
type |
Type of weight matrix, one of "triangular" (default), "block", and "harmonic" |
span |
proportion of samples to include on either side, default is 0.25 |
A weighted matrix
W <- trajectoryWeightMatrix(100) W <- trajectoryWeightMatrix(100, type = "triangular") W <- trajectoryWeightMatrix(100, type = "block") W <- trajectoryWeightMatrix(100, type = "harmonic")
W <- trajectoryWeightMatrix(100) W <- trajectoryWeightMatrix(100, type = "triangular") W <- trajectoryWeightMatrix(100, type = "block") W <- trajectoryWeightMatrix(100, type = "harmonic")
the weightedPearson function
weightedPearson(x, y, w = 1)
weightedPearson(x, y, w = 1)
x |
x and y are data vectors |
y |
x and y are data vectors |
w |
weight vector, values should be between 0 and 1 |
numeric
weighted correlation value between x and y
x = rnorm(100) y = rnorm(100) w = runif(100) weightedPearson(x,y,w)
x = rnorm(100) y = rnorm(100) w = runif(100) weightedPearson(x,y,w)
the weightedSpearman function
weightedSpearman(x, y, w = 1)
weightedSpearman(x, y, w = 1)
x |
x and y are data vectors |
y |
x and y are data vectors |
w |
weight vector, values should be between 0 and 1 |
numeric
weighted correlation value between x and y
x = rnorm(100) y = rnorm(100) w = runif(100) weightedSpearman(x,y,w)
x = rnorm(100) y = rnorm(100) w = runif(100) weightedSpearman(x,y,w)
the weightedVariance function
weightedVariance(x, y = NULL, w)
weightedVariance(x, y = NULL, w)
x |
x is a data vector |
y |
default to NULL, if given it is ignored |
w |
weight vector, values should be between 0 and 1 |
numeric
weighted variance value for x
x = rnorm(100) w = runif(100) weightedVariance(x,w = w)
x = rnorm(100) w = runif(100) weightedVariance(x,w = w)
the weightedZIKendall function calculates weighted Tau*, where Tau* is described in Pimentel et al (2015) doi:10.1016/j.spl.2014.09.002. This association measure is defined for zero-inflated, non-negative random variables.
weightedZIKendall(x, y, w = 1)
weightedZIKendall(x, y, w = 1)
x |
x and y are non-negative data vectors |
y |
x and y are non-negative data vectors |
w |
weight vector, values should be between 0 and 1 |
numeric
weighted Tau* association value between x and y
x = pmax(0,rnorm(100)) y = pmax(0,rnorm(100)) w = runif(100) weightedZIKendall(x,y,w)
x = pmax(0,rnorm(100)) y = pmax(0,rnorm(100)) w = runif(100) weightedZIKendall(x,y,w)
the weightedZISpearman function calculates weighted rho\*, where rho\* is described in Pimentel et al (2009). This association measure is defined for zero-inflated, non-negative random variables.
weightedZISpearman(x, y, w = 1)
weightedZISpearman(x, y, w = 1)
x |
x and y are non-negative data vectors |
y |
x and y are non-negative data vectors |
w |
weight vector, values should be between 0 and 1 |
numeric
weighted rho* association value between x and y
Pimentel, Ronald Silva, "Kendall's Tau and Spearman's Rho for Zero-Inflated Data" (2009). Dissertations. 721. https://scholarworks.wmich.edu/dissertations/721
x = pmax(0,rnorm(100)) y = pmax(0,rnorm(100)) w = runif(100) weightedZISpearman(x,y,w)
x = pmax(0,rnorm(100)) y = pmax(0,rnorm(100)) w = runif(100) weightedZISpearman(x,y,w)
Setter functions for scHOT objects
weightMatrix(x) <- value
weightMatrix(x) <- value
x |
A scHOT object |
value |
The value the slot should take |
A scHOT object
library(SingleCellExperiment) data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) W <- spatialWeightMatrix(colData(scHOT_spatial)[,slot(scHOT_spatial, "positionColData")]) weightMatrix(scHOT_spatial) <- W
library(SingleCellExperiment) data(MOB_subset) sce_MOB_subset <- MOB_subset$sce_MOB_subset scHOT_spatial <- scHOT_buildFromSCE(sce_MOB_subset, assayName = "logcounts", positionType = "spatial", positionColData = c("x", "y")) W <- spatialWeightMatrix(colData(scHOT_spatial)[,slot(scHOT_spatial, "positionColData")]) weightMatrix(scHOT_spatial) <- W