 Method
 Open Access
 Published:
scDesign2: a transparent simulator that generates highfidelity singlecell gene expression count data with gene correlations captured
Genome Biology volume 22, Article number: 163 (2021)
Abstract
A pressing challenge in singlecell transcriptomics is to benchmark experimental protocols and computational methods. A solution is to use computational simulators, but existing simulators cannot simultaneously achieve three goals: preserving genes, capturing gene correlations, and generating any number of cells with varying sequencing depths. To fill this gap, we propose scDesign2, a transparent simulator that achieves all three goals and generates highfidelity synthetic data for multiple singlecell gene expression countbased technologies. In particular, scDesign2 is advantageous in its transparent use of probabilistic models and its ability to capture gene correlations via copulas.
Introduction
The recent development of singlecell RNAseq (scRNAseq) technologies has revolutionized transcriptomic studies by revealing the genomewide gene expression levels within individual cells [1, 2]. In contrast to bulk RNA sequencing [3], scRNAseq technology captures cellspecific transcriptome landscapes, which can reveal crucial information about celltocell heterogeneity across different tissues, organs, and systems and enable the discovery of novel cell types and new transient cell states [4–9]. Already, scRNAseq technologies have led to breakthroughs in understanding biological processes such as stem cell differentiation and embryogenesis [10, 11], neurological disorders [12, 13], and tumorigenesis [14, 15].
Since the first scRNAseq study was published in 2009 [16], many experimental protocols have been developed [17–19]. Broadly speaking, the existing protocols fall into two categories: tagbased and fulllength [20]. Tagbased protocols (e.g., 10x Genomics [21], CELSeq2 [22], Dropseq [23], and SeqWell [24]) only capture and sequence one end of RNA transcripts, while fulllength protocols (e.g., SmartSeq2 [25], Fluidigm C1 [26], and MATQseq [27]) sequence fragments of fulllength RNA transcripts [19, 28]. Typically, compared to fulllength protocols (given the sequencing depth), tagbased protocols sequence more cells but have fewer transcripts captured per cell [29]. In addition to this cellnumber vs. percelldepth tradeoff, tagbased protocols use unique molecular identifiers (UMIs) to remove polymerase chain reaction (PCR) amplification biases [30], while fulllength protocols do not have this advantage and can only output reads without UMIs. Therefore, these protocols have different advantages in throughput (number of cells and number of genes captured) and accuracy (number of nonbiological zeros and PCR biases) [19, 31, 32]. Moreover, when designing experiments, researchers often face the practical issue of having a limited budget. In this case, they need guidance to choose either sequencing more cells with fewer reads (or UMIs) in each cell, or sequencing fewer cells with more reads (or UMIs) in each cell [33–35].
In addition to selecting experimental protocols before conducting scRNAseq experiments, a common challenge after collecting scRNAseq data is to choose among the many available data analysis methods in an unbiased manner. For example, many algorithms have been developed for missing gene expression imputation [36, 37], dimensionality reduction [38–40], cell clustering [41–44], rare cell type detection [45–47], differentially expressed gene identification [48–52], and trajectory inference [53–57]. Even though several benchmark and comparative studies have been carried out for common analysis tasks [58–63], most of them have only evaluated a subset of available computational methods using data from limited experimental protocols. Hence, they cannot meet the diverse needs of ongoing and future analyses of scRNAseq data. In short, singlecell researchers lack a systematic and flexible approach to select appropriate computational methods for specific data analysis needs.
One solution to the above two issues is to use in silico synthetic datasets, which carry ground truths (cell types, cell trajectories, differentially expressed genes, etc.) and do not induce extra experimental costs. Below, we summarize six properties that an ideal simulator should embrace.

1.
The simulator can be trained by real data so that it is adaptive to various experimental protocols and biological conditions.

2.
The simulator can preserve genes so that its synthetic cells contain expression levels of real genes. The simulator should retain every gene’s distribution of expression levels in its synthetic data without deleting genes in real data. This property is essential for benchmarking differential gene expression analysis.

3.
The simulator can capture gene correlations so that its synthetic data maintain a similar gene correlation structure to that in real data. This property relies on the last property and is essential for benchmarking multigene analyses such as cell dimensionality reduction (e.g., principal component analysis (PCA), tdistributed stochastic neighbor embedding (tSNE) [64, 65], and uniform manifold approximation and projection (UMAP) [66, 67]), cell clustering, rare cell type detection, and cell trajectory inference.

4.
The simulator can generate synthetic data with both varying cell number and sequencing depth, under the same biological condition of training data. This property is essential for guiding experimental design and benchmarking robustness of computational methods.

5.
The simulator is transparent so that its model parameters can be easily understood and adjusted. For example, key statistical properties, such as every gene’s expression mean, variance, zero proportions, and every gene pair’s expression correlation, can be easily accessed from the model. This property is essential for model diagnostics and customized simulation. Specifically, with a transparent model, whenever the synthetic data do not resemble the real data, computational researchers can easily access how well the model fits to each gene’s marginal distribution and what genes’ correlations are well captured or missed. Moreover, a transparent model offers users an opportunity to generate data from their specified parameter values, e.g., gene expression means.

6.
The simulator is computationally and sample efficient so that its training does not require expensive hardware, take excessive computational time, or rely on an enormous number of real cells to achieve good training. This property is essential for the simulator to be userfriendly and adaptive to fulllength protocols that generate hundreds to thousands of cells, e.g., Fluidigm C1 and SmartSeq2.
Although many simulators have been developed for scRNAseq data and various methodological advances have been made [35, 39, 68–76], to the best of our knowledge, none of them achieves all the six properties. We summarize 15 representative simulators in Table 1. Except scGAN [72], these simulators all use probabilistic models or differential equations that are transparent and easy to fit, thus satisfying properties 5 and 6. However, scDesign [35], three simulators in the splatter package (splat simple, splat, and kersplat) [69], and SymSim [70] do not preserve genes, failing properties 2 and 3; ZINBWaVE^{Footnote 1} [39, 69] and SPARSim [71] cannot vary cell number or sequencing depth, and SPsimSeq [79] cannot vary sequencing depth, failing property 4; SERGIO [76] requires a userspecified gene regulatory network as input and does not estimate gene correlations from real data^{Footnote 2}, thus not achieving property 3. Although scGAN preserves genes and uses a deep neural network to capture gene correlations, it cannot vary sequencing depth (not satisfying property 4), and its blackbox nature, requirement for GPU, and long computational time make it fail properties 5 and 6. Hence, a simulator that achieves all the six properties is in demand.
Here, we propose scDesign2 as the first simulator that achieves all the six properties and generates realistic synthetic data for multiple singlecell gene expression countbased technologies. Inheriting its name from our previous simulator scDesign, scDesign2 has achieved a significant methodological advance and become a transparent simulator that reliably captures gene correlations. This advance is enabled by probabilistic modeling of not only marginal distributions of individual genes but also the joint distribution of thousands of genes. Thanks to its achievement of the six properties, scDesign2 will serve as a powerful tool for guiding experimental design and benchmarking computational methods in the singlecell transcriptomics field.
Results
An overview of scDesign2
The statistical framework of scDesign2 consists of two steps: (1) model fitting and (2) synthetic data generation (Fig. 1). In the modelfitting step, scDesign2 fits a multivariate generative model to a real scRNAseq dataset. If the dataset contains more than one cell type (defined by marker genes or cell clustering; see the “Methods” section), then scDesign2 divides the dataset into subsets, one per cell type, and fits a cell typespecific model to each subset. In the datageneration step, scDesign2 generates synthetic scRNAseq data from the fitted model for each cell type.
The modelfitting step is composed of the following two substeps. First, scDesign2 fits a univariate count distribution to each gene’s counts in cells of the same type. Four count distributions are considered: Poisson, zeroinflated Poisson (ZIP), negative binomial (NB), and zeroinflated negative binomial (ZINB), with the former three as special cases of the ZINB. All the four distributions have been widely used to model a gene’s read or UMI counts in a homogeneous group of cells [39, 80–82]. From these four distributions, scDesign2 chooses one distribution for every gene in every cell type in a datadriven way. Second, scDesign2 captures the correlations of thousands of genes (all the moderately to highly expressed genes) by fitting a Gaussian copula in each cell type. We choose the Gaussian copula for its easiness to fit and good transparency, and we find it capturing gene correlations well (Fig. 2 and Additional file 1: Figures S1–S5).
As a simulator that explicitly captures gene correlations, scDesign2 leverages a unique advantage of the copula framework: the separate modeling of each gene’s marginal distribution and the correlation structure of thousands of genes together. This separation and its resulting flexibility are critical for scDesign2 to model singlecell gene expression count data generated by various experimental protocols. Thanks to this flexibility, scDesign2 can choose a count distribution from Poisson, ZIP, NB, and ZINB to fit each gene’s expression counts and reveal biological insights of that gene’s expression pattern.
Synthetic data generated by scDesign2 most resemble real scRNAseq data in benchmarking against existing simulators
We benchmark scDesign2 against eight existing simulators—ZINBWaVE, SPARSim, scGAN, scDesign, three variants of splat in the splatter package (splat simple, splat, and kersplat), and SymSim. We also compare scDesign2 with its own variant that only uses genes’ marginal distributions and no copula (w/o copula). Among these ten simulators, only scDesign2, its w/o copula variant, ZINBWaVE, SPARSim, and scGAN preserve genes. We apply these ten simulators to four scRNAseq datasets (in which cells are labeled with curated cell types) generated by different experimental protocols (10x Genomics [83], CELSeq2 [84], Fluidigm C1 [85], and SmartSeq2 [4]). For each dataset, we randomly split its cells into two halves, with one half (“training data”) to be used for training every simulator on each cell type individually and the other half (“test data”) to serve as the benchmark standard to be compared with the synthetic data generated by each simulator.
We use three sets of benchmark analyses to compare synthetic data with the corresponding test data. Here is an overview. First, we select three cell types from each dataset (measured by each experimental protocol), obtaining a total of 12 cell type–protocol combinations. For each combination, we evaluate eight key statistics: four genewise (expression mean, variance, coefficient of variation (cv), and zero proportion), two cellwise (zero proportion and library size), and two genepairwise (Pearson correlation and Kendall’s tau). (Note that we include Kendall’s tau instead of Spearman’s rank correlation as a rankbased correlation statistic because Kendall’s tau can account for ties.) For each statistic, we compare its empirical distribution—across genes (for genewise statistics), across cells (for cellwise statistics), or across genepairs (for genepairwise statistics)—in the test data with that in the synthetic data generated by each simulator. For the four genewise and two genepairwise statistics, we also directly compare their values in the test data with those in the synthetic data generated by scDesign2, ZINBWaVE, SPARSim, and scGAN—the four simulators that preserve genes. We cannot do this for the other simulators, because the values of these generelated statistics are not comparable if the genes are not preserved. The results are summarized in Fig. 3 and Additional file 1: Figures S6–S28. Second, for each of the 12 cell type–protocol combinations, we compare the gene correlation matrix estimated from the test data with that from the synthetic data generated by each simulator that preserves genes. We exclude the simulators that do not preserve genes because the gene expression matrices estimated from their synthetic data do not align with those from real data (i.e., the genes of the synthetic data matrix cannot be matched onetoone to the genes of the training data matrix). The results are summarized in Fig. 2 and Additional file 1: Figures S1–S5. Third, for each of the four protocols, we use 2D visualization—tSNE and PCA—to compare cells of multiple types in the test data and the synthetic data generated by each simulator that preserves genes. Again, we exclude the simulators that do not preserve genes because their synthetic cells cannot be combined with real cells for joint visualization (dimesionality reduction requires all cells to have the same original dimensions, i.e., genes). The results are summarized in Fig. 4 and Additional file 1: Figures S29–S31.
Overall, we find that the synthetic data generated by scDesign2 most resemble the test data for all four protocols. In our first set of analyses, we categorize the eight existing simulators into two types: simulators that preserve genes (ZINBWaVE, SPARSim, and scGAN) and others. First, by comparing the distributions of eight key statistics between test data and synthetic data, we find that the simulators capable of preserving genes have overall better performance than other simulators, across cell types and protocols (Fig. 3a and Additional file 1: Figures S6a–S16a).
Second, we further benchmark the genepreserving simulators by directly comparing their synthetic data and test data in terms of the genewise and genepairwise statistics’ values. Note that we cannot compare these statistics’ values for simulators that do not preserve genes because the “genes” in those simulators’ synthetic data cannot be matched to any genes in real data. In detail, we calculate the meansquared errors (MSEs) of the four genewise statistics and the two genepairwise statistics between test data and synthetic data generated by scDesign2, ZINBWaVE, SPARSim, and scGAN. Figure 3b shows that scGAN, a deeplearningbased method, consistently has the worst MSEs for all the six statistics. Due to its long computational time^{Footnote 3}, difficult implementation, and unsatisfactory performance, we exclude it from the following comparisons.
Out of 48 comparisons of genewise statistics (4 statistics times 12 cell type–protocol combinations), scDesign2 achieves the best MSEs in 37 comparisons and demonstrates a clear advantage over ZINBWaVE and SPARSim (Fig. 3b and Additional file 1: Figures S6b–S16b). Out of 24 comparisons of genepairwise statistics (2 correlation statistics times 12 cell type–protocol combinations) based on the 500 most highly expressed genes (in terms of their mean expression levels across cells) in each cell type–protocol combination, scDesign2 achieves the best MSEs in 15 comparisons (Fig. 3b and Additional file 1: Figures S6b–S16b). We highlight the highly expressed genes because their Pearson correlations and Kendall’s tau values are more biologically meaningful; in all cell type–protocol combinations, the top 500 highly expressed genes, ranked by either mean expression levels or nonzero proportions across cells, explain at least 50% of reads or UMIs (Additional file 1: Figures S17c–S28c), confirming that these genes play dominant roles in transcriptional programs in cells. In addition, we include the comparison results based on more genes in Additional file 1: Figures S17d&e–S28d&e, which show that, as more lowly expressed genes are included, the MSEs of all these simulators decrease and become less distinguishable (because lowly expressed gene pairs have correlations close to zero in test data and all synthetic data), making the comparison less meaningful.
Third, we examine correlations of individual gene pairs and observe that scDesign2 can preserve strong negative gene correlations missed by ZINBWaVE and SPARSim, which wrongly capture these correlations as weak or even positive (Fig. 3cd and Additional file 1: Figures S6cd–S16cd). This observation is further confirmed by our second set of analyses below. Furthermore, we compare the relationships of three pairs of genewise statistics (zero proportion vs. mean, variance vs. mean, and cv vs. mean) between test data and synthetic data generated by each simulator, and we find that scDesign2 better captures the relationships than existing simulators do across cell types and experimental protocols (Fig. 3e and Additional file 1: Figures S6e–S16e).
In our second set of analyses, we compare gene correlation matrices in terms of both Pearson correlation and Kendall’s tau between test data and synthetic data generated by scDesign2, ZINBWaVE, and SPARSim. Heatmap visualization shows that scDesign2 captures gene correlations most accurately and consistently across cell types and experimental protocols (Fig. 2 and Additional file 1: Figures S1–S5). Notably, for highly expressed genes in SmartSeq2 data, ZINBWaVE and SPARSim miss almost all the gene correlations, while scDesign2 well preserves positive and negative gene correlations in its synthetic data (Fig. 2b, d and Additional file 1: Figure S5b & d).
In our third set of analyses, we use 2D visualization to compare cells in test data and those in synthetic data generated by scDesign2, ZINBWaVE, and SPARSim. Both tSNE and PCA 2D plots show that cells in synthetic data generated by scDesign2 most resemble cells in test data (Fig. 4 and Additional file 1: Figures S29–S31). In particular, by overlaying real and synthetic cells in the same 2D plot, we find synthetic cells generated by scDesign2 least distinguishable from real cells. On the contrary, synthetic cells generated by ZINBWaVE and SPARSim exhibit spurious patterns unseen in real cells.
To quantify the similarity between synthetic cells and real test cells, we use the median integration local inverse Simpson’s index (miLISI) [86], whose value is between 1 and 2, with a larger value indicating a greater similarity. Specifically, we compute an integration local inverse Simpson’s index (iLISI) to represent the effective number of cell labels (with 1 meaning synthetic or real cells only, and 2 meaning equal numbers of synthetic and real cells) in the local neighborhood of each (synthetic or real) cell; the closer iLISI is to 2, the more equal presence synthetic and real cells have in the local neighborhood. Taking the median of the iLISIs of all cells, we obtain the miLISI, which quantifies the overall mixing of synthetic cells with real cells. Using the R package LISI [86], we calculate the miLISI value for each of the overlaying 2D plots containing real and synthetic cells (Fig. 4 and Additional file 1: Figures S29–S31), and we find that scDesign2 consistently leads to the highest miLISI value, with greater advantages in 2D tSNE plots than 2D PCA plots. Since 2D tSNE projection preserves cell clusters better than 2D PCA does and is more widely used for visualizing singlecell gene expression data, our results suggest that the synthetic data by scDesign2 best capture the cluster structure in real cells. Together, the miLISI values confirm the superb performance and the realistic nature of scDesign2.
These three sets of analyses also verify the advantage of using copula in scDesign2. Compared with scDesign2, its w/o copula variant, as expected, cannot capture gene correlations at all (Figs. 2 and 3a, Additional file 1: Figures S1–S5 and S6a–S16a). As a result, the synthetic data generated by the w/o copula variant do not resemble the corresponding real data in 2D visualization (Fig. 4 and Additional file 1: Figures S29–S31).
In addition to its realistic nature, scDesign2 also has two more unique advantages over ZINBWaVE and SPARSim. Unlike the other two simulators, scDesign2 only considers genes as features and models their joint distribution, and it regards cells as observations instead of features. This formulation is aligned with the statistical thinking that genes are fixed quantities, but cells are randomly sampled from a population of cells. Thanks to this principled formulation, scDesign2 can generate synthetic cells of any number, in contrast to ZINBWaVE and SPARSim that can only generate the same number of synthetic cells as real cells. It is also worth noting that, although scDesign2 does not explicitly model the distribution of cell library sizes, it recovers that distribution rather faithfully (see the cell library size distributions in Fig. 3a and Additional file 1: Figures S6a–S16a). This is achieved by modeling joint gene distributions and accounting for gene correlations through the use of copula. Compared to scGAN, the training of scDesign2 is fast and does not rely on a large number of input real cells for good training quality.
Refinement of scDesign2 training: calibration of cell types by ROGUE scores
For a dataset containing multiple cell types, scDesign2 needs to fit a model to each cell type before generating synthetic data. To ensure the quality of its synthetic data, scDesign2 must have one of its count models (ZINB model and its three simplified variants) fit well to each gene’s real expression levels in each cell type; otherwise, the synthetic data may not well mimic real data due to the poorness of model fitting. We observe this issue in the 10x Genomics dataset (Fig. 4a), where some cell types such as transitamplifying early (TA.Early) cells and goblet cells are composed of discrete subclusters in 2D tSNE illustration. As a result, some genes’ expression levels within one of such cell types cannot be fit well by scDesign2’s count models, leading to a discrepancy between synthetic data and real data (synthetic TA.Early and goblet cells do not appear to have cell subclusters in 2D tSNE illustration).
To address this issue, we calibrate each cell type using the ROGUE score [87], which measures the homogeneity of that cell type, before training scDesign2. Concretely, we first partition the cell type into subclusters using the Louvain clustering algorithm [88] in the Seurat R package [42]. Employing varying resolution parameters in the Louvain algorithm, we partition the cell type into a varying number of subclusters. Second, we calculate the ROGUE score of every subcluster, and then, we compute the average ROGUE score across subclusters for each number of subclusters, ranging from 1 to 6. Third, we examine how the average ROGUE score increases as the number of subclusters increases (Fig. 5a), together with 2D tSNE visualization (Fig. 5b), to determine an appropriate number of subclusters, which is usually the “elbow point” where the average ROGUE score saturates.
Applying this strategy to refining the six cell types in the 10x Genomics dataset, we observe that, after being trained with the refined cell types, scDesign2 generates more realistic synthetic data (Fig. 5c; the miLISI value increases from 1.596 to 1.779).
Application 1: scDesign2 generates realistic synthetic data for other singlecell expression countbased technologies
Beyond scRNAseq data, we demonstrate that scDesign2 can also generate realistic synthetic data for other singlecell countbased technologies that do not necessarily use nextgeneration sequencing, as long as individual genes’ count distributions can be well approximated by Poisson, ZIP, NB, or ZINB. For instance, singlecell spatial transcriptomics technologies, usually based on fluorescence in situ hybridization (FISH), are known to yield Poisson or NB distributed counts [89, 90]. The versatility of scDesign2 is endowed by its datadriven way of selecting marginal distributions for individual genes, regardless of each distribution being Poisson or NB, zeroinflated or not.
We demonstrate the accuracy of scDesign2 based on two singlecell spatial transcriptome datasets: one dataset of cells in the mouse hypothalamic preoptic region measured by multiplexed error robust fluorescence in situ hybridization (MERFISH) [91] and another dataset of cells in the mouse hippocampal area CA1 measured by probabilistic cell typing by in situ sequencing (pciSeq) [92], a newly developed spatial transcriptome profiling technology. Both datasets contain labeled cell types. Due to the lack of simulators specifically designed for singlecell spatial transcriptome data, we still benchmark scDesign2 against its w/o copula variant, as well as ZINBWaVE and SPARSim, the two simulators that preserve genes. Note that for all the simulators considered, they only generate gene counts, not spatial coordinates, for synthetic cells. Similar to our previous analysis, for each cell type in each dataset, we randomly split the cells into two halves, with one half (“training data”) to be used for training every simulator and the other half (“test data”) to serve as the benchmark standard to be compared with the synthetic data generated by each simulator. Figure 6 and Additional file 1: Figure S32 demonstrate the 2D visualization of each real dataset, the corresponding synthetic data generated by each simulator, as well as the combination of test data and each synthetic dataset. For both technologies and in both tSNE and PCA visualization, scDesign2 outperforms SPARSim and ZINBWaVE by generating synthetic data that most resemble the real data. In particular, scDesign2 consistently achieves the highest miLISI values in the 2D visualization plots of combined data, indicating that the synthetic cells generated by scDesign2 are least distinguishable from real cells. These results confirm the versatility and robustness of scDesign2.
Application 2: scDesign2 guides experimental design and computational method benchmarking in cell clustering
Cell clustering is a ubiquitous computational task in singlecell research. Here, we demonstrate how scDesign2 can guide experimental design (i.e., deciding the optimal cell number and sequencing depth) and benchmark computational methods for the cell clustering task.
After training scDesign2 on each of the four scRNAseq datasets generated by different experimental protocols (10x Genomics [83], CELSeq2 [84], Fluidigm C1 [85], and SmartSeq2 [4]), we apply the trained scDesign2 models to generate synthetic data under three experimental design scenarios: (1) varying sequencing depths, where the total number of reads (or UMIs) varies but the cell number is fixed; (2) varying cell numbers, where the number of sequenced cells varies but the sequencing depth is fixed; and (3) fixing the percell average sequencing depth, where the both the number of sequenced cells and the total sequencing depth vary, but the average number of reads (or UMIs) in each cell is fixed. For each protocol, scDesign2 generates a synthetic dataset per sequencing depth and cell number.
To guide the choices of sequencing depth and cell number based on clustering accuracy, we apply two popular scRNAseq cell clustering methods—Seurat (the kNNJaccardLouvain algorithm) [42, 88] and SC3 [41]—to the synthetic datasets and use the adjusted mutual information (AMI) [93] and the adjusted Rand index (ARI) [94] as two clustering accuracy measures. Note that SC3 can be specified to output the same number of cell clusters as the annotated cell types, while Seurat cannot due to the nature of the Louvain algorithm it uses [88]. The results are summarized in Figs. 7, 8, and 9 and Additional file 1: Figures S33–S41.
For the first, varyingsequencingdepth scenario, we expect the clustering accuracy to improve as the sequencing depth increases, because a larger sequencing depth would better reveal every cell’s transcriptome profile and thus lead to better clustering. Moreover, we also expect there to be a saturation effect: the clustering accuracy no longer improves much after the sequencing depth increases to a point, which we regard as the optimal sequencing depth that balances clustering accuracy and budget. The results confirm our expectation. For the two UMIbased protocols 10x Genomics and CELSeq2, we observe the improvement and the saturation effect in clustering accuracy, based on both Seurat and SC3, as the sequencing depth increases. In detail, the saturation for 10x Genomics data occurs at 113.05 million UMIs for 3793 cells, while the real dataset has only 28.57 million UMIs (Fig. 7); the saturation for CELSeq2 data occurs at 42.72 million UMIs for 2279 cells, while the real dataset contains 172.14 million UMIs (Additional file 1: Figure S33). For the two nonUMIbased protocols Fluidigm C1 and SmartSeq2, we observe the saturation effect even at the lowest sequencing depth we consider, likely due to the fact that these two protocols provide a deeper profiling of every cell than the UMIbased protocols do. In detail, the saturation for Fluidigm C1 data occurs at 26.74 (based on Seurat) or 110.52 (based on SC3) million reads for 317 cells, while the real dataset contains 869.24 million reads (Additional file 1: Figure S36); the saturation for SmartSeq2 data occurs at 33.68 million reads for 1078 cells, based on both Seurat and SC3, while the real dataset contains 1074.97 million reads (Additional file 1: Figure S39). The tSNE visualization supports the observed trends of clustering accuracy. In each tSNE plot that corresponds to one sequencing depth and one set of cell clusters/types (by Seurat, SC3, or annotated cell types), synthetic cells are labeled by their cell clusters/types; contrasting a tSNE plot of cell clusters with that showing cell types illustrates clustering accuracy (Fig. 7a and Additional file 1: Figures S33a, S36a, and S39a). In conclusion, for clustering purpose, we would recommend increasing the 10x Genomics sequencing depth to 113.05 million UMIs, if budget allows, and using SC3 for clustering; for CELSeq2, Fluidigm C1, and SmartSeq2, we would recommend decreasing the sequencing depths to 42.72 million UMIs, 110.52 million reads, and 33.68 million reads, respectively, to save budget and using either Seurat or SC3 for clustering.
For the second, varyingcellnumber scenario, we expect the clustering accuracy to first increase and then decrease as the cell number increases. The reason is that good clustering requires both a reasonable number of cells of each type and a clearenough gene expression profile (where enough genes are captured) of every cell, thus posing a tradeoff—given the sequencing depth, the larger the cell number, the less clear each cell’s profile would be. Hence, as the cell number increases from low, while every cell’s profile is still clear, clustering accuracy increases; however, as the cell number reaches a point where every cell type has more than enough cells, further increasing the cell number would obscure every cell’s profile and deteriorate clustering accuracy. For the two UMIbased protocols 10x Genomics and CELSeq2, our expectation is confirmed: we observe an overall trend of clustering accuracy that first increases and then decreases (Fig. 8b and Additional file 1: Figure S34b). In detail, for 10x Genomics data, both Seurat and SC3 have their accuracy maximized at 948 cells. This optimality is supported by the tSNE visualization, which shows that the Seurat and SC3 cell clusters best agree with the annotated cell types at this optimal cell number (Fig. 8a). Hence, the real data cell number 3793 is not optimal for distinguishing the annotated cell types by Seurat or SC3. For CELSeq2 data, Seurat and SC3 have optimal accuracy at 2279 and 570 cells, respectively, also supported by the tSNE visualization (Additional file 1: Figure S34a). This suggests that the real data cell number 2279 can lead to optimal cell clustering by Seurat. In contrast, for the two nonUMIbased protocols Fluidigm C1 and SmartSeq2, we only observe a firstincreasingandthensaturated trend of clustering accuracy as the cell number increases, without seeing the trend decreasing (except for SC3 on SmartSeq2 data) (Additional file 1: Figures S37b and S40b). A likely reason is that these two protocols can provide a clear profile of every cell up to a large cell number around 10,000 given their deep sequencing depths in real data (869.24 million reads in the Fluidigm C1 data and 1074.95 million reads in the SmartSeq2 data). For both Seurat and SC3, the cell numbers at which their performance saturates are close to the cell numbers in real data: 317 cells in the Fluidigm C1 data and 1078 cells in the SmartSeq2 data. In conclusion, we use scDesign2 to find that the cell numbers are close to being optimal in the CELSeq2, Fluidigm C1, and SmartSeq2 datasets. For 10x Genomics, we would recommend decreasing the cell number to 948 cells (while keeping the sequencing depth at 28.58 million UMIs) to optimize the clustering accuracy by either Seurat or SC3.
For the third, fixingaveragesequencingdepth scenario, we expect the clustering accuracy to improve as the cell number (and also the total sequencing depth) increases, because more cells will make the identification of cell types easier. Moreover, we expect there to be a saturation effect: the clustering accuracy no longer improves much after the cell number increases to a point, which we regard as the optimal cell number that balances clustering accuracy and budget. The results confirm our expectation. In all four protocols, we observe the expected trend of clustering accuracy for both Seurat and SC3, as well as the saturation effect, which is more obvious for Seurat. In detail, the saturation for 10x Genomics data occurs at 948 cells (based on Seurat), or 3793 cells (based on SC3), while the real dataset has 3793 cells (Fig. 9); the saturation for CELSeq2 data occurs at 1140 cells, while the real dataset has 2279 cells (Figure S35); the saturation for Fluidigm C1 data occurs at 317 cells (based on Seurat), which is the same cell number as the real dataset, while the optimal clustering accuracy occurs at 1268 cells based on SC3 (Figure S38); the saturation for SmartSeq2 data occurs at 4312 cells, while the real dataset has 1078 cells (Figure S41). In conclusion, when the average read (or UMI) count per cell is kept as fixed, for clustering purpose, we recommend keeping the cell number as in the original design for 10x Genomics and using SC3 for clustering; for CELSeq2, we recommend decreasing the cell number to 1140 to save budget and using Seurat for clustering; for Fluidigm C1, if budget allows, we recommend increasing the cell number to 1268 and using SC3 for clustering; for SmartSeq2, if budget allows, we recommend increasing the cell number to 4312 and using either Seurat or SC3 for clustering.
Beyond experimental design, scDesign2 also provides a comprehensive comparison of Seurat and SC3 across sequencing depths and cell numbers. Overall, both methods demonstrate superb accuracy in a wide range of sequencing depths and cell numbers for every protocol. At closetooptimal sequencing depths and cell numbers for each method, SC3 has better accuracy than Seurat. However, Seurat and SC3 have different robustness: Seurat is a more robust method for 10x Genomics data when the sequencing depth is low or the cell number is large (Figs. 7b, 8, and 9b), while SC3 is more robust when the cell number is small for CELSeq2 (Additional file 1: Figures S34b–S35b), Fluidigm C1 (Additional file 1: Figures S37b–S38b), and SmartSeq2 (Additional file 1: Figures S40b–S41b). This finding is consistent with the fact that SC3 is an ensemble method that is more robust against a small number of cells but cannot be easily scaled up when the cell number is too large.
Application 3: scDesign2 guides experimental design and computational method benchmarking in rare cell type detection
Rare cell type detection is another important application of scRNAseq, whose highthroughput profiling of cells opens an unprecedented opportunity to identify unknown cell types that are often rare but critical. Here, we demonstrate how scDesign2 can guide experimental design (i.e., deciding the optimal cell number and sequencing depth) and benchmark computational methods for the rare cell type detection task.
From the 10x Genomics dataset of mouse intestine epithelial tissue [83], we select six cell types—stem cells (Stem), goblet cells (Goblet), tuft cells (Tuft), early transit amplifying cells (TA.Early), enterocyte progenitors (EP), and early enterocyte progenitors (EP.Early), among which Tuft is the rare cell type [95] and has a proportion less than 5% among the six cell types. After training scDesign2 on this dataset, we use scDesign2 to generate synthetic data under three experimental design scenarios: (1) varying sequencing depths, where the total number of UMIs varies but the cell number is fixed; (2) varying cell numbers, where the number of sequenced cells varies but the sequencing depth is fixed; and (3) fixing the percell average sequencing depth, where both the number of sequenced cells and the total sequencing depth vary, but the average number of reads (or UMIs) in each cell is fixed. For every sequencing depth and cell number, scDesign2 generates a synthetic dataset.
To guide the choices of sequencing depth and cell number based on rare cell type detection accuracy, we apply two popular methods—FiRE [47] and GiniClust2 [46]—to the synthetic datasets and evaluate four accuracy measures: precision (the percentage of truly rare cells among the detected rare cells), recall (the percentage of detected rare cells among the truly rare cells), F1score (the harmonic mean of the precision and recall), and AUPRC (the area under the precisionrecall curve). Since GiniClust2 does not allow adjustment of its detection threshold, we cannot calculate its AUPRC. However, as most users of FiRE would stick with its default threshold, the AUPRC measure is not as informative as the other three measures from a user’s perspective.
For the first, varyingsequencingdepth scenario, we expect that the detection accuracy would improve as the sequencing depth increases and there would be a saturation effect, similar to our expectation for cell clustering. The detection accuracy of FiRE and GiniClust2 roughly confirms our expectation. Across twelve sequencing depths ranging from 1.76 to 3612.4 million UMIs (with the cell number fixed as 3793, the number of cells in real data), we observe an overall trend of increasing detection accuracy with few exceptions (Fig. 10). For FiRE, its accuracy exhibits saturation after the sequencing depth reaches 457.23 million UMIs (Fig. 10a, c), while for GiniClust2 the saturation occurs earlier at a sequencing depth of 113.05 million UMIs (Fig. 10b, d). The tSNE visualization supports the observed trends of precision and recall. In each tSNE plot that corresponds to one sequencing depth and one detection method (FiRE or GiniClust2), synthetic cells are labeled as one of four types: true positive (TP; the rare cells correctly detected), false positive (FP; the unrare cells falsely detected), false negative (FN; the rare cells falsely undetected), and true negative (TN; the unrare cells correctly undetected). The numbers of TP, FP, FN, and TN cells determine the precision and recall: a large precision requires many TP cells and few FP cells; a large recall requires many TP cells and few FN cells. Notably, the abnormal accuracy of GiniClust2 at 457.23 million UMIs (Fig. 10d) is explained by the tSNE visualization (Fig. 10b), which shows that GiniClust2 misidentifies the second largest cell cluster as the rare cell type, leads to many FP and FN cells, and results in close to zero precision and recall. Combining the FiRE and GiniClust2 results, we conclude that the real data sequencing depth at 28.57 million UMIs for 3793 cells is not optimal for detecting the rare cell type Tuft (Fig. 10c, d). If budget allows, we would recommend increasing the sequencing depth to 113.06 million UMIs and use GiniClust2 to detect tuft cells.
For the second, varyingcellnumber scenario, we expect the detection accuracy to first increase and then decrease as the cell number increases, similar to our expectation for cell clustering. Again, the detection accuracy of FiRE and GiniClust2 confirms our expectation. Across thirteen cell numbers ranging from 29 to 121,376 (with the sequencing depth fixed as 28.57 million UMIs, the same as in real data), we observe an overall trend of detection accuracy that first increases and then decreases (Fig. 11). For both FiRE and GiniClust2, their F1scores are optimal at 1896 cells (Fig. 11c, d). This optimality is supported by the tSNE visualization, which shows a plot of synthetic cells with TP, FP, FN, and TN labels for every cell number and each detection method (Fig. 11a, b). Hence, the real data cell number 3793 is not optimal for detecting tuft cells given the total sequencing depth of 28.57 million UMIs. If the detection of tuft cells is a primary goal and the sequencing depth cannot be increased due to budget constraints, we would recommend decreasing the cell number to 1896 cells and use GiniClust2 to detect tuft cells.
For the third, fixingaveragesequencingdepth scenario, we expect the detection accuracy to first increase and then saturate as the cell number increases, similar to our expectation for cell clustering. The detection accuracy of FiRE roughly confirms our expectation, while the detection accuracy of GiniClust2 deviates from this trend (Fig. 12). For FiRE, across thirteen cell numbers ranging from 29 to 121,376 (with the average sequencing depth fixed as 7.53k UMIs per cell, the same as in real data), the F1score reaches an early local maximum at 474 cells, and then stays relatively stable. A similar trend can be seen for the other three accuracy measures: precision, recall, and AUPRC. For GiniClust2, across nine cell numbers ranging from 29 to 7586, the F1score reaches a global maximum at 237 cells, and then it decreases as the cell number further increases. This is mainly due to the increasing proportion of FPs in the discovered rare cells, as indicated by the plunging precision curve. The recall, on the other hand, stays relatively stable after the optimal cell number. The tSNE visualization supports the observed trends of these accuracy measures. For example, we can see that for GiniClust2, when the cell number reaches 1000, more cells are labeled as FP, as shown in subpanels (4)–(6) of Fig. 12b. In summary, if the goal is to detect tuft cells and the average sequencing depth is fixed as 7.53k UMIs per cell, we recommend using GiniClust2 and decreasing the number of cells to 237.
In addition to assisting experimental design, scDesign2 also provides an objective comparison of FiRE and GiniClust2 across sequencing depths and cell numbers. Figures 10, 11 and 12 show that GiniClust2 has much better accuracy than FiRE at closetooptimal sequencing depths and cell numbers. However, FiRE is a more robust method that it can successfully run at all sequencing depths and cell numbers, while GiniClust2 fails when the cell number is too small or too large (GiniClust3 may have addressed this large cell number issue [96]). This finding is consistent with the methodological difference between the two methods: FiRE detects rare cells via an outlier detection approach, while GiniClust2 first performs cell clustering and then identifies the cells in small clusters as rare cells. The requirement of cell clustering explains why GiniClust2 fails when the cells exhibit no clear clusters and why it works well when rare cells form small clear clusters. In contrast, outlier detection has no requirement on cluster patterns, and this explains why FiRE is robust.
Discussion
In this article, we propose scDesign2, a transparent simulator for singlecell gene expression count data. Our development of scDesign2 is motivated by the pressing challenge to generate realistic synthetic data for various scRNAseq protocols and other singlecell gene expression countbased technologies. Unlike existing simulators including our previous simulator scDesign, scDesign2 achieves six properties: protocol adaptiveness, gene preservation, gene correlation capture, flexible cell number and sequencing depth choices, transparency, and computational and sample efficiency. This achievement of scDesign2 is enabled by its unique use of the copula statistical framework, which combines marginal distributions of individual genes and the global correlation structure among genes. As a result, scDesign2 has the following methodological advantages that contribute to its high degree of transparency. First, it selects a marginal distribution from four options (Poisson, ZIP, NB, and ZINB) for each gene in a datadriven manner to best capture and summarize the expression characteristics of that gene. Second, it uses a Gaussian copula to estimate gene correlations, which will be used to generate synthetic singlecell gene expression counts that preserve the correlation structures. Third, it can generate gene expression counts according to userspecified sequencing depth and cell number.
We have performed a comprehensive set of benchmarking and real data studies to evaluate scDesign2 in terms of its accuracy in generating synthetic data and its efficacy in guiding experimental design and benchmarking computational methods. Based on four scRNAseq protocols and 12 cell types, our benchmarking results demonstrate that scDesign2 better captures gene expression characteristics in real data than eight existing scRNAseq simulators do. In particular, among the four simulators that aim to preserve gene correlations, scDesign2 achieves the best accuracy. Moreover, we demonstrate the capacity of scDesign2 in generating synthetic data of other singlecell countbased technologies including MERFISH and pciSeq, two singlecell spatial transcriptomics technologies. After validating the realistic nature of synthetic data generated by scDesign2, we use real data applications to demonstrate how scDesign2 can guide the selection of cell number and sequencing depth in experimental design, as well as how scDesign2 can benchmark computational methods for cell clustering and rare cell type identification.
In the last stage of manuscript finalization, we found another scRNAseq simulator SPsimSeq [79] (published in Bioinformatics as a 2.3page software article), which can capture gene correlations. However, unlike scDesign2, SPsimSeq cannot generate scRNAseq data with varying sequencing depths. To compare scDesign2 with SPsimSeq, we have benchmarked their synthetic data against the corresponding real data in two sets of analyses: (1) gene correlation matrices of the previously used 12 cell type–protocol combinations (3 cell types × 4 scRNAseq protocols) and (2) 2D visualization plots of the 4 multicell type scRNAseq datasets and one MERFISH dataset. The results are summarized in Additional file 2. We find that in most cases (10 out 12 cases in the first set of analysis; 5 out 5 cases in the second set of analysis), the synthetic data of scDesign2 better resemble the real data than the synthetic data of SPsimSeq do.
Since scRNAseq data typically contain tens of thousands of genes, the estimation of the copula gene correlation matrix is a high dimensional problem. This problem can be partially avoided by only estimating the copula correlation matrix of thousands of moderately to highly expressed genes. We use a simulation study to demonstrate why this approach is reasonable (Additional file 1: Figures S42 and S43), and a more detailed discussion is in the “Methods” section. To summarize, the simulation results suggest that, to reach an average estimation accuracy of ±0.3 of true correlation values among the top 1000 highly expressed genes, at least 20 cells are needed. To reach an accuracy level of ±0.2 for the top 1500 highly expressed genes, at least 50 cells are needed. With 100 cells, an accuracy level of ±0.1 can be reached for the top 200 highly expressed genes, and a slightly worse accuracy level can be reached for the top 2000 genes.
In the implementation of the scDesign2 R package, we control the number of genes for which copula correlations need to be estimated by filtering out the genes whose zero proportions exceed a userspecified cutoff. For all the results in this paper, the cutoff is set as 0.8. In Additional file 1: Table S1, we summarize the number of cells (n), i.e., the sample size, and the number of genes included for copula correlation estimation (p) in each of the 12 datasets used for benchmarking simulators. Based on Additional file 1: Figures S42 and S43, we see that p appears to be too large for the CELSeq2, Fluidigm C1, and SmartSeq2 datasets. This suggests that the results in this paper may be further improved by setting a more stringent cutoff for gene selection.
For future methodological improvement, there are other ways to address this highdimensional estimation problem. For example, we can consider implementing sparse estimation (e.g., [97]) for the copula correlation matrix. Moreover, we can build a hierarchical model to borrow information across cell types/clusters. This will be useful for improving the model fitting for small cell types/clusters that may share similar gene correlation structures.
The current implementation of scDesign2 is restricted to singlecell datasets composed of discrete cell types, because the generative model of scDesign2 assumes that cells of the same type follow the same distribution of gene expression. However, many singlecell datasets exhibit continuous cell trajectories instead of discrete cell types. A nice property of the probabilistic model used in scDesign2 is that it is generalizable to account for continuous cell trajectories. First, we can use the generalized additive model (GAM) [52, 98, 99] to model each gene’s marginal distribution of expression as a function of cell pseudotime, which can be computationally inferred from real data [53, 54, 56]. Second, the copula framework can be used to incorporate gene correlation structures along the cell pseudotime. Combining these two steps into a generative model, this extension of scDesign2 has the potential to overcome the current challenge in preserving gene correlations encountered by existing simulators for singlecell trajectory data, such as Splatter Path [69], dyngen [77], and PROSSTT [68]. Another note is that scDesign2 does not generate synthetic cells based on outlier cells that do not cluster well with any cells in wellformed clusters. This is not necessarily a disadvantage, neither is it a unique feature to scDesign2. In fact, all modelbased simulators that learn a generative model from real data must ignore certain outlier cells that do not fit well to their model. Some outlier cells could either represent an extremely rare cell type or are just “doublets” [100–103], artifacts resulted from singlecell sequencing experiments. Hence, our stance is that ignorance of outlier cells is a sacrifice that every simulator has to make; the open question is the degree to which outlier cells should be ignored, and proper answers to this question must resort to statistical model selection principles.
Regarding the use of scDesign2 to guide the design of scRNAseq experiments, although scDesign2 can model and simulate data from various scRNAseq protocols and other singlecell expression countbased technologies, the current scDesign2 implementation is not yet applicable to crossprotocol data generation (i.e., training scDesign2 on real data of one protocol and generating synthetic data for another protocol) because of complicated differences in data characteristics among protocols. To demonstrate this issue, we use a multiprotocol dataset of peripheral blood mononuclear cells (PBMCs) generated for benchmarking purposes [20]. We select data of five cell types measured by three protocols, 10x Genomics, DropSeq, and SmartSeq2, and we train scDesign2 on the 10x Genomics data. Then, we adjust the fitted scDesign2 model for the DropSeq and SmartSeq2 protocols by rescaling the mean parameters in the fitted model to account for the total sequencing depth and cell number, which are protocolspecific (see the “Methods” for details). After the adjustment, we use the model for each protocol to generate synthetic data. Additional file 1: Figure S44 illustrates the comparison of real data and synthetic data for each protocol. From the comparison, we observe that the synthetic cells do not mix well with the real cells for the two crossprotocol scenarios; only for 10x Genomics, the sameprotocol scenario, do the synthetic cells mix well with the real cells.
To further illustrate the different data characteristics of different protocols, we compare individual genes’ mean expression levels in the aforementioned three protocols. We refer to DropSeq and SmartSeq2 as the target protocols, and 10x Genomics as the reference protocol. First, we randomly partition the two targetprotocol datasets and the referenceprotocol dataset into two halves each; we repeat the partitions for 100 times and collect 100 sets of partial datasets, with each set containing two targetprotocol partial datasets (one DropSeq and one SmartSeq2) and two referenceprotocol partial datasets (split from the 10x Genomics dataset)—one of the latter is randomly picked and referred to as the “reference data.” Second, For every gene in each cell type, we take each set of partial datasets and compute two crossprotocol ratios, defined as the gene’s mean expression levels in the targetprotocol partial datasets divided by its mean expression level in the reference data, and a withinprotocol ratio, defined as the ratio of the gene’s mean expression level in the other referenceprotocol partial dataset divided by that in the reference data; together, with the 100 sets of partial dataset, every gene in each cell type has 100 ratios for each of the two crossprotocol comparisons and 100 ratios for the withinprotocol comparison. We apply this procedure to the top 50 and 2000 highly expressed genes in five cell types. Additional file 1: Figures S45 and S46 show that, with the withinprotocol ratios as a baseline control for each cell type and each target protocol, the crossprotocol ratios exhibit a strongly genespecific pattern; moreover, there is no monotone relationship between the crossprotocol ratios and the mean expression levels of genes. This result confirms that there does not exist a single scaling factor to convert all genes’ expression levels from one protocol to another. However, an interesting phenomenon is that, for each target protocol, the crossprotocol ratios have similar patterns across cell types. This phenomenon sheds light on a future research direction of crossprotocol simulation for the cell types that exist in only one protocol, if the two protocols have shared cell types. In this scenario, we may train a model for each cell type in each protocol, learn a genespecific but cell typeinvariant scaling factor from the shared cell types, and simulate data for the cell types missing in one protocol.
We note that the above analysis is only conducted for the genes’ mean expression levels. The difficulty of crossprotocol simulation is in fact even larger because realistic simulation requires the rescaling of the other distributional parameter(s) in a twoparameter distribution such as NB and ZIP or a threeparameter distribution such as ZINB. Existing work has provided extensive empirical evidence on the vast differences between protocols in terms of data characteristics [42, 86].
In applications 2 and 3, we have demonstrated how to use scDesign2 to guide experimental design and benchmark computational methods for the tasks of cell clustering and rare cell type detection. Note that in these analyses, the optimized sequencing depths and cell numbers are only applicable to the same experimental protocols and biological samples. Yet, this limitation does not disqualify scDesign2 as a useful tool to guide experimental design. For example, researchers usually perform a coarsegrained, lowbudget experiment to obtain a preliminary dataset, and then they may use scDesign2 to guide the optimal design of the later, more refined experiment. As another example, if scRNAseq data need to be collected from many individuals, researchers usually first perform a pilot study on a small number of individuals. Then, they may train scDesign2 using the pilot data to guide the design of the subsequent, largescale experiments. In addition to guiding the experimental design, scDesign2 is useful as a general benchmarking tool for various experimental protocols and computational methods. For example, the analyses we performed in applications 2 and 3 are easily generalizable to other computational methods for a more comprehensive benchmarking.
Although we only use cell clustering and rare cell type detection to demonstrate scDesign2’s use in guiding experimental design and benchmarking computational methods, we want to emphasize that scDesign2 has broad applications beyond these two tasks. Inheriting the flexible and transparent modeling nature of our previous simulator scDesign, scDesign2 can also benchmark other computational analyses we have demonstrated in our scDesign paper [35], including differential gene expression analysis and cell dimensionality reduction. Moreover, beyond its role as a simulator, scDesign2 may benefit singlecell gene expression data analysis by providing its estimated parameters about gene expression and gene correlations. Here, we discuss three potential directions. First, scDesign2 can assist differential gene expression analysis. Its estimated marginal distributions of individual genes in different cell types can be used to investigate more general patterns of differential expression (such as different variances and different zero proportions), in addition to comparing gene expression means between two groups of cells [104]. Second, its estimated gene correlation structures can be used to construct cell typespecific gene networks [105] and incorporated into gene set enrichment analysis to enhance statistical power [106, 107]. Third, scDesign2 has the potential to improve the alignment of cells from multiple singlecell datasets [108]. Its estimated gene expression parameters can guide the calculation of cell type or cluster similarities between batches, and its estimated gene correlation structures can be used to align cell types or clusters across batches based on the similarity in gene correlation structures. [109].
Methods
The statistical framework of scDesign2
Fitting a generative model of singlecell gene expression count data with gene correlations
Given an scRNAseq count matrix \(\mathbf {X}\in \mathbb {N}^{p\times n}\) with p genes and n cells, we assume that the n cells belong to K cell types and that the cell memberships have been assigned by clustering, labeled by marker genes, or known in advance. (For input data without predefined cell types, our recommendation for cell clustering is in two subsections.) Our goal is to fit a parametric count model to characterize the joint distribution of genes’ counts in each cell type. For cell type k, we denote its number of cells by n^{(k)}, its count submatrix by X^{(k)}, and its set of model parameters by Θ^{(k)}, k=1,…,K. For simplicity of notation, we drop the superscript (k) in the following discussion about the generative model for one single cell type.
We denote \(X_{\cdot j} = (X_{1j},\ldots,X_{pj})^{\mathsf {T}} \in \mathbb {R}^{p}\) as a random pdimensional gene count vector in cell j, j=1,…,n. We denote its realization, i.e., the observed gene count vector as the jth column in X, by x_{·j}=(x_{1j},…,x_{pj})^{T}. Jointly for the p genes, we assume that X_{·j} independently follows a pdimensional distribution F, which we will specify by a copula in the next paragraph. Marginally for each gene i, we assume that X_{ij} independently follows a univariate count distribution F_{i}. For example, if F_{i} is the ZINB distribution, we write \(X_{ij} \overset {\text {ind}}\sim \text {ZINB}(p_{i}, \psi _{i}, \mu _{i})\), which can be interpreted as a hierarchical model: (1) \(Z_{ij} \overset {\text {ind}}\sim \text {Ber}(p_{i})\) is a hidden latent variable indicating whether gene i drops out in cell j; (2) \(X_{ij}  Z_{ij} \overset {\text {ind}}\sim 1_{0} Z_{ij} + \text {NB}(\psi _{i}, \mu _{i}) (1Z_{ij})\), where 1_{0} indicates a point mass at 0. That is,
Note that the Z_{ij}’s are unobserved and introduced only to describe the zeroinflation component. The Poisson, the zeroinflated Poisson (ZIP), and the negative binomial (NB) distributions are three special cases of the ZINB distribution, where p_{i}=0 for Poisson and NB, and ψ_{i}=∞ for Poisson and ZIP. From these four distributions, scDesign2 automatically chooses the one that best fits to gene i’s observed counts. Specifically, for the ith row of X, x_{i·}=(x_{i1},…,x_{in})^{T}, if its sample mean \(\bar x_{i \cdot } = n^{1}\sum _{j=1}^{n} x_{ij} \ge \) its sample variance \(\hat \sigma _{i}^{2} = (n1)^{1}\sum _{j=1}^{n}(x_{ij}  x_{i \cdot })^{2}\), i.e., there is no overdispersion, scDesign2 fits the Poisson and the ZIP distributions separately to x_{i·} by maximum likelihood estimation (MLE), and then performs a likelihood ratio test with \(\chi _{1}^{2}\) as the null distribution to determine if zeroinflation is significant, i.e., the ZIP distribution should be chosen over the Poisson distribution. Otherwise if there is overdispersion, i.e., \(\bar x_{i\cdot } < \hat \sigma _{i}^{2}\), scDesign2 fits the NB and the ZINB distributions separately to x_{i·} by MLE and then performs a likelihood ratio test with \(\chi _{1}^{2}\) as the null distribution to determine if zeroinflation is significant, i.e., the ZINB distribution should be chosen over the NB distribution. The default significance level (i.e., p value cutoff) for both tests is 0.05.
After estimating the marginal distributions of the p genes, i.e., F_{1},…,F_{p}, scDesign2 uses a copula to model the joint pdimensional distribution F. A copula is defined as a joint cumulative distribution function (CDF), C(·) : [0,1]^{p}→[0,1], which includes p uniform marginal distributions on [0,1]. That is, C is the CDF of a random vector U=(U_{1},…,U_{p})^{T}∈[0,1]^{p}, with U_{i}∼Uniform[0,1], i=1,…,p. For cell j’s gene count vector \(X_{\cdot j}\in \mathbb {R}^{p}\), although its ith component X_{ij} may not follow the Uniform[0,1] distribution, we can transform X_{ij} by applying the marginal CDF F_{i} so that F_{i}(X_{ij})∼Uniform[0,1]. This allows us to write the joint CDF F as:
which is decomposable into the copula C and the marginal distributions F_{1},…,F_{p}. Sklar’s theorem states that such a decomposition exists uniquely for any continuous distribution F [110]. If F is discrete in any dimension, the copula C still exists but may not be unique, i.e., not identifiable [111, 112]. To resolve this unidentifiability issue, scDesign2 uses the technique of distributional transform [113]: first draw V_{ij}∼Uniform[0,1] independently for i=1,…,p and j=1,…,n; second define U_{ij} as:
The effect of this transform is illustrated in Additional file 1: Figure S47. Essentially, for a discrete random variable X_{ij} with CDF F_{i}, this transform distributes the nonzero probability mass X_{ij} has at every value x uniformly to the interval [x,x+1), thus transforming the discrete CDF F_{i} to a continuous CDF F ~_{i} as:
where ⌊y⌋ denotes the largest integer no greater than y.
With V_{ij} and X_{ij}, if we define:
then the probability density function of X ~_{ij} is:
and the CDF of X ~_{ij} is:
Hence, \(\tilde {X}_{ij} \sim \Tilde {F}_{i}\); that is, the continuous random variable \(\tilde {X}_{ij}\) constructed from X_{ij} and V_{ij} follows \(\tilde {F}_{ij}\). Defining U_{ij}=F ~_{i}(X ~_{ij}), we have U_{ij}∼Uniform[0,1] and:
which is (1). This proves that U_{ij} constructed by (1) follows Uniform[0,1] and is thus desirable.
After this transform, the CDF F of X_{·j} is defined as the copula C of U_{·j}=(U_{1j},…,U_{pj})^{T}:
where (u_{1j},…,u_{pj})^{T} is a realization of (U_{1j},…,U_{pj})^{T}. In scDesign2, we choose C as the Gaussian copula. Denoting by Φ the CDF of a standard Gaussian distribution, we define F as:
where Φ_{p}(·;R) is the CDF of a pdimensional Gaussian distribution with a zero mean vector and a covariance matrix that is equal to the correlation matrix R. If we denote R_{hl} as the Gaussian copula correlation between genes h and l, i.e., the (h,l)th entry of R, and τ_{hl} as the Kendall’s tau between the same two genes on the original scale, i.e., τ_{hl}=τ(X_{hj},X_{lj}), then we have the following relationship [114, 115]:
This relationship links the copula correlation with the Kendall’s tau of the two original variables, thus providing an interpretation of the copula correlation. It also suggests that R can be estimated by plugging the sample tau matrix into the above formula; however, this estimate of R may not always be positive semidefinite [116, 117]. Therefore, we use another procedure to estimate R.
Denote by \((\hat {p}_{i}, \hat {\psi }_{i}, \hat {\mu }_{i})\) the estimated parameters of F_{i}, which specify a fitted marginal distribution \(\widehat {F}_{i}\). We sample \(v^{*}_{ij}\) from Uniform[0,1] independently for i=1,…,p and j=1,…,n, and we calculate \(u^{*}_{ij}\) as:
Then, we estimate R by the sample covariance matrix \(\widehat {\mathbf {R}}\) of \(\left (\Phi ^{1}(u^{*}_{1j}), \ldots, \Phi ^{1}(u^{*}_{pj})\right)^{\mathsf {T}}\), j=1,…,n.
As a side note, since this estimation procedure requires the random sampling of \(v^{*}_{ij}\)’s, it introduces additional randomness into the estimation of R; that is, \(\widehat {\mathbf {R}}\) is not a deterministic function of data. However, this additional randomness has a negligible effect on the synthetic data. As demonstrated in Additional file 1: Figure S48, the gene correlation matrices estimated from synthetic data generated by scDesign2, with \(\widehat {\mathbf {R}}\) estimated under two different random samples of \(v^{*}_{ij}\)’s, are very similar to each other.
To summarize, scDesign2 first estimates the marginal distributions F_{1},…,F_{p} as \(\widehat F_{1}, \ldots, \widehat F_{p}\), each of which may be a fitted Poisson, ZIP, NB, or ZINB distribution. Then, scDesign2 calculates \(u^{*}_{ij}\)’s as described above and estimates a p×p covariance matrix as \(\widehat {\mathbf {R}}\). Finally, scDesign2 estimates the pdimensional joint distribution F as:
whose estimated model parameters are \(\widehat \Theta = \{\hat p_{1}, \hat \psi _{1}, \hat \mu _{1}, \ldots, \hat p_{p}, \hat \psi _{p}, \hat \mu _{p}, \widehat {\mathbf {R}}\}\).
As a practical note, since the data matrix X typically contains tens of thousands of genes, if the sample size, i.e., the number of cells is not large enough, the estimation of the copula correlation matrix can be problematic [97]. Moreover, many genes are too lowly expressed to be detected in scRNAseq data, making their correlations uninteresting to estimate. For these two reasons, we argue that the copula correlations should only be estimated for a subset of moderately to highly expressed genes.
In Additional file 1: Figures S42 and S43, we analyze how n (the sample size, i.e., the number of cells) and p (the number of top expressed genes included) affect the estimation of the copula correlation matrix. We use two example datasets: the stem cell data generated by the 10x Genomics protocol and the dendrocyte (subtype 1) data generated by the SmartSeq2 protocol. For each dataset, we extract the fitted Gaussian copula model for the top 2000 genes with the highest mean expression levels, and we use this model as the ground truth model to generate 1000 samples with a varying n. Then, we estimate the copula correlation matrix of a varying p from each sample. For computational efficiency, we use the plugin estimation method based on sample tau values: \(\hat {R}_{hl} = \sin {(\frac {\pi }{2}\hat {\tau }_{hl})}\). Finally, we calculate the mean squared error (MSE) between the estimated copula correlations and the true copula correlations. That is, for each n and p, we have 1000 MSE values.
In Additional file 1: Figures S42 and S43, from panel (a), we can see that MSEs decrease as n increases. From panel (b), we can see that MSEs increase as p increases, i.e., more lowly expressed genes are included. To ease the interpretation of the results, we mark three horizontal lines at MSE =0.09, 0.04, and 0.01 to represent three levels of estimation quality. On the scale of correlation values, these three levels indicate that on average the estimated values are within ±0.3, ±0.2, and ±0.1 of the true values. The results suggest that to reach the ±0.3 level of estimation quality, a reasonable choice of n is at least 20, and the top 1000 highly expressed genes can be included. To reach the ±0.2 level, a reasonable choice of n is at least 50, and the top 1500 highly expressed genes can be included. For n= 100, the ±0.1 level can be reached for the top 100–200 highly expressed genes, and even the error level for the top 2000 is close to this level. The results confirm that sample size is not a concern for singlecell data because most cell types contain at least a hundred cells that can be measured by current protocols.
In the implementation of the scDesign2 R package, before fitting the above generative model for each cell type, scDesign2 partitions the genes into three groups: the first group containing genes with zero proportions less than a cutoff (default 0.8, but can be changed according to the discussion above), the second group containing genes with zero proportions between the cutoff and (n−2)/n, where n is the number of cells, and the last group including the remaining genes, i.e., genes expressed in fewer than three cells. For the first group, scDesign2 fits the above generative model jointly for its genes. For the second group, scDesign2 fits a marginal distribution for each individual gene. For the last group, scDesign2 only generates zero counts for all its genes.
Generation of synthetic singlecell gene expression count data
To generate synthetic scRNAseq data for K cell types, scDesign2 first estimates the proportions of K cell types from the real scRNAseq count matrix X, for which we denote the number of reads mapped to the n^{(k)} cells of type k as N^{(k)}, and the total number of reads mapped to all the n cells as \(N=\sum _{k=1}^{K} N^{(k)}\). Denoting the cell type proportions as π=(π^{(1)},…,π^{(K)})^{T} such that \(\sum _{k=1}^{K} \pi ^{(k)} = 1\), scDesign2 estimates them by \(\hat \pi =(\hat \pi ^{(1)},\ldots,\hat \pi ^{(K)})^{\mathsf {T}}\), where:
We denote the synthetic scRNAseq data to be generated as X^{′}, which contains n^{′} cells and N^{′} expected number of reads, with n^{′} and N^{′} as userspecified input parameters of scDesign2. Denoting the number of synthetic cells of type k as n^{(k)′}, scDesign2 draws the numbers of synthetic cells of all K cell types from a multinomial distribution, i.e., \((n^{(1)^{\prime }},\ldots,n^{(K)^{\prime }})^{\mathsf {T}} \sim \text {Multinomial}(n^{\prime },\hat {\pi })\). Then, given \(\phantom {\dot {i}\!}n^{(k)^{\prime }}\), the expected number of reads assigned to cell type k in X^{′} should be:
However, given the constraint that the expected total number of reads in X^{′} is N^{′}, we need to rescale N^{(k)0} to:
As a result, the scaling factor is:
which does not depend on the cell type, and scDesign2 uses this scaling factor to rescale the mean parameter of every gene.
Given the fitted generative model \(\widehat F^{(k)}\) for cell type k with parameters:
and the scaling factor r, scDesign2 generates n^{(k)′} synthetic cells from a rescaled model \(\widehat F^{(k)\prime }\), which is defined by parameters:
Concretely, how the data generation works is that scDesign2 first draws n^{(k)′} vectors, denoted as \(z_{\cdot j}^{(k)\prime } \in \mathbb{R}^{p}\); j=1,…,n^{(k)′}, independently from \(\Phi _{p}(\cdot ;\widehat {\mathbf {R}}^{(k)})\). Then, scDesign2 converts \(z_{ij}^{(k)\prime }\) to \(x_{ij}^{(k)\prime }\) by setting \(x_{ij}^{(k)\prime }\) to be the \(\Phi (z_{ij}^{(k)\prime })\)th quantile of \(\widehat {F}_{i}^{(k)\prime }\), i.e., \(\text {ZINB}(\hat {p}_{i}^{(k)},\hat {\psi }_{i}^{(k)}, r\hat {\mu }_{i}^{(k)})\) (including the Poisson, ZIP, and NB distributions as special cases), i=1,…,p. Finally, scDesign2 outputs the synthetic count matrix \(\phantom {\dot {i}\!}\mathbf {X}^{\prime } = [\mathbf {X}^{(1)\prime } \cdots \mathbf {X}^{(K)\prime }]\), where \(\mathbf {X}^{(k)\prime } = (x_{ij}^{(k)\prime })\) is a p×n^{(k)′} matrix for cell type k.
Note that the synthetic count matrix X^{′} does not contain exactly N^{′} reads; rather, N^{′} is the expected total number of reads. We think this setting mimics a real sequencing experiment, where the total number of sequenced reads would not be exactly the same as the preset sequencing depth N^{′} due to experimental randomness.
Recommendation for cell clustering when input data do not have labeled cell types
If users would like to train scDesign2 on a genebycell count matrix without cell type labels, a necessary preceding step is cell clustering. We recommend users to choose a stateoftheart cell clustering method such as Seurat and SC3. For the resulting clusters, we recommend users to visualize them by tSNE or UMAP and use a goodnessoffit measure (e.g., Pearson’s chisquare statistic and ROGUE score [87]) to check whether each gene approximately follows a NB or ZINB distribution in a cell cluster. This check will guide users to decide on an appropriate number of cell clusters in a datadriven way.
The scDesign2 variant without copula
The only difference between this variant “w/o copula” and scDesign2 is that this variant assumes the p genes to have independent marginal distributions F_{1},…,F_{p}. The fitting of the p marginal distributions and the generation of synthetic data is the same as those in scDesign2.
Existing simulators

scDesign: The R package scDesign version 1.0.0 is used for the analysis.

scGAN: This method is executed from this github repository https://github.com/imsbuke/scGAN, downloaded around March 29, 2020.

splat, splat simple, kersplat: These methods are executed from the R packge splatter version 1.10.1.

SPARSim: The R package SPARSim version 0.9.5 is used for the analysis.

SymSim: The R package SymSim version 0.0.0.9000 is used for the analysis.

ZINBWaVE: The ZINBWaVE method is used from the wrapper functions in the R package splatter version 1.10.1.

SPsimSeq: The R package SPsimSeq version 0.99.13 is used for the analysis.
Cell type/cluster refining method

ROGUE: The R package ROGUE version 1.0 is used for the analysis.
Dimensionality reduction methods

tSNE: The R package Rtsne version 0.15 is used for generating tSNE plots. The function Rtsne is used, with all parameters set to default, except check_duplicate = FALSE and perplexity is changed from the default value of 30 to one third of the sample size when the sample size (total number of cells) is less than 90.

PCA: The R function prcomp() is used for generating PCA plots, with parameters set as default.
Cell clustering methods

Seurat: The Seurat clustering method is executed by the following instruction in this tutorial https://satijalab.org/seurat/v3.2/pbmc3k_tutorial.html. R package Seurat version 3.1.5 is used for the analysis.

SC3: The SC3 clustering method is executed by the following instruction in this tutorial https://www.bioconductor.org/packages/release/bioc/vignettes/SC3/inst/ doc/SC3.html. R package SC3 version 1.14.0 is used for the analysis.
Rare cell type detection methods

FiRE: The FiRE method is executed by the following instruction in this tutorial https://github.com/princethewinner/FiRE. R package FiRE version 1.0 is used for the analysis.

GiniClust2: This method is executed from this github repository https://github.com/dtsoucas/GiniClust2downloaded around March 4, 2020. It is executed based on the reference manual in this repository, except no cells are filtered.
Availability of data and materials
∙10x Genomics: The 10x Genomics dataset measures the mouse intestinal epithelial tissue [83]. The raw count dataset is downloaded from Gene Expression Omnibus (GEO) with accession number GSE92332. Data for cell types Stem, Goblet, Tuft, Transit Amplifying Early (TA Early), Enterocyte Progenitor, and Enterocyte Progenitor Early were selected for analysis. Spikein RNA counts were filtered. The resulting count matrix contains 15962 genes and 3793 cells.
∙CELSeq2: The CELSeq2 dataset measures the human pancreas [84]. The raw count dataset is downloaded from GEO with accession number GSE85241. Data for cell types alpha, beta, acinar, delta, duct, endothelial, mesenchymal, and pancreatic polypeptide cell (pp) were selected for analysis. Spikein RNA counts were filtered. The resulting count matrix contains 19049 genes and 2279 cells.
∙Fluidigm C1: The Fluidigm C1 dataset measures human brain cells [85]. The raw count dataset is downloaded from GEO with accession number GSE67835. Data for cell types astrocytes, endothelial, fetal quiescent, hybrid neurons, oligodendrocytes, and oligodendrocyte precursor cell (OPC) were selected for analysis. The resulting count matrix contains 22,088 genes and 317 cells.
∙SmartSeq2: The SmartSeq2 dataset measures human blood dendritic cells [4]. The raw count dataset is downloaded from GEO with accession number GSE94820. Data for dendrocyte subtypes 1–6 and monocyte subtypes 1–4 were selected for analysis. Spikein RNA counts were filtered. The resulting count matrix contains 26,586 genes and 1078 cells.
∙MERFISH: The MERFISH dataset measures the mouse hypothalamic preoptic region [91]. The raw count dataset is downloaded from Dryad (https://datadryad.org/stash/dataset/doi:10.5061/dryad.8t8s248). It contains 155 genes and 6412 cells. Cell subtypes are combined into cell types, e.g., “Endothelial 1” and “Endothelial 2” are combined as “Endothelial,” resulting in nine cell types in total.
∙pciSeq: The pciSeq dataset measures the mouse hippocampal area CA1 [92]. The raw data “cells_left_CA1_31” are downloaded from https://su.figshare.com/articles/pciSeq_files_in_csv_format/10318610/1. Gene expression values are rounded as integers, and cell subtypes are combined into cell types, e.g., “Astro.1” to “Astro.5” are combined as “Astro.” The cell type “Zero” is removed as it contains cells with almost no genes expressed, so seven cell types are retained. The processed data contain 84 genes and 2253 cells.
∙Software and code: The scDesign2 R package is available at https://github.com/JSBUCLA/scDesign2 [118]. The source code and data for reproducing the results are available at https://doi.org/10.5281/zenodo.4011311[119]. Both the R package and the source code are under the MIT license.
Change history
09 June 2021
A Correction to this paper has been published: https://doi.org/10.1186/s1305902102394z
Notes
 1.
 2.
A quote from the SERGIO paper [76]: “It is worth noting here that several existing singlecell expression simulators employ a probabilistic model whose parameters are directly estimated from a real dataset and then sample synthetic data from the model. This approach is not feasible in SERGIO since the true GRN underlying the real dataset is unknown and notoriously hard to reconstruct, and the explicit use of a GRN is a crucial distinguishing feature of SERGIO. As such, SERGIO uses a randomly generated GRN to first synthesize clean expression data and uses the real dataset only in the second phase, to determine the extent of technical noise to add to the clean data.”
 3.
The training of scGAN takes 1–2 days (with NVIDIA GeFore GTX 2080 Ti GPU) on 255 cells and 15,926 genes, in contrast to the other simulators that take at most minutes to train with CPU.
References
 1
Haque A, Engel J. Sarah A Teichmann, and Tapio Lönnberg. A practical guide to singlecell RNAsequencing for biomedical research and clinical applications. Genome Med. 2017; 9(1):1–12.
 2
Kiselev VY, Andrews TS, Hemberg M. Challenges in unsupervised clustering of singlecell RNAseq data. Nat Rev Genet. 2019; 20(5):273–82.
 3
Li WV, Li JJ. Modeling and analysis of RNAseq data: a review from a statistical perspective. Quant Biol. 2018; 6:195–209. https://doi.org/10.1007/s4048401801447.
 4
Villani AC, Satija R, Reynolds G, Sarkizova S, Shekhar K, Fletcher J, Griesbeck M, Butler A, Zheng S, Lazo S, et al.Singlecell RNAseq reveals new types of human blood dendritic cells, monocytes, and progenitors. Science. 2017a; 356(6335):eaah4573.
 5
Steven Potter S. Singlecell RNA sequencing for the study of development, physiology and disease. Nat Rev Nephrol. 2018; 14(8):479–92.
 6
Birnbaum KD. Power in numbers: singlecell RNAseq strategies to dissect complex tissues. Ann Rev Genet. 2018; 52:203–21.
 7
Strunz M, Simon LM, Ansari M, Kathiriya JJ, Angelidis I, Mayr CH, Tsidiridis G, Lange M, Mattner LF, Yee M, et al.Alveolar regeneration through a krt8+ transitional stem cell state that persists in human lung fibrosis. Nat Commun. 2020; 11(1):1–20.
 8
Karacosta LG, Anchang B, Ignatiadis N, Kimmey SC, Benson JA, Shrager JB, Tibshirani R, Bendall SC, Plevritis SK. Mapping lung cancer epithelialmesenchymal transition states and trajectories with singlecell resolution. Nat Commun. 2019; 10(1):1–15.
 9
Bergen V, Lange M, Peidli S, Alexander Wolf F, Theis FJ. Generalizing RNA velocity to transient cell states through dynamical modeling. Nat Biotechnol. 2020; 38:1408–14.
 10
Petropoulos S, Edsgärd D, Reinius B, Deng Q, Panula SP, Codeluppi S, Reyes AP, Linnarsson S, Sandberg R, Lanner F. Singlecell RNAseq reveals lineage and x chromosome dynamics in human preimplantation embryos. Cell. 2016; 165(4):1012–26.
 11
Chu LF, Leng N, Zhang J, Hou Z, Mamott D, Vereide DT, Choi J, Kendziorski C, Stewart R, Thomson JA. Singlecell RNAseq reveals novel regulators of human embryonic stem cell differentiation to definitive endoderm. Genome Biol. 2016; 17(1):173.
 12
Skene NG, Bryois J, Bakken TE, Breen G, Crowley JJ, Gaspar HA, GiustiRodriguez P, Hodge RD, Miller JA, MuñozManchado AB, et al.Genetic identification of brain cell types underlying schizophrenia. Nat Genet. 2018; 50(6):825–33.
 13
Li Q, Cheng Z, Zhou L, Darmanis S, Neff NF, Okamoto J, Gulati G, Bennett ML, Sun LO, Clarke LE, et al.Developmental heterogeneity of microglia and brain myeloid cells revealed by deep singlecell RNA sequencing. Neuron. 2019; 101(2):207–23.
 14
Tirosh I, Izar B, Prakadan SM, Wadsworth MH, Treacy D, Trombetta JJ, Rotem A, Rodman C, Lian C, Murphy G, et al.Dissecting the multicellular ecosystem of metastatic melanoma by singlecell RNAseq. Science. 2016; 352(6282):189–96.
 15
Chung W, Eum HH, Lee HO, Lee KM, Lee HB, Kim KT, Ryu HS, Kim S, Lee JE, Park YH, et al.Singlecell RNAseq enables comprehensive tumour and immune cell profiling in primary breast cancer. Nat Commun. 2017; 8(1):1–12.
 16
Tang F, Barbacioru C, Wang Y, Nordman E, Lee C, Xu N, Wang X, Bodeau J, Tuch BB, Siddiqui A, et al.mRNAseq wholetranscriptome analysis of a single cell. Nat Methods. 2009; 6(5):377–82.
 17
Kolodziejczyk AA, Kim JK, Svensson V, Marioni JC, Teichmann SA. The technology and biology of singlecell RNA sequencing. Mol Cell. 2015; 58(4):610–620.
 18
Zhang X, Li T, Liu F, Chen Y, Yao J, Li Z, Huang Y, Wang J. Comparative analysis of dropletbased ultrahighthroughput singlecell RNAseq systems. Mol Cell. 2019a; 73(1):130–42.
 19
Chen G, Ning B, Shi T. Singlecell RNAseq technologies and related computational data analysis. Front Genet. 2019; 10:317.
 20
Ding J, Adiconis X, Simmons SK, Kowalczyk MS, Hession CC, Marjanovic ND, Hughes TK, Wadsworth MH, Burks T, Nguyen LT, et al.Systematic comparison of singlecell and singlenucleus RNAsequencing methods. Nat Biotechnol. 2020; 38:737–46.
 21
Zheng GXY, Terry JM, Belgrader P, Ryvkin P, Bent ZW, Wilson R, Ziraldo SB, Wheeler TD, Mcdermott GP, Zhu J, et al.Massively parallel digital transcriptional profiling of single cells. Nat Commun. 2017; 8(1). https://doi.org/10.1038/ncomms14049.
 22
Hashimshony T, Senderovich N, Avital G, Klochendler A, De Leeuw Y, Anavy L, Gennert D, Li S, Livak KJ, RozenblattRosen O, et al.Celseq2: sensitive highlymultiplexed singlecell RNAseq. Genome Biol. 2016; 17(1):4. https://doi.org/10.1186/s1305901609388.
 23
Macosko EZ, Basu A, Satija R, Nemesh J, Shekhar K, Goldman M, Tirosh I, Bialas AR, Kamitaki N, Martersteck EM, et al.Highly parallel genomewide expression profiling of individual cells using nanoliter droplets. Cell. 2015; 161(5):1202–14.
 24
Gierahn TM, Wadsworth II MH, Hughes TK, Bryson BD, Butler A, Satija R, Fortune S, Love CJ, Shalek AK. Seqwell: portable, lowcost RNA sequencing of single cells at high throughput. Nat Methods. 2017; 14(4):395–8.
 25
Picelli S, Faridani OR, Björklund ÅK, Winberg G, Sagasser S, Sandberg R. Fulllength RNAseq from single cells using smartseq2. Nat Protoc. 2014; 9(1):171–81. https://doi.org/10.1038/nprot.2014.006.
 26
Pollen AA, Nowakowski TJ, Shuga J, Wang X, Leyrat AA, Lui JH, Li N, Szpankowski L, Fowler B, Chen P, et al.Lowcoverage singlecell mRNA sequencing reveals cellular heterogeneity and activated signaling pathways in developing cerebral cortex. Nat Biotechnol. 2014; 32(10):1053–8. https://doi.org/10.1038/nbt.2967.
 27
Sheng K, Cao W, Niu Y, Deng Q, Zong C. Effective detection of variation in singlecell transcriptomes using matqseq. Nat Methods. 2017; 14(3):267–70.
 28
Kulkarni A, Anderson AG, Merullo DP, Konopka G. Beyond bulk: a review of single cell transcriptomics methodologies and applications. Curr Opin Biotechnol. 2019; 58:129–36.
 29
Svensson V, VentoTormo R, Teichmann SA. Exponential scaling of singlecell RNAseq in the past decade. Nat Protoc. 2018a; 13(4):599–604.
 30
Kivioja T, Vähärautio A, Karlsson K, Bonke M, Enge M, Linnarsson S, Taipale J. Counting absolute numbers of molecules using unique molecular identifiers. Nat Methods. 2012; 9(1):72–4.
 31
Svensson V, Natarajan KN, Ly LH, Miragaia RicardoJ, Labalette Charlotte, Macaulay IainC, Cvejic Ana, Teichmann SarahA. Power analysis of singlecell RNAsequencing experiments. Nat Methods. 2017; 14(4):381–7.
 32
Ziegenhain C, Vieth B, Parekh S, Reinius B, GuillaumetAdkins A, Smets M, Leonhardt H, Heyn H, Hellmann I, Enard W. Comparative analysis of singlecell RNA sequencing methods. Mol Cell. 2017; 65(4):631–43.
 33
Molin AD, Camillo BD. How to design a singlecell rnasequencing experiment: pitfalls, challenges and perspectives. Brief Bioinforma. 2019; 20(4):1384–94.
 34
Zhang MJ, Ntranos V, Tse D. Determining sequencing depth in a singlecell RNAseq experiment. Nat Commun. 2020; 11(1):1–11.
 35
Li WV, Li JJ. A statistical simulator scdesign for rational scRNAseq experimental design. Bioinformatics. 2019; 35(14):i41–i50. https://doi.org/10.1093/bioinformatics/btz321.
 36
Li WV, Li JJ. An accurate and robust imputation method scimpute for singlecell RNAseq data. Nat Commun. 2018; 9(1):1–9.
 37
Yungang Xu, Zhang Z, You L, Liu J, Fan Z, Zhou X. scigans: singlecell RNAseq imputation using generative adversarial networks. Nucleic Acids Res. 2020; 48(15):e85.
 38
Pierson E, Zifa CY. Dimensionality reduction for zeroinflated singlecell gene expression analysis. Genome Biol. 2015; 16(1):1–10.
 39
Risso D, Perraudeau F, Gribkova S, Dudoit S, Vert JP. A general and flexible method for signal extraction from singlecell RNAseq data. Nat Commun. 2018; 9(1). https://doi.org/10.1038/s41467017025545.
 40
Sun S, Zhu J, Ma Y, Zhou X. Accuracy, robustness and scalability of dimensionality reduction methods for singlecell RNAseq analysis. Genome Biol. 2019; 20(1):269.
 41
Kiselev VY, Kirschner K, Schaub MT, Andrews T, Yiu A, Chandra T, Natarajan KN, Reik W, Barahona M, Green AR, et al.Sc3: consensus clustering of singlecell RNAseq data. Nat Methods. 2017; 14(5):483–6. https://doi.org/10.1038/nmeth.4236.
 42
Stuart T, Butler A, Hoffman P, Hafemeister C, Papalexi E, Mauck III WM, Hao Y, Stoeckius M, Smibert P, Satija R. Comprehensive integration of singlecell data. Cell. 2019; 177:1888–902. https://doi.org/10.1016/j.cell.2019.05.031.
 43
Tan Y, Cahan P. Singlecellnet: a computational tool to classify single cell RNAseq data across platforms and across species. Cell Syst. 2019; 9(2):207–13.
 44
Pliner HA, Shendure J, Trapnell C. Supervised classification enables rapid annotation of cell atlases. Nat Methods. 2019; 16(10):983–6.
 45
Johansen N, Quon G. scalign: a tool for alignment, integration, and rare cell identification from scRNAseq data. Genome Biol. 2019; 20(1):1–21.
 46
Tsoucas D, Yuan GC. Giniclust2: a clusteraware, weighted ensemble clustering method for celltype detection. Genome Biol. 2018; 19(1):58.
 47
Jindal A, Gupta P, Sengupta J, Sengupta D. Discovery of rare cells from voluminous single cell expression data. Nat Commun. 2018; 9(1). https://doi.org/10.1038/s41467018072346.
 48
Song D, Li JJ. PseudotimeDE: inference of differential gene expression along cell pseudotime with wellcalibrated pvalues from singlecell RNA sequencing data. Genome Biol. 2021; 22(1):1–25.
 49
Kharchenko PV, Silberstein L, Scadden DT. Bayesian approach to singlecell differential expression analysis. Nat Methods. 2014; 11(7):740–2.
 50
Finak G, McDavid A, Yajima M, Deng J, Gersuk V, Shalek AK, Slichter CK, Miller HW, McElrath MJ, Prlic M, et al.Mast: a flexible statistical framework for assessing transcriptional changes and characterizing heterogeneity in singlecell RNA sequencing data. Genome Biol. 2015; 16(1):1–13.
 51
Soneson C, Robinson MD. Bias, robustness and scalability in singlecell differential expression analysis. Nat Methods. 2018; 15(4):255.
 52
Van den Berge K, De Bezieux HR, Street K, Saelens W, Cannoodt R, Saeys Y, Dudoit S, Clement L. Trajectorybased differential expression analysis for singlecell sequencing data. Nature Commun. 2020; 11(1):1–13.
 53
Trapnell C, Cacchiarelli D, Grimsby J, Pokharel P, Li S, Morse M, Lennon NJ, Livak KJ, Mikkelsen TS, Rinn JL. The dynamics and regulators of cell fate decisions are revealed by pseudotemporal ordering of single cells. Nat Biotechnol. 2014; 32(4):381.
 54
Ji Z, Tscan HJ. Pseudotime reconstruction and evaluation in singlecell rnaseq analysis. Nucleic Acids Res. 2016; 44(13):e117–e117.
 55
Qiu X, Qi M, Tang Y, Li W, Chawla R, Pliner HA, Trapnell C. Reversed graph embedding resolves complex singlecell trajectories. Nat Methods. 2017; 14(10):979.
 56
Street K, Risso D, Fletcher RB, Das D, Ngai J, Yosef N, Purdom E, Dudoit S. Slingshot: cell lineage and pseudotime inference for singlecell transcriptomics. BMC Genomics. 2018; 19(1):477.
 57
Cao J, Spielmann M, Qiu X, Huang X, Ibrahim DM, Hill AJ, Zhang F, Mundlos S, Christiansen L, Steemers FJ, et al.The singlecell transcriptional landscape of mammalian organogenesis. Nature. 2019; 566(7745):496–502.
 58
Saelens W, Cannoodt R, Todorov H, Saeys Y. A comparison of singlecell trajectory inference methods. Nature Biotechnol. 2019; 37(5):547–54.
 59
Tian L, Dong X, Freytag S, Le Cao KA, Su S, JalalAbadi A, AmannZalcenstein D, Weber TS, Seidi A, Jabbari JS, et al.Benchmarking single cell RNAsequencing analysis pipelines using mixture control experiments. Nat Methods. 2019; 16(6):479–87.
 60
Duò A, Robinson MD, Soneson C. A systematic performance evaluation of clustering methods for singlecell RNAseq data. F1000Research. 2018; 7:1141.
 61
Wang T, Li B, Nelson CE, Nabavi S. Comparative analysis of differential gene expression analysis tools for singlecell RNA sequencing data. BMC Bioinforma. 2019; 20(1):40.
 62
Hou W, Ji Z, Ji H, Hicks SC. A systematic evaluation of singlecell RNAsequencing imputation methods. bioRxiv. 2020; 21(1):1–30.
 63
Li WV, Li JJ. Issues arising from benchmarking singlecell RNA sequencing imputation methods. arXiv preprint arXiv:1908.07084. 2019.
 64
van der Maaten L, Hinton G. Visualizing data using tSNE. J Mach Learn Res. 2008; 9(Nov):2579–2605.
 65
Van Der Maaten L. Accelerating tsne using treebased algorithms. J Mach Learn Res. 2014; 15(1):3221–45.
 66
McInnes L, Healy J, Umap JM. Uniform manifold approximation and projection for dimension reduction. arXiv preprint arXiv:1802.03426. 2018.
 67
Becht E, McInnes L, Healy J, Dutertre CA, Kwok IWH, Ng LG, Ginhoux F, Newell EW. Dimensionality reduction for visualizing singlecell data using umap. Nat Biotechnol. 2019; 37(1):38–44.
 68
Papadopoulos N, Gonzalo PR, Söding J. Prosstt: probabilistic simulation of singlecell RNAseq data for complex differentiation processes. Bioinformatics. 2019; 35(18):3517–9. https://doi.org/10.1093/bioinformatics/btz078.
 69
Zappia L, Phipson B, Oshlack A. Splatter: simulation of singlecell RNA sequencing data. Genome Biol. 2017; 18(1). https://doi.org/10.1186/s1305901713050.
 70
Zhang X, Xu C, Yosef N. Simulating multiple faceted variability in single cell RNA sequencing. Nat Commun. 2019b; 10(1). https://doi.org/10.1038/s4146701910500w.
 71
Baruzzo G, Patuzzi I, Di Camillo B. Sparsim single cell: a count data simulator for scRNAseq data. Bioinformatics. 2019. https://doi.org/10.1093/bioinformatics/btz752.
 72
Marouf M, Machart P, Bansal V, Kilian C, Magruder DS, Krebs CF, Bonn S. Realistic in silico generation and augmentation of singlecell RNAseq data using generative adversarial networks. Nat Commun. 2020; 11(1). https://doi.org/10.1038/s4146701914018z.
 73
Lopez R, Regier J, Cole MB, Jordan MI, Yosef N. Deep generative modeling for singlecell transcriptomics. Nat Methods. 2018; 15(12):1053–8. https://doi.org/10.1038/s4159201802292.
 74
Korthauer KD, Chu LF, Newton MA, Li Y, Thomson J, Stewart R, Kendziorski C. A statistical approach for identifying differential distributions in singlecell RNAseq experiments. Genome Biology. 2016; 17(1). https://doi.org/10.1186/s130590161077y.
 75
Vieth B, Ziegenhain C, Parekh S, Enard W, Hellmann I. powsimR: power analysis for bulk and single cell RNAseq experiments. Bioinformatics. 2017; 33(21):3486–8. https://doi.org/10.1093/bioinformatics/btx435.
 76
Dibaeinia P, Sinha S. Sergio: a singlecell expression simulator guided by gene regulatory networks. Cell Syst. 2020; 11(3):252–71.
 77
Cannoodt R, Saelens W, Deconinck L, Saeys Y. dyngen: a multimodal simulator for spearheading new singlecell omics analyses. BioRxiv. 2020. https://doi.org/10.1101/2020.02.06.936971.
 78
Lun ATL, Marioni JC. Overcoming confounding plate effects in differential expression analyses of singlecell RNAseq data. Biostatistics. 2017; 18(3):451–64.
 79
Assefa AT, Vandesompele J, Thas O. SPsimSeq: semiparametric simulation of bulk and singlecell RNAsequencing data. Bioinformatics. 2020; 36(10):3276–8.
 80
William Townes F, Hicks SC, Aryee MJ, Irizarry RA. Feature selection and dimension reduction for singlecell RNAseq based on a multinomial model. Genome Biol. 2019; 20(1):12.
 81
Sarkar AK, Stephens M. Separating measurement and expression models clarifies confusion in single cell rnaseq analysis. BioRxiv. 2020. https://doi.org/10.1101/2020.04.07.030007.
 82
Svensson V. Droplet scRNAseq is not zeroinflated. Nat Biotechnol. 2020; 38(2):147–50.
 83
Haber AL, Biton M, Rogel N, Herbst RH, Shekhar K, Smillie C, Burgin G, Delorey TM, Howitt MR, Katz Y, et al.A singlecell survey of the small intestinal epithelium. Nature. 2017; 551(7680):333–9.
 84
Muraro MJ, Dharmadhikari G, Grün D, Groen N, Dielen T, Jansen E, Van Gurp L, Engelse MA, Carlotti F, De Koning EJP, et al.A singlecell transcriptome atlas of the human pancreas. Cell Syst. 2016; 3(4):385–94. https://doi.org/10.1016/j.cels.2016.09.002.
 85
Darmanis S, Sloan SA, Zhang Y, Enge M, Caneda C, Shuer LM, Hayden Gephart MG, Barres BA, Quake SR. A survey of human brain transcriptome diversity at the single cell level. Proc Natl Acad Sci. 2015; 112(23):7285–90. https://doi.org/10.1073/pnas.1507125112.
 86
Korsunsky I, Millard N, Fan J, Slowikowski K, Zhang F, Wei K, Baglaenko Y, Brenner M, Loh P, Raychaudhuri S. Fast, sensitive and accurate integration of singlecell data with harmony. Nat Methods. 2019; 16(12):1289–96.
 87
Liu B, Li C, Li Z, Wang D, Ren X, Zhang Z. An entropybased metric for assessing the purity of single cell populations. Nature Commun. 2020; 11(1):1–13.
 88
Blondel VD, Guillaume JL, Lambiotte R, Lefebvre E. Fast unfolding of communities in large networks. J Stat Mech Theory Exp. 2008; 2008(10). https://doi.org/10.1088/17425468/2008/10/p10008.
 89
Svensson V, Teichmann SA, Stegle O. Spatialde: identification of spatially variable genes. Nat Methods. 2018b; 15(5):343–6.
 90
Sun S, Zhu J, Zhou X. Statistical analysis of spatial expression patterns for spatially resolved transcriptomic studies. Nat Methods. 2020; 17(2):193–200.
 91
Moffitt JR, BambahMukku D, Eichhorn SW, Vaughn E, Shekhar K, Perez JD, Rubinstein ND, Hao J, Regev A, Dulac C, et al.Molecular, spatial, and functional singlecell profiling of the hypothalamic preoptic region. Science. 2018; 362(6416):eaau5324.
 92
Qian X, Harris KD, Hauling T, Nicoloutsopoulos D, MuñozManchado AB, Skene N, HjerlingLeffler J, Nilsson M. Probabilistic cell typing enables fine mapping of closely related cell types in situ. Nat Methods. 2020; 17(1):101–6.
 93
Vinh NX, Epps J, Bailey J. Information theoretic measures for clusterings comparison. In: Proceedings of the 26th Annual International Conference on Machine Learning  ICML 09: 2009. https://doi.org/10.1145/1553374.1553511.
 94
Hubert L, Arabie P. Comparing partitions. J Classif. 1985; 2(1):193–218.
 95
McKinley ET, Sui Y, AlKofahi Y, Millis BA, Tyska MJ, Roland JT, SantamariaPang A, Ohland CL, Jobin C, Franklin JL, et al., Vol. 2. Optimized multiplex immunofluorescence singlecell analysis reveals tuft cell heterogeneity; 2017, p. e93487.
 96
Dong R, Yuan GC. Giniclust3: a fast and memoryefficient tool for rare cell type identification. BMC Bioinformatics. 2020; 21:1–7.
 97
Bien J, Tibshirani RJ. Sparse estimation of a covariance matrix. Biometrika. 2011; 98(4):807–20.
 98
Hastie TJ, Tibshirani RJ. Generalized additive models, vol 43. Boca Raton: CRC press; 1990.
 99
Wood SN. Generalized additive models: an introduction with R. Boca Raton: CRC press; 2017.
 100
Wolock SL, Lopez R, Klein AM. Scrublet: Computational identification of cell doublets in singlecell transcriptomic data. Cell Syst. 2019; 8(4):281–291. https://doi.org/10.1016/j.cels.2018.11.005.
 101
Mcginnis CS, Murrow LM, Gartner ZJ. Doubletfinder: doublet detection in singlecell RNA sequencing data using artificial nearest neighbors. Cell Syst. 2019; 8(4). https://doi.org/10.1016/j.cels.2019.03.003.
 102
Stoeckius M, Zheng S, HouckLoomis B, Hao S, Yeung BZ, Mauck WM, Smibert P, Satija R. Cell hashing with barcoded antibodies enables multiplexing and doublet detection for single cell genomics. Genome Biol. 2018; 19(1). https://doi.org/10.1186/s1305901816031.
 103
Xi NM, Li JJ. Benchmarking computational doubletdetection methods for singlecell rna sequencing data. Cell Syst. 2021; 12(2):176–94.
 104
Lähnemann D, Köster J, Szczurek E, McCarthy DJ, Hicks SC, Robinson MD, Vallejos CA, Campbell KR, Beerenwinkel N, Mahfouz A, et al.Eleven grand challenges in singlecell data science. Genome Biol. 2020; 21(1):1–35.
 105
Rachel Wang YX, Li L, Li JJ, Huang H. Network Modeling in Biology: Statistical Methods for Gene and Brain Networks. Stat Sci. 2021; 36(1):89–108.
 106
Ma Y, Sun S, Shang X, Keller ET, Chen M, Zhou X. Integrative differential expression and gene set enrichment analysis using summary statistics for scRNAseq studies. Nat Commun. 2020; 11(1):1–13.
 107
Subramanian A, Tamayo P, Mootha VK, Mukherjee S, Ebert BL, Gillette MA, Paulovich A, Pomeroy SL, Golub TR, Lander ES, et al.Gene set enrichment analysis: a knowledgebased approach for interpreting genomewide expression profiles. Proc Natl Acad Sci. 2005; 102(43):15545–50.
 108
Tran HTN, Ang KS, Chevrier M, Zhang X, Lee NYS, Goh M, Chen J. A benchmark of batcheffect correction methods for singlecell RNA sequencing data. Genome Biol. 2020; 21(1):1–32.
 109
Butler A, Hoffman P, Smibert P, Papalexi E, Satija R. Integrating singlecell transcriptomic data across different conditions, technologies, and species. Nat Biotechnol. 2018; 36(5):411–20.
 110
Sklar A. Fonctions de répartition à n dimensions et leurs marges. Publ Inst Stat Univ Paris. 1959; 8:229–231.
 111
Genest C, Nešlehová J. A primer on copula for count data. ASTIN Bull J IAA. 2007; 37(2):475–515.
 112
Inouye DI, Yang E, Allen GI, Ravikumar P. A review of multivariate distributions for count data derived from the poisson distribution. Wiley Interdisc Rev Comput Stat. 2017; 9(3):e1398.
 113
Rüschendorf L. Copulas, sklar’s theorem, and distributional transform. In: Mathematical Risk Analysis. New York City: Springer: 2013. p. 3–34.
 114
Avramidis AN, Channouf N, L’Ecuyer P. Efficient correlation matching for fitting discrete multivariate distributions with arbitrary marginals and normalcopula dependence. INFORMS J Comput. 2009; 21(1):88–106.
 115
Lebrun R, Dutfoy A. An innovating analysis of the nataf transformation from the copula viewpoint. Probabilistic Eng Mech. 2009; 24(3):312–20.
 116
Ghosh S, Henderson SG. Behavior of the norta method for correlated random vector generation as the dimension increases. ACM Trans Model Comput Simul (TOMACS). 2003; 13(3):276–94.
 117
Channouf N, L’Ecuyer P. A normal copula model for the arrival process in a call center. Int Trans Oper Res. 2012; 19(6):771–87.
 118
Sun T. scDesign2: a statistical simulator for scRNAseq data with gene correlation captured. R package version 0.1.0.https://github.com/JSBUCLA/scDesign2.
 119
Sun T, Song D, Li WV, Li JJ. scDesign2: an interpretable simulator that generates realistic singlecell gene expression count data with gene correlations captured. 2021. https://doi.org/10.5281/zenodo.4011311.
Acknowledgements
The authors would like to thank Dr. Roy Wollman and his Ph.D. student Zach Hemminger for bringing our attention to MERFISH and pciSeq data. The authors also appreciate the comments and feedback from the members of the Junction of Statistics and Biology at UCLA (http://jsb.ucla.edu).
Peer review information
Barbara Cheifet was the primary editor of this article and managed its editorial process and peer review in collaboration with the rest of the editorial team.
Review history
The review history is available as Additional file 3.
Funding
This work was supported by the following grants: National Science Foundation DBI1846216, NIH/NIGMS R01GM120507, Johnson & Johnson WiSTEM2D Award, Sloan Research Fellowship, and UCLA David Geffen School of Medicine W.M. Keck Foundation Junior Faculty Award (to J.J.L); Rutgers School of Public Health Pilot Grant and NJ ACTS BERD MiniMethods Grant (to W.V.L).
Author information
Affiliations
Contributions
Authors’ contributions
All authors read and approved the final manuscript.
Authors’ information
Twitter: @TianyiSun17 (Tianyi Sun); @SongDongyuan (Dongyuan Song); @vivianstats (Wei Vivian Li); @jsb_ucla (Jingyi Jessica Li).
Corresponding authors
Ethics declarations
Ethics approval and consent to participate
Not applicable.
Competing interests
The authors declare that they have no competing interests.
Additional information
Publisher’s Note
Springer Nature remains neutral with regard to jurisdictional claims in published maps and institutional affiliations.
The original version of this article was revised: "Table 1 has been corrected and updated.
Supplementary Information
Additional file 1
Supplementary materials. It includes all supplementary tables and figures.
Additional file 2
Comparison of scDesign2 to SPsimSeq.
Additional file 3
Review history
Rights and permissions
Open Access This article is licensed under a Creative Commons Attribution 4.0 International License, which permits use, sharing, adaptation, distribution and reproduction in any medium or format, as long as you give appropriate credit to the original author(s) and the source, provide a link to the Creative Commons licence, and indicate if changes were made. The images or other third party material in this article are included in the article’s Creative Commons licence, unless indicated otherwise in a credit line to the material. If material is not included in the article’s Creative Commons licence and your intended use is not permitted by statutory regulation or exceeds the permitted use, you will need to obtain permission directly from the copyright holder. To view a copy of this licence, visit http://creativecommons.org/licenses/by/4.0/. The Creative Commons Public Domain Dedication waiver (http://creativecommons.org/publicdomain/zero/1.0/) applies to the data made available in this article, unless otherwise stated in a credit line to the data.
About this article
Cite this article
Sun, T., Song, D., Li, W.V. et al. scDesign2: a transparent simulator that generates highfidelity singlecell gene expression count data with gene correlations captured. Genome Biol 22, 163 (2021). https://doi.org/10.1186/s13059021023672
Received:
Accepted:
Published:
DOI: https://doi.org/10.1186/s13059021023672