The package can be installed from bioconductor
if (!require("BiocManager", quietly = TRUE))
install.packages("BiocManager")
BiocManager::install("scDDboost")
Issue can be reported at “https://github.com/wiscstatman/scDDboost/issues”
scDDboost scores evidence of a gene being differentially distributed(DD) across two conditions for single cell RNA-seq data. Higher resolution brings several chanllenges for analyzing the data, specifically, the distribution of gene expression tends to have high prevalence of zero and multi-modes. To account for those characteristics and utilizing some biological intuition, we view the expression values sampled from a pool of cells mixed by distinct cellular subtypes blind to condition label. Consequently, the distributional change can be fully determined by the the change of subtype proportions. One tricky part is that not any change of proportions will lead to a distributional change. Given that some genes could be equivalent expressed across several subtypes, even the individual subytpe proportion may differ between conditions but as long as the aggregated proportions over those subtypes remain the same between conditions, it will not introduce different distribution. For example
Proportions of subtypes 1 and 2 changed between the 2 conditions. The gene is not DD if subtype 1 and 2 have the same expression level
For subtype 1 and 2 have different expression level, there is different distribution
pdd
is the core function developed to quantify the
posterior probabilities of DD for input genes.
Let’s look at an example,
suppressMessages(library(scDDboost))
Next, we load the toy simulated example a object that we will use for identifying and classifying DD genes.
data(sim_dat)
Verify that this object is a member of the SingleCellExperiment class and that it contains 200
cells and 1000 genes. The colData slot (which contains a dataframe of metadata for the
cells) should have a column that contains the biological condition or grouping of interest. In
this example data, that variable is the condition
variable. Note that the input gene set needs
to be a matrix of normalized counts.
We run the function pdd
data_counts <- SummarizedExperiment::assays(sim_dat)$counts
conditions <- SummarizedExperiment::colData(sim_dat)$conditions
rownames(data_counts) <- seq_len(1000)
##here we use 2 cores to compute the distance matrix
bp <- BiocParallel::MulticoreParam(2)
D_c <- calD(data_counts,bp)
ProbDD <- pdd(data = data_counts,cd = conditions, bp = bp, D = D_c)
There are 4 input parameters needed to be specified by user, the dataset, the condition label, number of cpu cores used for computation and a distance matrix of cells. Other input parameters have default settings.
We provide a default method of getting the distance matrix, archived by calD
, in general pdd
accept all valid distance matrix. User can also input a cluster label rather than distance matrix for the argument D
, but the random distancing mechanism which relies on distance matrix will be disabled and random
should be set to false.
For the number of sutypes, we provide a default function detK
, which consider the smallest number of sutypes such that the ratio of difference within cluster between difference between clusters become smaller than a threshold (default setting is 1).
If user have other ways to determine \(K\), \(K\) should be specified in pdd
.
## determine the number of subtypes
K <- detK(D_c)
If we set threshold to be 5% then we have estimated DD genes
EDD <- which(ProbDD > 0.95)
Notice that, pdd is actually local false discovery rate, this is a conservative estimation of DD genes. We could gain further power, let index gene by \(g = 1,2,...,G\) and let \(p_g = P(DD_g | \text{data})\), \(p_{(1)},...,p_{(G)}\) be ranked local false discovery rate from small to large. To control the false discovery rate at 5%, our positive set is those genes with the \(s^*\) smallest lFDR, where \[s^* = \text{argmax}_s\{s,\frac{\Sigma_{i = 1}^s p_{(i)}}{s} \leq 0.05\}\]
EDD <- getDD(ProbDD,0.05)
Function getDD
extracts the estimated DD genes using the above transformation.
sessionInfo()
## R version 4.3.0 RC (2023-04-13 r84269)
## Platform: x86_64-pc-linux-gnu (64-bit)
## Running under: Ubuntu 22.04.2 LTS
##
## Matrix products: default
## BLAS: /home/biocbuild/bbs-3.17-bioc/R/lib/libRblas.so
## LAPACK: /usr/lib/x86_64-linux-gnu/lapack/liblapack.so.3.10.0
##
## locale:
## [1] LC_CTYPE=en_US.UTF-8 LC_NUMERIC=C
## [3] LC_TIME=en_GB LC_COLLATE=C
## [5] LC_MONETARY=en_US.UTF-8 LC_MESSAGES=en_US.UTF-8
## [7] LC_PAPER=en_US.UTF-8 LC_NAME=C
## [9] LC_ADDRESS=C LC_TELEPHONE=C
## [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C
##
## time zone: America/New_York
## tzcode source: system (glibc)
##
## attached base packages:
## [1] stats graphics grDevices utils datasets methods base
##
## other attached packages:
## [1] scDDboost_1.2.0 ggplot2_3.4.2 BiocStyle_2.28.0
##
## loaded via a namespace (and not attached):
## [1] SummarizedExperiment_1.30.0 gtable_0.3.3
## [3] xfun_0.39 bslib_0.4.2
## [5] caTools_1.18.2 Biobase_2.60.0
## [7] lattice_0.21-8 vctrs_0.6.2
## [9] tools_4.3.0 bitops_1.0-7
## [11] generics_0.1.3 stats4_4.3.0
## [13] parallel_4.3.0 tibble_3.2.1
## [15] fansi_1.0.4 cluster_2.1.4
## [17] highr_0.10 pkgconfig_2.0.3
## [19] blockmodeling_1.1.4 KernSmooth_2.23-20
## [21] Matrix_1.5-4 EBSeq_1.40.0
## [23] desc_1.4.2 S4Vectors_0.38.0
## [25] lifecycle_1.0.3 GenomeInfoDbData_1.2.10
## [27] compiler_4.3.0 farver_2.1.1
## [29] brio_1.1.3 gplots_3.1.3
## [31] munsell_0.5.0 codetools_0.2-19
## [33] GenomeInfoDb_1.36.0 htmltools_0.5.5
## [35] sass_0.4.5 RCurl_1.98-1.12
## [37] yaml_2.3.7 pillar_1.9.0
## [39] jquerylib_0.1.4 BiocParallel_1.34.0
## [41] SingleCellExperiment_1.22.0 cachem_1.0.7
## [43] DelayedArray_0.26.0 magick_2.7.4
## [45] mclust_6.0.0 gtools_3.9.4
## [47] tidyselect_1.2.0 digest_0.6.31
## [49] dplyr_1.1.2 bookdown_0.33
## [51] labeling_0.4.2 rprojroot_2.0.3
## [53] fastmap_1.1.1 grid_4.3.0
## [55] colorspace_2.1-0 cli_3.6.1
## [57] magrittr_2.0.3 utf8_1.2.3
## [59] withr_2.5.0 scales_1.2.1
## [61] rmarkdown_2.21 XVector_0.40.0
## [63] matrixStats_0.63.0 RcppEigen_0.3.3.9.3
## [65] evaluate_0.20 knitr_1.42
## [67] GenomicRanges_1.52.0 IRanges_2.34.0
## [69] testthat_3.1.7 Oscope_1.30.0
## [71] rlang_1.1.0 Rcpp_1.0.10
## [73] glue_1.6.2 BiocManager_1.30.20
## [75] BiocGenerics_0.46.0 pkgload_1.3.2
## [77] jsonlite_1.8.4 R6_2.5.1
## [79] MatrixGenerics_1.12.0 zlibbioc_1.46.0