DeconvoBuddies 1.1.5
DeconvoBuddies is an R package developed to assist in running bulk RNA-seq
deconvolution. This package provides functions to access a data set designed to
evaluate deconvolution method performance, find marker genes, and create plots
useful in deconvolution.
This package is associated with “Benchmark of cellular deconvolution methods using a multi-assay reference dataset from postmortem human prefrontal cortex” from Huuki-Myers et al. (10.1101/2024.02.09.579665v2)[https://www.biorxiv.org/content/10.1101/2024.02.09.579665v2].
DeconvoBuddiesR is an open-source statistical environment which can be easily
modified to enhance its functionality via packages.
DeconvoBuddies is a R package available via the
Bioconductor repository for packages. R can
be installed on any operating system from
CRAN after which you can install
DeconvoBuddies by using the following commands in your
R session:
if (!requireNamespace("BiocManager", quietly = TRUE)) {
    install.packages("BiocManager")
}
BiocManager::install("DeconvoBuddies")
## Check that you have a valid Bioconductor installation
BiocManager::valid()DeconvoBuddies is based on many other packages and in particular in those that have implemented the infrastructure needed for dealing with snRNA-seq data. That is, packages like SingleCellExperiment.
If you are asking yourself the question “Where do I start using Bioconductor?” you might be interested in this blog post.
As package developers, we try to explain clearly how to use our packages
and in which order to use the functions. But R and Bioconductor have
a steep learning curve so it is critical to learn where to ask for help.
The blog post quoted above mentions some but we would like to highlight
the Bioconductor support site as
the main resource for getting help: remember to use the DeconvoBuddies
tag and check the older
posts. Other
alternatives are available such as creating GitHub issues and tweeting.
However, please note that if you want to receive help you should adhere
to the posting
guidelines. It
is particularly critical that you provide a small reproducible example
and your session information so package developers can track down the
source of the error.
DeconvoBuddiesWe hope that DeconvoBuddies will be useful for your research. Please use the following information to cite the package and the overall approach. Thank you!
## Citation info
citation("DeconvoBuddies")
#> To cite package 'DeconvoBuddies' in publications use:
#> 
#>   Huuki-Myers LA, Maynard KR, Hicks SC, Zandi P, Kleinman JE, Hyde TM,
#>   Goes FS, Collado-Torres L (2025). _DeconvoBuddies: a R/Bioconductor
#>   package with deconvolution helper functions_.
#>   doi:10.18129/B9.bioc.DeconvoBuddies
#>   <https://doi.org/10.18129/B9.bioc.DeconvoBuddies>,
#>   https://github.com/LieberInstitute/DeconvoBuddies/DeconvoBuddies - R
#>   package version 1.1.5,
#>   <http://www.bioconductor.org/packages/DeconvoBuddies>.
#> 
#>   Huuki-Myers LA, Montgomery KD, Kwon SH, Cinquemani S, Eagles NJ,
#>   Gonzalez-Padilla D, Maden SK, Kleinman JE, Hyde TM, Hicks SC, Maynard
#>   KR, Collado-Torres L (2025). "Benchmark of cellular deconvolution
#>   methods using a multi-assay dataset from postmortem human prefrontal
#>   cortex." _Genome Biol_. doi:10.1186/s13059-025-03552-3
#>   <https://doi.org/10.1186/s13059-025-03552-3>,
#>   <https://doi.org/10.1186/s13059-025-03552-3>.
#> 
#> To see these entries in BibTeX format, use 'print(<citation>,
#> bibtex=TRUE)', 'toBibtex(.)', or set
#> 'options(citation.bibtex.max=999)'.DeconvoBuddiesLet’s load some packages we’ll use in this vignette.
suppressMessages({
    library("DeconvoBuddies")
    library("SummarizedExperiment")
    library("dplyr")
    library("tidyr")
    library("tibble")
})Use fetch_deconvo_data to download RNA sequencing data from the Human
DLPFC (Huuki-Myers, Montgomery, Kwon, Cinquemani, Eagles, Gonzalez-Padilla, Maden, Kleinman, Hyde, Hicks, Maynard, and Collado-Torres, 2025).
rse_gene: 110 samples of bulk RNA-seq. [110 bulk RNA-seq samples x
21k genes] (41 MB).
sce : snRNA-seq data from the Human DLPFC. [77k nuclei x 36k
genes] (172 MB)
sce_DLPFC_example: Sub-set of sce useful for testing. [10k
nuclei x 557 genes] (49 MB)
## Access and snRNA-seq example data
if (!exists("sce_DLPFC_example")) sce_DLPFC_example <- fetch_deconvo_data("sce_DLPFC_example")
#> 2025-10-07 17:15:39.630243 Access ExperimentHub EH9626
#> see ?DeconvoBuddies and browseVignettes('DeconvoBuddies') for documentation
#> loading from cache
#> require("SingleCellExperiment")
## Explore snRNA-seq data in sce_DLPFC_example
sce_DLPFC_example
#> class: SingleCellExperiment 
#> dim: 557 10000 
#> metadata(3): Samples cell_type_colors cell_type_colors_broad
#> assays(1): logcounts
#> rownames(557): GABRD PRDM16 ... AFF2 MAMLD1
#> rowData names(7): source type ... gene_type binomial_deviance
#> colnames(10000): 8_AGTGACTGTAGTTACC-1 17_GCAGCCAGTGAGTCAG-1 ...
#>   12_GGACGTCTCTGACAGT-1 1_GGTTAACTCTCTCTAA-1
#> colData names(32): Sample Barcode ... cellType_layer layer_annotation
#> reducedDimNames(0):
#> mainExpName: NULL
#> altExpNames(0):
## Access Bulk RNA-seq data
if (!exists("rse_gene")) rse_gene <- fetch_deconvo_data("rse_gene")
#> 2025-10-07 17:15:44.835052 Access ExperimentHub EH9625
#> see ?DeconvoBuddies and browseVignettes('DeconvoBuddies') for documentation
#> loading from cache
## Explore bulk data in rse_gene
rse_gene
#> class: RangedSummarizedExperiment 
#> dim: 21745 110 
#> metadata(1): SPEAQeasy_settings
#> assays(2): counts logcounts
#> rownames(21745): ENSG00000227232.5 ENSG00000278267.1 ...
#>   ENSG00000210195.2 ENSG00000210196.2
#> rowData names(11): Length gencodeID ... gencodeTx passExprsCut
#> colnames(110): 2107UNHS-0291_Br2720_Mid_Bulk
#>   2107UNHS-0291_Br2720_Mid_Cyto ... AN00000906_Br8667_Mid_Cyto
#>   AN00000906_Br8667_Mid_Nuc
#> colData names(80): SAMPLE_ID Sample ... diagnosis qc_classFor more details on this dataset, and an example deconvolution run check out the Vignette: Deconvolution Benchmark in Human DLPFC.
Accurate deconvolution requires highly specific marker genes for each
cell type to be defined. To select genes specific for each cell type,
you can evaluate the MeanRatio for each gene x each cell type, where
MeanRatio = mean(Expression  of target cell type) / mean(Expression of highest non-target cell type).
These values can be calculated for a single cell RNA-seq dataset using
get_mean_ratio(). This can also work for spatially-resolved transcriptomics
datasets. That is, get_mean_ratio() can also work with
SpatialExperiment::SpatialExperiment() objects.
## find marker genes with get_mean_ratio
marker_stats <- get_mean_ratio(
    sce_DLPFC_example,
    cellType_col = "cellType_broad_hc",
    gene_name = "gene_name",
    gene_ensembl = "gene_id"
)
## explore tibble output, gene with high MeanRatio values are good marker genes
marker_stats
#> # A tibble: 762 × 10
#>    gene       cellType.target mean.target cellType.2nd mean.2nd MeanRatio
#>    <chr>      <fct>                 <dbl> <fct>           <dbl>     <dbl>
#>  1 CD22       Oligo                  1.36 OPC            0.0730      18.6
#>  2 LINC01608  Oligo                  2.39 Micro          0.142       16.8
#>  3 FOLH1      Oligo                  1.59 OPC            0.101       15.7
#>  4 SLC5A11    Oligo                  2.14 Micro          0.145       14.7
#>  5 AC012494.1 Oligo                  2.42 OPC            0.169       14.3
#>  6 ST18       Oligo                  4.65 OPC            0.329       14.1
#>  7 MAG        Oligo                  1.44 Astro          0.103       14.0
#>  8 ANLN       Oligo                  1.60 Micro          0.115       13.9
#>  9 CLDN11     Oligo                  1.82 EndoMural      0.146       12.5
#> 10 MOG        Oligo                  2.06 OPC            0.185       11.1
#> # ℹ 752 more rows
#> # ℹ 4 more variables: MeanRatio.rank <int>, MeanRatio.anno <chr>,
#> #   gene_ensembl <chr>, gene_name <chr>For more discussion of finding marker genes with DeconvoBuddies check
out the Vignette: Finding Marker Genes with
DeconvoBuddies.
As you work with single-cell data and deconvolution outputs, it is very
useful to establish a consistent color palette to use across different
plots. The function create_cell_colors() returns a named vector of hex
values, corresponding to the names of cell types. This list is
compatible with functions like ggplot2::scale_color_manual().
There are three palettes to choose from to generate colors or users can provide their own color palette:
“classic” (default): classic set of 8 cell type colors from LIBD, checked for visability and color blind accessibility.
“gg”: Equi-distant hues, same process for selecting colors as
ggplot - no maximum number
“tableau”: tableau20 color set - max 20 colors
test_cell_types <- c("cell_A", "cell_B", "cell_C", "cell_D", "cell_E")
## Preview "classic" colors
test_cell_colors_classic <- create_cell_colors(
    cell_types = test_cell_types,
    palette_name = "classic",
    preview = TRUE
)
#> Creating classic palette for 5 broad cell types
## Preview "gg" colors
test_cell_colors_gg <- create_cell_colors(
    cell_types = test_cell_types,
    palette_name = "gg",
    preview = TRUE
)
#> Creating gg palette for 5 broad cell types
## Preview "tableau" colors
test_cell_colors_tableau <- create_cell_colors(
    cell_types = test_cell_types,
    palette_name = "tableau",
    preview = TRUE
)
#> Creating tableau palette for 5 broad cell types
## Check the color hex codes for "tableau"
test_cell_colors_tableau
#>    cell_A    cell_B    cell_C    cell_D    cell_E 
#> "#1F77B4" "#AEC7E8" "#FF7F0E" "#FFBB78" "#2CA02C"
## Provide a palette from RColorBrewer
test_cell_colors_brew <- create_cell_colors(
    cell_types = test_cell_types,
    palette = RColorBrewer::brewer.pal(n = length(test_cell_types), name = "Dark2"),
    preview = TRUE
)
#> Creating custom palette for 5 broad cell typesIf there are sub-cell types with consistent delimiters, the split
argument creates a scale of related colors. This helps expand on the
maximum number of colors and makes your palette flexible when considering
different ‘resolutions’ of cell types. This works by ignoring any prefixes after
the split character. In this example below, Excit_01 and Excit_02 will
just be considered as Excit since split = "_".
my_cell_types <- levels(sce_DLPFC_example$cellType_hc)
## Ignore any suffix after the "_" character by using the "split" argument
my_cell_colors <- create_cell_colors(
    cell_types = my_cell_types,
    palette_name = "classic",
    preview = TRUE,
    split = "_"
)
#> Creating classic palette for 8 broad cell types
#> Creating fine cell type gradients for 4 cell typesThe function plot_marker_express() helps quickly visualize expression
of top marker genes, by ordering and annotating violin plots of
expression over cell type. Here we’ll plot the expression of the top 6
marker genes for Astrocytes.
# plot expression of the top 6 Astro marker genes
plot_marker_express(
    sce = sce_DLPFC_example,
    stats = marker_stats,
    cell_type = "Astro",
    n_genes = 6,
    cellType_col = "cellType_broad_hc",
    color_pal = my_cell_colors
)
#> Warning: No shared levels found between `names(values)` of the manual scale and the
#> data's fill values.
#> No shared levels found between `names(values)` of the manual scale and the
#> data's fill values.The violin plots of gene expression confirm the cell type specificity of these marker genes, most of the nuclei with high expression of these six genes are astrocytes (Astro).
The output of deconvolution are cell type estimates that sum to 1. A
good visulization for these predictions is a stacked bar plot. The
function plot_composition_bar() creates a stacked bar plot showing the
cell type proportion for each sample, or the average proportion for a
group of samples. In this example data, the RNum is a sample (donor)
identifier and Dx is a group variable for the diagnosis status of the donors.
# load example data
data("rse_bulk_test")
data("est_prop_test")
# access the colData of a test rse dataset
pd <- colData(rse_bulk_test) |>
    as.data.frame()
## pivot data to long format and join with test estimated proportion data
est_prop_long <- est_prop_test |>
    rownames_to_column("RNum") |>
    pivot_longer(!RNum, names_to = "cell_type", values_to = "prop") |>
    left_join(pd)
#> Joining with `by = join_by(RNum)`
## explore est_prop_long
est_prop_long
#> # A tibble: 500 × 7
#>    RNum  cell_type    prop BrNum Sex   Dx        Age
#>    <chr> <chr>       <dbl> <chr> <chr> <chr>   <dbl>
#>  1 R913  cell_A    0.431   Br001 F     Case     71.9
#>  2 R913  cell_B    0.242   Br001 F     Case     71.9
#>  3 R913  cell_C    0.110   Br001 F     Case     71.9
#>  4 R913  cell_D    0.174   Br001 F     Case     71.9
#>  5 R913  cell_E    0.0426  Br001 F     Case     71.9
#>  6 R602  cell_A    0.286   Br002 F     Control  73.1
#>  7 R602  cell_B    0.392   Br002 F     Control  73.1
#>  8 R602  cell_C    0.207   Br002 F     Control  73.1
#>  9 R602  cell_D    0.00186 Br002 F     Control  73.1
#> 10 R602  cell_E    0.113   Br002 F     Control  73.1
#> # ℹ 490 more rows
## the composition bar plot shows cell type composition for Sample
plot_composition_bar(est_prop_long,
    x_col = "RNum",
    add_text = FALSE
) +
    ggplot2::scale_fill_manual(values = test_cell_colors_classic)
## the composition bar plot shows the average cell type composition for each Dx
plot_composition_bar(est_prop_long, x_col = "Dx") +
    ggplot2::scale_fill_manual(values = test_cell_colors_classic)We can see that the mean proportions of cell types A through E are very similar
across the Dx groups (Case and Control). In this case, this is expected
given that we are using simulated data. Although if you look across each donor
with RNum we can see more variability across the simulated data.
Since you are now familiar with the basic overview of DeconvoBuddies, you are
now ready to dive deeper into:
DeconvoBuddies to the Human Brain (DLPFC) Deconvolution dataset.The DeconvoBuddies package (Huuki-Myers, Maynard, Hicks, Zandi, Kleinman, Hyde, Goes, and Collado-Torres, 2025) was made possible thanks to:
This vignette was generated using BiocStyle (Oleś, 2025) with knitr (Xie, 2025) and rmarkdown (Allaire, Xie, Dervieux, McPherson, Luraschi, Ushey, Atkins, Wickham, Cheng, Chang, and Iannone, 2025) running behind the scenes.
Citations made with RefManageR (McLean, 2017).
This package was developed using biocthis.
R session information.
#> ─ Session info ───────────────────────────────────────────────────────────────────────────────────────────────────────
#>  setting  value
#>  version  R version 4.5.1 Patched (2025-08-23 r88802)
#>  os       Ubuntu 24.04.3 LTS
#>  system   x86_64, linux-gnu
#>  ui       X11
#>  language (EN)
#>  collate  C
#>  ctype    en_US.UTF-8
#>  tz       America/New_York
#>  date     2025-10-07
#>  pandoc   2.7.3 @ /usr/bin/ (via rmarkdown)
#>  quarto   1.7.32 @ /usr/local/bin/quarto
#> 
#> ─ Packages ───────────────────────────────────────────────────────────────────────────────────────────────────────────
#>  package              * version   date (UTC) lib source
#>  abind                  1.4-8     2024-09-12 [2] CRAN (R 4.5.1)
#>  AnnotationDbi          1.71.1    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  AnnotationHub          3.99.6    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  attempt                0.3.1     2020-05-03 [2] CRAN (R 4.5.1)
#>  backports              1.5.0     2024-05-23 [2] CRAN (R 4.5.1)
#>  beachmat               2.25.5    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  beeswarm               0.4.0     2021-06-01 [2] CRAN (R 4.5.1)
#>  benchmarkme            1.0.8     2022-06-12 [2] CRAN (R 4.5.1)
#>  benchmarkmeData        1.0.4     2020-04-23 [2] CRAN (R 4.5.1)
#>  bibtex                 0.5.1     2023-01-26 [2] CRAN (R 4.5.1)
#>  Biobase              * 2.69.1    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  BiocFileCache          2.99.6    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  BiocGenerics         * 0.55.1    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  BiocIO                 1.19.0    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  BiocManager            1.30.26   2025-06-05 [2] CRAN (R 4.5.1)
#>  BiocNeighbors          2.3.1     2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  BiocParallel           1.43.4    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  BiocSingular           1.25.0    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  BiocStyle            * 2.37.1    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  BiocVersion            3.22.0    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  Biostrings             2.77.2    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  bit                    4.6.0     2025-03-06 [2] CRAN (R 4.5.1)
#>  bit64                  4.6.0-1   2025-01-16 [2] CRAN (R 4.5.1)
#>  bitops                 1.0-9     2024-10-03 [2] CRAN (R 4.5.1)
#>  blob                   1.2.4     2023-03-17 [2] CRAN (R 4.5.1)
#>  bluster                1.19.0    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  bookdown               0.45      2025-10-03 [2] CRAN (R 4.5.1)
#>  bslib                  0.9.0     2025-01-30 [2] CRAN (R 4.5.1)
#>  cachem                 1.1.0     2024-05-16 [2] CRAN (R 4.5.1)
#>  circlize               0.4.16    2024-02-20 [2] CRAN (R 4.5.1)
#>  cli                    3.6.5     2025-04-23 [2] CRAN (R 4.5.1)
#>  clue                   0.3-66    2024-11-13 [2] CRAN (R 4.5.1)
#>  cluster                2.1.8.1   2025-03-12 [3] CRAN (R 4.5.1)
#>  codetools              0.2-20    2024-03-31 [3] CRAN (R 4.5.1)
#>  colorspace             2.1-2     2025-09-22 [2] CRAN (R 4.5.1)
#>  ComplexHeatmap         2.25.2    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  config                 0.3.2     2023-08-30 [2] CRAN (R 4.5.1)
#>  cowplot                1.2.0     2025-07-07 [2] CRAN (R 4.5.1)
#>  crayon                 1.5.3     2024-06-20 [2] CRAN (R 4.5.1)
#>  curl                   7.0.0     2025-08-19 [2] CRAN (R 4.5.1)
#>  data.table             1.17.8    2025-07-10 [2] CRAN (R 4.5.1)
#>  DBI                    1.2.3     2024-06-02 [2] CRAN (R 4.5.1)
#>  dbplyr                 2.5.1     2025-09-10 [2] CRAN (R 4.5.1)
#>  DeconvoBuddies       * 1.1.5     2025-10-07 [1] Bioconductor 3.22 (R 4.5.1)
#>  DelayedArray           0.35.3    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  DelayedMatrixStats     1.31.0    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  dichromat              2.0-0.1   2022-05-02 [2] CRAN (R 4.5.1)
#>  digest                 0.6.37    2024-08-19 [2] CRAN (R 4.5.1)
#>  doParallel             1.0.17    2022-02-07 [2] CRAN (R 4.5.1)
#>  dplyr                * 1.1.4     2023-11-17 [2] CRAN (R 4.5.1)
#>  dqrng                  0.4.1     2024-05-28 [2] CRAN (R 4.5.1)
#>  DT                     0.34.0    2025-09-02 [2] CRAN (R 4.5.1)
#>  edgeR                  4.7.5     2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  evaluate               1.0.5     2025-08-27 [2] CRAN (R 4.5.1)
#>  ExperimentHub          2.99.5    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  farver                 2.1.2     2024-05-13 [2] CRAN (R 4.5.1)
#>  fastmap                1.2.0     2024-05-15 [2] CRAN (R 4.5.1)
#>  filelock               1.0.3     2023-12-11 [2] CRAN (R 4.5.1)
#>  foreach                1.5.2     2022-02-02 [2] CRAN (R 4.5.1)
#>  generics             * 0.1.4     2025-05-09 [2] CRAN (R 4.5.1)
#>  GenomicAlignments      1.45.4    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  GenomicRanges        * 1.61.5    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  GetoptLong             1.0.5     2020-12-15 [2] CRAN (R 4.5.1)
#>  ggbeeswarm             0.7.2     2023-04-29 [2] CRAN (R 4.5.1)
#>  ggplot2                4.0.0     2025-09-11 [2] CRAN (R 4.5.1)
#>  ggrepel                0.9.6     2024-09-07 [2] CRAN (R 4.5.1)
#>  GlobalOptions          0.1.2     2020-06-10 [2] CRAN (R 4.5.1)
#>  glue                   1.8.0     2024-09-30 [2] CRAN (R 4.5.1)
#>  golem                  0.5.1     2024-08-27 [2] CRAN (R 4.5.1)
#>  gridExtra              2.3       2017-09-09 [2] CRAN (R 4.5.1)
#>  gtable                 0.3.6     2024-10-25 [2] CRAN (R 4.5.1)
#>  htmltools              0.5.8.1   2024-04-04 [2] CRAN (R 4.5.1)
#>  htmlwidgets            1.6.4     2023-12-06 [2] CRAN (R 4.5.1)
#>  httpuv                 1.6.16    2025-04-16 [2] CRAN (R 4.5.1)
#>  httr                   1.4.7     2023-08-15 [2] CRAN (R 4.5.1)
#>  httr2                  1.2.1     2025-07-22 [2] CRAN (R 4.5.1)
#>  igraph                 2.1.4     2025-01-23 [2] CRAN (R 4.5.1)
#>  IRanges              * 2.43.5    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  irlba                  2.3.5.1   2022-10-03 [2] CRAN (R 4.5.1)
#>  iterators              1.0.14    2022-02-05 [2] CRAN (R 4.5.1)
#>  jquerylib              0.1.4     2021-04-26 [2] CRAN (R 4.5.1)
#>  jsonlite               2.0.0     2025-03-27 [2] CRAN (R 4.5.1)
#>  KEGGREST               1.49.1    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  knitr                  1.50      2025-03-16 [2] CRAN (R 4.5.1)
#>  labeling               0.4.3     2023-08-29 [2] CRAN (R 4.5.1)
#>  later                  1.4.4     2025-08-27 [2] CRAN (R 4.5.1)
#>  lattice                0.22-7    2025-04-02 [3] CRAN (R 4.5.1)
#>  lazyeval               0.2.2     2019-03-15 [2] CRAN (R 4.5.1)
#>  lifecycle              1.0.4     2023-11-07 [2] CRAN (R 4.5.1)
#>  limma                  3.65.5    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  locfit                 1.5-9.12  2025-03-05 [2] CRAN (R 4.5.1)
#>  lubridate              1.9.4     2024-12-08 [2] CRAN (R 4.5.1)
#>  magick                 2.9.0     2025-09-08 [2] CRAN (R 4.5.1)
#>  magrittr               2.0.4     2025-09-12 [2] CRAN (R 4.5.1)
#>  Matrix                 1.7-4     2025-08-28 [3] CRAN (R 4.5.1)
#>  MatrixGenerics       * 1.21.0    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  matrixStats          * 1.5.0     2025-01-07 [2] CRAN (R 4.5.1)
#>  memoise                2.0.1     2021-11-26 [2] CRAN (R 4.5.1)
#>  metapod                1.17.0    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  mime                   0.13      2025-03-17 [2] CRAN (R 4.5.1)
#>  paletteer              1.6.0     2024-01-21 [2] CRAN (R 4.5.1)
#>  pillar                 1.11.1    2025-09-17 [2] CRAN (R 4.5.1)
#>  pkgconfig              2.0.3     2019-09-22 [2] CRAN (R 4.5.1)
#>  plotly                 4.11.0    2025-06-19 [2] CRAN (R 4.5.1)
#>  plyr                   1.8.9     2023-10-02 [2] CRAN (R 4.5.1)
#>  png                    0.1-8     2022-11-29 [2] CRAN (R 4.5.1)
#>  promises               1.3.3     2025-05-29 [2] CRAN (R 4.5.1)
#>  purrr                  1.1.0     2025-07-10 [2] CRAN (R 4.5.1)
#>  R6                     2.6.1     2025-02-15 [2] CRAN (R 4.5.1)
#>  rafalib                1.0.4     2025-04-08 [2] CRAN (R 4.5.1)
#>  rappdirs               0.3.3     2021-01-31 [2] CRAN (R 4.5.1)
#>  RColorBrewer           1.1-3     2022-04-03 [2] CRAN (R 4.5.1)
#>  Rcpp                   1.1.0     2025-07-02 [2] CRAN (R 4.5.1)
#>  RCurl                  1.98-1.17 2025-03-22 [2] CRAN (R 4.5.1)
#>  RefManageR           * 1.4.0     2022-09-30 [2] CRAN (R 4.5.1)
#>  rematch2               2.1.2     2020-05-01 [2] CRAN (R 4.5.1)
#>  reshape2               1.4.4     2020-04-09 [2] CRAN (R 4.5.1)
#>  restfulr               0.0.16    2025-06-27 [2] CRAN (R 4.5.1)
#>  rjson                  0.2.23    2024-09-16 [2] CRAN (R 4.5.1)
#>  rlang                  1.1.6     2025-04-11 [2] CRAN (R 4.5.1)
#>  rmarkdown              2.30      2025-09-28 [2] CRAN (R 4.5.1)
#>  Rsamtools              2.25.3    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  RSQLite                2.4.3     2025-08-20 [2] CRAN (R 4.5.1)
#>  rsvd                   1.0.5     2021-04-16 [2] CRAN (R 4.5.1)
#>  rtracklayer            1.69.1    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  S4Arrays               1.9.1     2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  S4Vectors            * 0.47.4    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  S7                     0.2.0     2024-11-07 [2] CRAN (R 4.5.1)
#>  sass                   0.4.10    2025-04-11 [2] CRAN (R 4.5.1)
#>  ScaledMatrix           1.17.0    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  scales                 1.4.0     2025-04-24 [2] CRAN (R 4.5.1)
#>  scater                 1.37.0    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  scran                  1.37.0    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  scuttle                1.19.0    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  Seqinfo              * 0.99.2    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  sessioninfo          * 1.2.3     2025-02-05 [2] CRAN (R 4.5.1)
#>  shape                  1.4.6.1   2024-02-23 [2] CRAN (R 4.5.1)
#>  shiny                  1.11.1    2025-07-03 [2] CRAN (R 4.5.1)
#>  shinyWidgets           0.9.0     2025-02-21 [2] CRAN (R 4.5.1)
#>  SingleCellExperiment * 1.31.1    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  SparseArray            1.9.1     2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  sparseMatrixStats      1.21.0    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  SpatialExperiment      1.19.1    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  spatialLIBD            1.21.6    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  statmod                1.5.0     2023-01-06 [2] CRAN (R 4.5.1)
#>  stringi                1.8.7     2025-03-27 [2] CRAN (R 4.5.1)
#>  stringr                1.5.2     2025-09-08 [2] CRAN (R 4.5.1)
#>  SummarizedExperiment * 1.39.2    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  tibble               * 3.3.0     2025-06-08 [2] CRAN (R 4.5.1)
#>  tidyr                * 1.3.1     2024-01-24 [2] CRAN (R 4.5.1)
#>  tidyselect             1.2.1     2024-03-11 [2] CRAN (R 4.5.1)
#>  timechange             0.3.0     2024-01-18 [2] CRAN (R 4.5.1)
#>  utf8                   1.2.6     2025-06-08 [2] CRAN (R 4.5.1)
#>  vctrs                  0.6.5     2023-12-01 [2] CRAN (R 4.5.1)
#>  vipor                  0.4.7     2023-12-18 [2] CRAN (R 4.5.1)
#>  viridis                0.6.5     2024-01-29 [2] CRAN (R 4.5.1)
#>  viridisLite            0.4.2     2023-05-02 [2] CRAN (R 4.5.1)
#>  withr                  3.0.2     2024-10-28 [2] CRAN (R 4.5.1)
#>  xfun                   0.53      2025-08-19 [2] CRAN (R 4.5.1)
#>  XML                    3.99-0.19 2025-08-22 [2] CRAN (R 4.5.1)
#>  xml2                   1.4.0     2025-08-20 [2] CRAN (R 4.5.1)
#>  xtable                 1.8-4     2019-04-21 [2] CRAN (R 4.5.1)
#>  XVector                0.49.1    2025-10-07 [2] Bioconductor 3.22 (R 4.5.1)
#>  yaml                   2.3.10    2024-07-26 [2] CRAN (R 4.5.1)
#> 
#>  [1] /tmp/Rtmp9GLe7a/Rinst122a944215b66d
#>  [2] /home/biocbuild/bbs-3.22-bioc/R/site-library
#>  [3] /home/biocbuild/bbs-3.22-bioc/R/library
#>  * ── Packages attached to the search path.
#> 
#> ──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────[1] C. Ahlmann-Eltze, P. Hickey, and H. Pagès. MatrixGenerics: S4 Generic Summary Statistic Functions that Operate on Matrix-Like Objects. R package version 1.21.0. 2025. DOI: 10.18129/B9.bioc.MatrixGenerics. URL: https://bioconductor.org/packages/MatrixGenerics.
[2] J. Allaire, Y. Xie, C. Dervieux, et al. rmarkdown: Dynamic Documents for R. R package version 2.30. 2025. URL: https://github.com/rstudio/rmarkdown.
[3] R. Amezquita, A. Lun, E. Becht, et al. “Orchestrating single-cell analysis with Bioconductor”. In: Nature Methods 17 (2020), pp. 137–145. URL: https://www.nature.com/articles/s41592-019-0654-x.
[4] P. Hickey. DelayedMatrixStats: Functions that Apply to Rows and Columns of ‘DelayedMatrix’ Objects. R package version 1.31.0. 2025. DOI: 10.18129/B9.bioc.DelayedMatrixStats. URL: https://bioconductor.org/packages/DelayedMatrixStats.
[5] L. A. Huuki-Myers, K. R. Maynard, S. C. Hicks, et al. DeconvoBuddies: a R/Bioconductor package with deconvolution helper functions. https://github.com/LieberInstitute/DeconvoBuddies/DeconvoBuddies - R package version 1.1.5. 2025. DOI: 10.18129/B9.bioc.DeconvoBuddies. URL: http://www.bioconductor.org/packages/DeconvoBuddies.
[6] L. A. Huuki-Myers, K. D. Montgomery, S. H. Kwon, et al. “Benchmark of cellular deconvolution methods using a multi-assay dataset from postmortem human prefrontal cortex”. In: Genome Biol (2025). DOI: 10.1186/s13059-025-03552-3. URL: https://doi.org/10.1186/s13059-025-03552-3.
[7] R. A. Irizarry and M. I. Love. rafalib: Convenience Functions for Routine Data Exploration. R package version 1.0.4. 2025. DOI: 10.32614/CRAN.package.rafalib. URL: https://CRAN.R-project.org/package=rafalib.
[8] A. T. L. Lun, D. J. McCarthy, and J. C. Marioni. “A step-by-step workflow for low-level analysis of single-cell RNA-seq data with Bioconductor”. In: F1000Res. 5 (2016), p. 2122. DOI: 10.12688/f1000research.9501.2.
[9] M. W. McLean. “RefManageR: Import and Manage BibTeX and BibLaTeX References in R”. In: The Journal of Open Source Software (2017). DOI: 10.21105/joss.00338.
[10] M. Morgan, V. Obenchain, J. Hester, et al. SummarizedExperiment: A container (S4 class) for matrix-like assays. R package version 1.39.2. 2025. DOI: 10.18129/B9.bioc.SummarizedExperiment. URL: https://bioconductor.org/packages/SummarizedExperiment.
[11] M. Morgan and L. Shepherd. AnnotationHub: Client to access AnnotationHub resources. R package version 3.99.6. 2025. DOI: 10.18129/B9.bioc.AnnotationHub. URL: https://bioconductor.org/packages/AnnotationHub.
[12] M. Morgan and L. Shepherd. ExperimentHub: Client to access ExperimentHub resources. R package version 2.99.5. 2025. DOI: 10.18129/B9.bioc.ExperimentHub. URL: https://bioconductor.org/packages/ExperimentHub.
[13] K. Müller and H. Wickham. tibble: Simple Data Frames. R package version 3.3.0. 2025. DOI: 10.32614/CRAN.package.tibble. URL: https://CRAN.R-project.org/package=tibble.
[14] A. Oleś. BiocStyle: Standard styles for vignettes and other Bioconductor documents. R package version 2.37.1. 2025. DOI: 10.18129/B9.bioc.BiocStyle. URL: https://bioconductor.org/packages/BiocStyle.
[15] H. Pagès, M. Lawrence, and P. Aboyoun. S4Vectors: Foundation of vector-like and list-like containers in Bioconductor. R package version 0.47.4. 2025. DOI: 10.18129/B9.bioc.S4Vectors. URL: https://bioconductor.org/packages/S4Vectors.
[16] B. Pardo, A. Spangler, L. M. Weber, et al. “spatialLIBD: an R/Bioconductor package to visualize spatially-resolved transcriptomics data”. In: BMC Genomics (2022). DOI: 10.1186/s12864-022-08601-w. URL: https://doi.org/10.1186/s12864-022-08601-w.
[17] R Core Team. R: A Language and Environment for Statistical Computing. R Foundation for Statistical Computing. Vienna, Austria, 2025. URL: https://www.R-project.org/.
[18] L. Shepherd and M. Morgan. BiocFileCache: Manage Files Across Sessions. R package version 2.99.6. 2025. DOI: 10.18129/B9.bioc.BiocFileCache. URL: https://bioconductor.org/packages/BiocFileCache.
[19] H. Wickham. “Reshaping Data with the reshape Package”. In: Journal of Statistical Software 21.12 (2007), pp. 1–20. URL: http://www.jstatsoft.org/v21/i12/.
[20] H. Wickham. ggplot2: Elegant Graphics for Data Analysis. Springer-Verlag New York, 2016. ISBN: 978-3-319-24277-4. URL: https://ggplot2.tidyverse.org.
[21] H. Wickham. stringr: Simple, Consistent Wrappers for Common String Operations. R package version 1.5.2. 2025. DOI: 10.32614/CRAN.package.stringr. URL: https://CRAN.R-project.org/package=stringr.
[22] H. Wickham, R. François, L. Henry, et al. dplyr: A Grammar of Data Manipulation. R package version 1.1.4. 2023. DOI: 10.32614/CRAN.package.dplyr. URL: https://CRAN.R-project.org/package=dplyr.
[23] H. Wickham and L. Henry. purrr: Functional Programming Tools. R package version 1.1.0. 2025. DOI: 10.32614/CRAN.package.purrr. URL: https://CRAN.R-project.org/package=purrr.
[24] Y. Xie. knitr: A General-Purpose Package for Dynamic Report Generation in R. R package version 1.50. 2025. URL: https://yihui.org/knitr/.