Title: | Differential Topology, Progression and Differentiation |
---|---|
Description: | This package encapsulate many functions to conduct a differential topology analysis. It focuses on analyzing an 'omic dataset with multiple conditions. While the package is mostly geared toward scRNASeq, it does not place any restriction on the actual input format. |
Authors: | Hector Roux de Bezieux [aut, cre] , Koen Van den Berge [aut, ctb], Kelly Street [aut, ctb] |
Maintainer: | Hector Roux de Bezieux <[email protected]> |
License: | MIT + file LICENSE |
Version: | 1.15.1 |
Built: | 2025-01-03 03:16:43 UTC |
Source: | https://github.com/bioc/condiments |
This creates a simulated reduced dimension dataset
create_differential_topology( n_cells = 200, noise = 0.15, shift = 10, unbalance_level = 0.9, speed = 1 )
create_differential_topology( n_cells = 200, noise = 0.15, shift = 10, unbalance_level = 0.9, speed = 1 )
n_cells |
The number of cells in the dataset. |
noise |
Amount of noise. Between 0 and 1. |
shift |
How much should the top lineage shift in condition B. |
unbalance_level |
How much should the bottom lineage be unbalanced toward condition A. |
speed |
How fast the cells from condition B should differentiate |
A list with two components
sd
: An n_cells
by 4
dataframe that contains the
reduced dimensions coordinates, lineage assignment (1 or 2) and condition
assignment (A or B) for each cell.
mst
: a data.frame that contains the skeleton of the trajectories
sd <- create_differential_topology()
sd <- create_differential_topology()
Test whether or not the cell repartition between lineages is independent of the conditions
differentiationTest(...)
differentiationTest(...)
... |
See the |
See the fateSelectionTest
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) differentiationTest(sds, condition)
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) differentiationTest(sds, condition)
Test whether or not the cell repartition between lineages is independent of the conditions
fateSelectionTest(cellWeights, ...) ## S4 method for signature 'matrix' fateSelectionTest( cellWeights, conditions, global = TRUE, pairwise = FALSE, method = c("Classifier", "mmd", "wasserstein_permutation"), classifier_method = "rf", thresh = 0.01, args_classifier = list(), args_mmd = list(), args_wass = list() ) ## S4 method for signature 'SlingshotDataSet' fateSelectionTest( cellWeights, conditions, global = TRUE, pairwise = FALSE, method = c("Classifier", "mmd", "wasserstein_permutation"), classifier_method = "rf", thresh = 0.01, args_classifier = list(), args_mmd = list(), args_wass = list() ) ## S4 method for signature 'SingleCellExperiment' fateSelectionTest( cellWeights, conditions, global = TRUE, pairwise = FALSE, method = c("Classifier", "mmd", "wasserstein_permutation"), classifier_method = "rf", thresh = 0.01, args_classifier = list(), args_mmd = list(), args_wass = list() ) ## S4 method for signature 'PseudotimeOrdering' fateSelectionTest( cellWeights, conditions, global = TRUE, pairwise = FALSE, method = c("Classifier", "mmd", "wasserstein_permutation"), classifier_method = "rf", thresh = 0.01, args_classifier = list(), args_mmd = list(), args_wass = list() )
fateSelectionTest(cellWeights, ...) ## S4 method for signature 'matrix' fateSelectionTest( cellWeights, conditions, global = TRUE, pairwise = FALSE, method = c("Classifier", "mmd", "wasserstein_permutation"), classifier_method = "rf", thresh = 0.01, args_classifier = list(), args_mmd = list(), args_wass = list() ) ## S4 method for signature 'SlingshotDataSet' fateSelectionTest( cellWeights, conditions, global = TRUE, pairwise = FALSE, method = c("Classifier", "mmd", "wasserstein_permutation"), classifier_method = "rf", thresh = 0.01, args_classifier = list(), args_mmd = list(), args_wass = list() ) ## S4 method for signature 'SingleCellExperiment' fateSelectionTest( cellWeights, conditions, global = TRUE, pairwise = FALSE, method = c("Classifier", "mmd", "wasserstein_permutation"), classifier_method = "rf", thresh = 0.01, args_classifier = list(), args_mmd = list(), args_wass = list() ) ## S4 method for signature 'PseudotimeOrdering' fateSelectionTest( cellWeights, conditions, global = TRUE, pairwise = FALSE, method = c("Classifier", "mmd", "wasserstein_permutation"), classifier_method = "rf", thresh = 0.01, args_classifier = list(), args_mmd = list(), args_wass = list() )
cellWeights |
Can be either a |
... |
parameters including: |
conditions |
Either the vector of conditions, or a character indicating which column of the metadata contains this vector |
global |
If TRUE, test for all pairs simultaneously. |
pairwise |
If TRUE, test for all pairs independently. |
method |
One of "Classifier" or "mmd". |
classifier_method |
The method used in the classifier test. Default to "rf", i.e random forest. |
thresh |
The threshold for the classifier test. See details. Default to .05. |
args_classifier |
arguments passed to the classifier test. See |
args_mmd |
arguments passed to the mmd test. See |
args_wass |
arguments passed to the wasserstein permutation test. See
|
A data frame with 3 columns:
*pair* for individual pairs, the lineages numbers. For global,
"All"
.
*p.value* the pvalue for the test at the global or pair level
*statistic* The classifier accuracy
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) fateSelectionTest(sds, condition)
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) fateSelectionTest(sds, condition)
Test whether or not the cell repartition between lineages is independent of the conditions, with samples not being confounded by conditions
fateSelectionTest_multipleSamples(cellWeights, ...) ## S4 method for signature 'matrix' fateSelectionTest_multipleSamples(cellWeights, conditions, Samples, ...) ## S4 method for signature 'SlingshotDataSet' fateSelectionTest_multipleSamples(cellWeights, conditions, Samples, ...) ## S4 method for signature 'SingleCellExperiment' fateSelectionTest_multipleSamples(cellWeights, conditions, Samples, ...) ## S4 method for signature 'PseudotimeOrdering' fateSelectionTest_multipleSamples(cellWeights, conditions, Samples, ...)
fateSelectionTest_multipleSamples(cellWeights, ...) ## S4 method for signature 'matrix' fateSelectionTest_multipleSamples(cellWeights, conditions, Samples, ...) ## S4 method for signature 'SlingshotDataSet' fateSelectionTest_multipleSamples(cellWeights, conditions, Samples, ...) ## S4 method for signature 'SingleCellExperiment' fateSelectionTest_multipleSamples(cellWeights, conditions, Samples, ...) ## S4 method for signature 'PseudotimeOrdering' fateSelectionTest_multipleSamples(cellWeights, conditions, Samples, ...)
cellWeights |
Can be either a |
... |
Other arguments passed to |
conditions |
Either the vector of conditions, or a character indicating which column of the metadata contains this vector. |
Samples |
A vector assigning each cell to a sample. Samples must be shared across all conditions. |
The same object has the fateSelectionTest
with one more column per sample.
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) samples <- sample(1:2, 140, replace = TRUE) fateSelectionTest_multipleSamples(cellWeights = sds, conditions = condition, Samples = samples)
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) samples <- sample(1:2, 140, replace = TRUE) fateSelectionTest_multipleSamples(cellWeights = sds, conditions = condition, Samples = samples)
Compute a imbalance score to show whether nearby cells have the same condition of not
imbalance_score(Object, ...) ## S4 method for signature 'matrix' imbalance_score(Object, conditions, k = 10, smooth = 10) ## S4 method for signature 'SingleCellExperiment' imbalance_score(Object, dimred = 1, conditions, k = 10, smooth = 10)
imbalance_score(Object, ...) ## S4 method for signature 'matrix' imbalance_score(Object, conditions, k = 10, smooth = 10) ## S4 method for signature 'SingleCellExperiment' imbalance_score(Object, dimred = 1, conditions, k = 10, smooth = 10)
Object |
A |
... |
parameters including: |
conditions |
Either the vector of conditions, or a character indicating which column of the metadata contains this vector |
k |
The number of neighbors to consider when computing the score. Default to 10. |
smooth |
The smoothing parameter. Default to k. Lower values mean that we smooth more. |
dimred |
A string or integer scalar indicating the reduced dimension
result in |
Either a list with the scaled_scores
and the scores
for
each cell, if input is a matrix, or the SingleCellExperiment
object, wit this list in the colData
.
data("toy_dataset") scores <- imbalance_score(as.matrix(toy_dataset$sd[,1:2]), toy_dataset$sd$conditions, k = 4) cols <- as.numeric(cut(scores$scaled_scores, 8)) plot(as.matrix(toy_dataset$sd[, 1:2]), xlab = "Dim1", ylab = "Dim2", pch = 16, col = RColorBrewer::brewer.pal(8, "Blues")[cols])
data("toy_dataset") scores <- imbalance_score(as.matrix(toy_dataset$sd[,1:2]), toy_dataset$sd$conditions, k = 4) cols <- as.numeric(cut(scores$scaled_scores, 8)) plot(as.matrix(toy_dataset$sd[, 1:2]), xlab = "Dim1", ylab = "Dim2", pch = 16, col = RColorBrewer::brewer.pal(8, "Blues")[cols])
If trajectory inference needs to be manually done condition per condition, this allows to merge them into one. It requires manual mapping of lineages.
merge_sds(..., mapping, condition_id = seq_len(ncol(mapping)), scale = FALSE)
merge_sds(..., mapping, condition_id = seq_len(ncol(mapping)), scale = FALSE)
... |
Slingshot datasets |
mapping |
a matrix, one column per dataset. Each row amounts to lineage mapping. |
condition_id |
A vector of condition for each condition. Default to integer values in order of appearance |
scale |
If TRUE (default), lineages that are mapped are scaled to have the same length. |
The function assumes that each lineage in a dataset maps to exactly one lineage in another dataset. Anything else needs to be done manually.
A modified slingshot dataset that can be used for downstream steps.
data(list = 'slingshotExample', package = "slingshot") if (!"cl" %in% ls()) { rd <- slingshotExample$rd cl <- slingshotExample$cl } sds <- slingshot::slingshot(rd, cl) merge_sds(sds, sds, mapping = matrix(c(1, 2, 1, 2), nrow = 2))
data(list = 'slingshotExample', package = "slingshot") if (!"cl" %in% ls()) { rd <- slingshotExample$rd cl <- slingshotExample$cl } sds <- slingshot::slingshot(rd, cl) merge_sds(sds, sds, mapping = matrix(c(1, 2, 1, 2), nrow = 2))
Return the number of lineages for a slingshot object
nLineages(sds, ...) ## S4 method for signature 'SingleCellExperiment' nLineages(sds) ## S4 method for signature 'SlingshotDataSet' nLineages(sds) ## S4 method for signature 'PseudotimeOrdering' nLineages(sds)
nLineages(sds, ...) ## S4 method for signature 'SingleCellExperiment' nLineages(sds) ## S4 method for signature 'SlingshotDataSet' nLineages(sds) ## S4 method for signature 'PseudotimeOrdering' nLineages(sds)
sds |
A slingshot object already run on the full dataset. Can be either a
|
... |
parameters including: |
The number of lineages in the slingshot object
data(list = 'slingshotExample', package = "slingshot") if (!"cl" %in% ls()) { rd <- slingshotExample$rd cl <- slingshotExample$cl } sds <- slingshot::slingshot(rd, cl) nLineages(sds)
data(list = 'slingshotExample', package = "slingshot") if (!"cl" %in% ls()) { rd <- slingshotExample$rd cl <- slingshotExample$cl } sds <- slingshot::slingshot(rd, cl) nLineages(sds)
Test whether or not the pseudotime distribution are identical within lineages between conditions
progressionTest(pseudotime, ...) ## S4 method for signature 'matrix' progressionTest( pseudotime, cellWeights, conditions, global = TRUE, lineages = FALSE, method = ifelse(dplyr::n_distinct(conditions) == 2, "KS", "Classifier"), thresh = ifelse(method == "Classifer", 0.05, 0.01), args_mmd = list(), args_classifier = list(), args_wass = list(), rep = 10000, distinct_samples = NULL ) ## S4 method for signature 'SlingshotDataSet' progressionTest( pseudotime, conditions, global = TRUE, lineages = FALSE, method = ifelse(dplyr::n_distinct(conditions) == 2, "KS", "Classifier"), thresh = ifelse(method == "Classifer", 0.05, 0.01), args_mmd = list(), args_classifier = list(), args_wass = list(), rep = 10000, distinct_samples = NULL ) ## S4 method for signature 'SingleCellExperiment' progressionTest( pseudotime, conditions, global = TRUE, lineages = FALSE, method = ifelse(dplyr::n_distinct(conditions) == 2, "KS", "Classifier"), thresh = ifelse(method == "Classifer", 0.05, 0.01), args_mmd = list(), args_classifier = list(), args_wass = list(), rep = 10000, distinct_samples = NULL ) ## S4 method for signature 'PseudotimeOrdering' progressionTest( pseudotime, conditions, global = TRUE, lineages = FALSE, method = ifelse(dplyr::n_distinct(conditions) == 2, "KS", "Classifier"), thresh = ifelse(method == "Classifer", 0.05, 0.01), args_mmd = list(), args_classifier = list(), args_wass = list(), rep = 10000, distinct_samples = NULL )
progressionTest(pseudotime, ...) ## S4 method for signature 'matrix' progressionTest( pseudotime, cellWeights, conditions, global = TRUE, lineages = FALSE, method = ifelse(dplyr::n_distinct(conditions) == 2, "KS", "Classifier"), thresh = ifelse(method == "Classifer", 0.05, 0.01), args_mmd = list(), args_classifier = list(), args_wass = list(), rep = 10000, distinct_samples = NULL ) ## S4 method for signature 'SlingshotDataSet' progressionTest( pseudotime, conditions, global = TRUE, lineages = FALSE, method = ifelse(dplyr::n_distinct(conditions) == 2, "KS", "Classifier"), thresh = ifelse(method == "Classifer", 0.05, 0.01), args_mmd = list(), args_classifier = list(), args_wass = list(), rep = 10000, distinct_samples = NULL ) ## S4 method for signature 'SingleCellExperiment' progressionTest( pseudotime, conditions, global = TRUE, lineages = FALSE, method = ifelse(dplyr::n_distinct(conditions) == 2, "KS", "Classifier"), thresh = ifelse(method == "Classifer", 0.05, 0.01), args_mmd = list(), args_classifier = list(), args_wass = list(), rep = 10000, distinct_samples = NULL ) ## S4 method for signature 'PseudotimeOrdering' progressionTest( pseudotime, conditions, global = TRUE, lineages = FALSE, method = ifelse(dplyr::n_distinct(conditions) == 2, "KS", "Classifier"), thresh = ifelse(method == "Classifer", 0.05, 0.01), args_mmd = list(), args_classifier = list(), args_wass = list(), rep = 10000, distinct_samples = NULL )
pseudotime |
Can be either a |
... |
parameters including: |
cellWeights |
If |
conditions |
Either the vector of conditions, or a character indicating which column of the metadata contains this vector. |
global |
If TRUE, test for all lineages simultaneously. |
lineages |
If TRUE, test for all lineages independently. |
method |
One of "KS", "Classifier", "mmd", "wasserstein_permutation" or "Permutation" for a permutation. See details. Default to KS if there is two conditions and to "Classifier" otherwise. |
thresh |
The threshold for the KS test or Classifier test.
Ignored if |
args_mmd |
arguments passed to the mmd test. See |
args_classifier |
arguments passed to the classifier test. See |
args_wass |
arguments passed to the wasserstein permutation test. See
|
rep |
Number of permutations to run. Only for methods "Permutations" and
"wasserstein_permutation". Default to |
distinct_samples |
The samples to which each cell belong to. Only use
with method |
For every lineage, we compare the pseudotimes of the cells from either conditions, using the lineage weights as observations weights.
If method = "KS"
, this uses the updated KS test,
see ks_test
for details.
If method = "Classifier"
, this uses a classifier to assess if
that classifier can do better than chance on the conditions
If method = "Permutation"
, the difference of weighted mean
pseudotime between condition is computed, and a p-value is found by
permuting the condition labels.
If method = "mmd"
, this uses the mean maximum discrepancies
statistics.
The p-value at the global level can be computed in two ways. method is "KS"
or
"Permutation"
, then the p-values are computed using stouffer's
z-score method, with the lineages weights acting as weights. Otherwise,
the test works on multivariate data and is applied on all pseudotime values.
A data frame with 3 columns:
lineage for individual lineages, the lineage number. For global,
"All"
.
p.value the pvalue for the test at the global or lineage level
statistic for individual lineages, either the modified KS statistic
if method = "KS"
, or the weighted difference of means, if
method = "Permutation"
. For the global test, the combined Z-score.
Stouffer, S.A.; Suchman, E.A.; DeVinney, L.C.; Star, S.A.; Williams, R.M. Jr. (1949). The American Soldier, Vol.1: Adjustment during Army Life. Princeton University Press, Princeton.
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) progressionTest(sds, condition)
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) progressionTest(sds, condition)
Test whether or not the pseudotime distribution are identical within lineages between conditions, with samples not being confounded by conditions
progressionTest_multipleSamples(pseudotime, ...) ## S4 method for signature 'matrix' progressionTest_multipleSamples( pseudotime, cellWeights, conditions, Samples, ... ) ## S4 method for signature 'SlingshotDataSet' progressionTest_multipleSamples(pseudotime, conditions, Samples, ...) ## S4 method for signature 'SingleCellExperiment' progressionTest_multipleSamples(pseudotime, conditions, Samples, ...) ## S4 method for signature 'PseudotimeOrdering' progressionTest_multipleSamples(pseudotime, conditions, Samples, ...)
progressionTest_multipleSamples(pseudotime, ...) ## S4 method for signature 'matrix' progressionTest_multipleSamples( pseudotime, cellWeights, conditions, Samples, ... ) ## S4 method for signature 'SlingshotDataSet' progressionTest_multipleSamples(pseudotime, conditions, Samples, ...) ## S4 method for signature 'SingleCellExperiment' progressionTest_multipleSamples(pseudotime, conditions, Samples, ...) ## S4 method for signature 'PseudotimeOrdering' progressionTest_multipleSamples(pseudotime, conditions, Samples, ...)
pseudotime |
Can be either a |
... |
Other arguments passed to |
cellWeights |
If 'pseudotime' is a matrix of pseudotime values, this represent the cell weights for each lineage. Ignored if 'pseudotime' is not a matrix. |
conditions |
Either the vector of conditions, or a character indicating which column of the metadata contains this vector. |
Samples |
A vector assigning each cell to a sample. Samples must be shared across all conditions. |
The same object has the progressionTest
with one more column per sample.
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) samples <- sample(1:2, 140, replace = TRUE) progressionTest_multipleSamples(pseudotime = sds, conditions = condition, Samples = samples)
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) samples <- sample(1:2, 140, replace = TRUE) progressionTest_multipleSamples(pseudotime = sds, conditions = condition, Samples = samples)
Based on an original slingshot object, refit one trajectory per condition, using the same skeleton.
slingshot_conditions(sds, ...) ## S4 method for signature 'SlingshotDataSet' slingshot_conditions( sds, conditions, approx_points = 100, adjust_skeleton = TRUE, verbose = TRUE, ... ) ## S4 method for signature 'SingleCellExperiment' slingshot_conditions( sds, conditions, approx_points = 100, adjust_skeleton = TRUE, verbose = TRUE, ... ) ## S4 method for signature 'PseudotimeOrdering' slingshot_conditions( sds, conditions, approx_points = 100, adjust_skeleton = TRUE, verbose = TRUE, ... )
slingshot_conditions(sds, ...) ## S4 method for signature 'SlingshotDataSet' slingshot_conditions( sds, conditions, approx_points = 100, adjust_skeleton = TRUE, verbose = TRUE, ... ) ## S4 method for signature 'SingleCellExperiment' slingshot_conditions( sds, conditions, approx_points = 100, adjust_skeleton = TRUE, verbose = TRUE, ... ) ## S4 method for signature 'PseudotimeOrdering' slingshot_conditions( sds, conditions, approx_points = 100, adjust_skeleton = TRUE, verbose = TRUE, ... )
sds |
A slingshot object already run on the full dataset. Can be either a
|
... |
Other arguments passed to |
conditions |
Either the vector of conditions, or a character indicating which column of the metadata contains this vector. |
approx_points |
Passed to |
adjust_skeleton |
Boolean, default to 'TRUE'. Whether to recompute the locations of the nodes after fitting per conditions. |
verbose |
Boolean, default to 'TRUE'. Control whether messages are printed. |
A list of SlingshotDataSet
, one per condition.
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) sdss <- slingshot_conditions(sds, condition)
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) sdss <- slingshot_conditions(sds, condition)
Test whether or not slingshot should be fitted independently for different conditions or not.
topologyTest(sds, ...) ## S4 method for signature 'SlingshotDataSet' topologyTest( sds, conditions, rep = 100, threshs = 0.01, methods = ifelse(dplyr::n_distinct(conditions) == 2, "KS_mean", "Classifier"), parallel = FALSE, BPPARAM = BiocParallel::bpparam(), args_mmd = list(), args_classifier = list(), args_wass = list(), nmax = nrow(slingshot::slingPseudotime(sds)), distinct_samples = NULL ) ## S4 method for signature 'SingleCellExperiment' topologyTest( sds, conditions, rep = 100, threshs = 0.01, methods = ifelse(dplyr::n_distinct(conditions) == 2, "KS_mean", "Classifier"), parallel = FALSE, BPPARAM = BiocParallel::bpparam(), args_mmd = list(), args_classifier = list(), args_wass = list(), nmax = ncol(sds), distinct_samples = NULL ) ## S4 method for signature 'PseudotimeOrdering' topologyTest( sds, conditions, rep = 100, threshs = 0.01, methods = ifelse(dplyr::n_distinct(conditions) == 2, "KS_mean", "Classifier"), parallel = FALSE, BPPARAM = BiocParallel::bpparam(), args_mmd = list(), args_classifier = list(), args_wass = list(), nmax = nrow(slingshot::slingPseudotime(sds)), distinct_samples = NULL )
topologyTest(sds, ...) ## S4 method for signature 'SlingshotDataSet' topologyTest( sds, conditions, rep = 100, threshs = 0.01, methods = ifelse(dplyr::n_distinct(conditions) == 2, "KS_mean", "Classifier"), parallel = FALSE, BPPARAM = BiocParallel::bpparam(), args_mmd = list(), args_classifier = list(), args_wass = list(), nmax = nrow(slingshot::slingPseudotime(sds)), distinct_samples = NULL ) ## S4 method for signature 'SingleCellExperiment' topologyTest( sds, conditions, rep = 100, threshs = 0.01, methods = ifelse(dplyr::n_distinct(conditions) == 2, "KS_mean", "Classifier"), parallel = FALSE, BPPARAM = BiocParallel::bpparam(), args_mmd = list(), args_classifier = list(), args_wass = list(), nmax = ncol(sds), distinct_samples = NULL ) ## S4 method for signature 'PseudotimeOrdering' topologyTest( sds, conditions, rep = 100, threshs = 0.01, methods = ifelse(dplyr::n_distinct(conditions) == 2, "KS_mean", "Classifier"), parallel = FALSE, BPPARAM = BiocParallel::bpparam(), args_mmd = list(), args_classifier = list(), args_wass = list(), nmax = nrow(slingshot::slingPseudotime(sds)), distinct_samples = NULL )
sds |
A slingshot object already run on the full dataset. Can be either a
|
... |
parameters including: |
conditions |
Either the vector of conditions, or a character indicating which column of the metadata contains this vector. |
rep |
How many permutations to run. Default to 50. |
threshs |
the threshold(s) for the KS test or classifier test. Default to .01
See |
methods |
The method(s) to use to test. Must be among 'KS_mean', 'Classifier', "KS_all', "mmd' and 'wasserstein_permutation'. See details. |
parallel |
Logical, defaults to FALSE. Set to TRUE if you want to parallellize the fitting. |
BPPARAM |
object of class |
args_mmd |
arguments passed to the mmd test. See |
args_classifier |
arguments passed to the classifier test. See |
args_wass |
arguments passed to the wasserstein permutation test. See
|
nmax |
How many samples to use to compute the mmd test. See details. |
distinct_samples |
The samples to which each cell belong to. Only use
with method 'distinct'. See ' |
If there is only two conditions, default to 'KS_mean'. Otherwise, uses a classifier.
More than one method can be specified at once, which avoids running slingshot on the permutations more than once (as it is the slowest part).
For the 'mmd_test', if 'null=unbiased', it is recommand to set 'nmax=2000' or something of that order of magnitude to avoid overflowing the memory.
A list containing the following components:
*method* The method used to test
*thresh* The threshold (if relevant)
*statistic* the value of the test statistic.
*p.value* the p-value of the test.
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::getLineages(rd, cl) topologyTest(sds, condition, rep = 10)
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::getLineages(rd, cl) topologyTest(sds, condition, rep = 10)
Test whether or not slingshot should be fitted independently for different conditions or not, per sample, with samples not being confounded by conditions.
topologyTest_multipleSamples(sds, ...) ## S4 method for signature 'SlingshotDataSet' topologyTest_multipleSamples(sds, conditions, Samples, ...) ## S4 method for signature 'SingleCellExperiment' topologyTest_multipleSamples(sds, conditions, Samples, ...) ## S4 method for signature 'PseudotimeOrdering' topologyTest_multipleSamples(sds, conditions, Samples, ...)
topologyTest_multipleSamples(sds, ...) ## S4 method for signature 'SlingshotDataSet' topologyTest_multipleSamples(sds, conditions, Samples, ...) ## S4 method for signature 'SingleCellExperiment' topologyTest_multipleSamples(sds, conditions, Samples, ...) ## S4 method for signature 'PseudotimeOrdering' topologyTest_multipleSamples(sds, conditions, Samples, ...)
sds |
A slingshot object already run on the full dataset. Can be either a
|
... |
Other arguments passed to |
conditions |
Either the vector of conditions, or a character indicating which column of the metadata contains this vector. |
Samples |
A vector assigning each cell to a sample. Samples must be shared across all conditions. |
The same object has the topologyTest
with one more column per sample.
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) samples <- sample(1:2, 140, replace = TRUE) topologyTest_multipleSamples(sds = sds, conditions = condition, Samples = samples, rep = 10)
data('slingshotExample', package = "slingshot") rd <- slingshotExample$rd cl <- slingshotExample$cl condition <- factor(rep(c('A','B'), length.out = nrow(rd))) condition[110:139] <- 'A' sds <- slingshot::slingshot(rd, cl) samples <- sample(1:2, 140, replace = TRUE) topologyTest_multipleSamples(sds = sds, conditions = condition, Samples = samples, rep = 10)
This example has been created using the 'create_differential_topology' function.
data(toy_dataset)
data(toy_dataset)
A list with two dataframes
*sd* A dataframe containing, for 1000 cells, the dimensions in two coordinates, and cluster, lineage and condition assignment.
mst
: a data.frame that contains the skeleton of the trajectories
The following code reproduces the object
set.seed(21)
library(condiments)
data <- create_differential_topology(n_cells = 1000, shift = 0)
data$sd$Dim2 <- data$sd$Dim2 * 5
data$mst$Dim2 <- data$mst$Dim2 * 5
data$sd$cl <- kmeans(as.matrix(data$sd[, 1:2]), 8)$cluster
data$sd$cl <- as.character(data$sd$cl)
Most trajectory inference methods do not perform soft assignment but instead assign cells to all possible lineages before a branching point, and then to one or another. This function re-creates a weight matrix from those matrices of pseudotime
weights_from_pst(pseudotime, ...) ## S4 method for signature 'matrix' weights_from_pst(pseudotime) ## S4 method for signature 'data.frame' weights_from_pst(pseudotime)
weights_from_pst(pseudotime, ...) ## S4 method for signature 'matrix' weights_from_pst(pseudotime) ## S4 method for signature 'data.frame' weights_from_pst(pseudotime)
pseudotime |
A matrix or data.frame of \[ncells\] by \[nCurves\]. |
... |
Other parameters including: |
A object of the same type and dimensions as the original object, with the weights for each curve and cell.
data(list = 'slingshotExample', package = "slingshot") if (!"cl" %in% ls()) { rd <- slingshotExample$rd cl <- slingshotExample$cl } sds <- slingshot::slingshot(rd, cl) weights_from_pst(slingshot::slingPseudotime(sds))
data(list = 'slingshotExample', package = "slingshot") if (!"cl" %in% ls()) { rd <- slingshotExample$rd cl <- slingshotExample$cl } sds <- slingshot::slingshot(rd, cl) weights_from_pst(slingshot::slingPseudotime(sds))