Introduction to iSEEhub

Introduction

iSEEhub is an extension to the iSEE Bioconductor package that provides a link between iSEE and the Bioconductor ExperimentHub.

Specifically, iSEEhub adds a custom landing page to iSEE web applications that can be used to browse the Bioconductor ExperimentHub interactively, and loads a selected data set in the standard iSEE user interface.

Basics

Install iSEEhub

R is an open-source statistical environment which can be easily modified to enhance its functionality via packages. iSEEhub 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 iSEEhub by using the following commands in your R session:

if (!requireNamespace("BiocManager", quietly = TRUE)) {
      install.packages("BiocManager")
  }

BiocManager::install("iSEEhub")

## Check that you have a valid Bioconductor installation
BiocManager::valid()

Required knowledge

iSEEhub is based on many other packages that have implemented the infrastructure needed for dealing with omics data and interactive visualisation. That is, packages like SummarizedExperiment, SingleCellExperiment, iSEE and shiny.

If you are asking yourself the question “Where do I start using Bioconductor?” you might be interested in this blog post.

Asking for help

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 iSEEhub 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.

Citing iSEEhub

We hope that iSEEhub will be useful for your research. Please use the following information to cite the package and the overall approach. Thank you!

## Citation info
citation("iSEEhub")
#> To cite package 'iSEEhub' in publications use:
#> 
#>   Rue-Albrecht K (2024). _iSEEhub: iSEE for the Bioconductor ExperimentHub_. R package version 1.9.0,
#>   <https://github.com/iSEE/iSEEhub>.
#> 
#> A BibTeX entry for LaTeX users is
#> 
#>   @Manual{,
#>     title = {iSEEhub: iSEE for the Bioconductor ExperimentHub},
#>     author = {Kevin Rue-Albrecht},
#>     year = {2024},
#>     note = {R package version 1.9.0},
#>     url = {https://github.com/iSEE/iSEEhub},
#>   }

Here is an example of you can cite your package inside the vignette:

Quick start to using to iSEEhub

The main functionality of the package is available through the function iSEEhub().

The function returns a shiny app that can then be launched using the function shiny::runApp().

library(iSEEhub)
library(ExperimentHub)
ehub <- ExperimentHub()

app <- iSEEhub(ehub)

if (interactive()) {
  shiny::runApp(app, port = 1234)
}

The ExperimentHub pane

Datasets available in the Bioconductor ExperimentHub are listed – along with metadata – in the interactive table on the left.

The table may be filtered and sorted using any metadata column, to efficiently browse the datasets available.

By default, only a subset of metadata columns are displayed. The selectize input labelled Show columns: at the top of the pane may be used to add, remove, or reorder columns in the table.

No more than one dataset may be selected at any time.

The Selected Dataset pane

Overview

The pane on the right updates with the currently selected dataset.

This pane contains information and inputs required to load the currently selected dataset in the main iSEE app.

The pane is composed of two tabs described in the following sections.

The Info tab

The Info tab displays the full metadata associated with the currently selected dataset – the same metadata as in the ExperimentHub table – in formatted text.

As such, users can uses a minimal subset of columns in the table to efficiently browse available datasets, while having a full overview of the currently selected dataset in this tab.

The Config tab

The Config tab displays a selectize input offering users a choice of initial app configurations that are specific to the currently selected dataset.

For all datasets, an option Default is available. That option does not provide any specific instruction with respect to the initial set of panels, their layout, nor their respective initial settings. Instead, the Default option prompts the app to automatically identify all the built-in iSEE panel classes that are compatible with the loaded dataset, initialising an app that contains one instance of each of those panels.

The number of panels and data points to draw for large datasets makes the Default option a showcase mode for demonstration and for new users, more than one optimised for a short loading time or featuring specific aspects of the dataset.

For some datasets, additional choices of initial settings are available. Configurations are provided as scripts that define the list of panels and their respective initial configuration when the main iSEE app is launched.

To contribute new scripts, please refer to the vignette Contributing to iSEEhub.

For demonstration, a simple example config_1.R is included for the dataset EH1. When selected, the contents of the configuration file are shown in the pane – including any comment from the authors – allowing users to review the script before using it.

When the appropriate configuration is selected, users may click the Launch! button to load the dataset into the main iSEE app.

The main iSEE app

Once the dataset is successfully loaded into the R session, the app will switch to the main iSEE view.

Managing dataset dependencies

Overview

Each dataset in the Bioconductor ExperimentHub is associated with package dependencies that are required to handle the dataset in an R session. Package dependencies must be installed in the R library before the corresponding dataset can be loaded.

The list of packages associated with all datasets types supported by iSEEhub is regularly updated in the Suggests: field of the DESCRIPTION file. However, those packages are not automatically installed in a minimal installation of the iSEEhub package.

From the R console

By default, iSEEhub(..., runtime_install = FALSE) prevents the app from installing those dependencies at runtime. In that case, when users identify a missing dependency, they must interrupt the app, install the required package(s) using the R console, and re-launch the app. We recommend this approach for applications hosted on public web-servers.

From the live app

Alternatively, iSEEhub(..., runtime_install = TRUE) can be used to launch an app that prompts users interactively (i.e., within the app) for their consent to install missing dependencies. We recommend this approach for applications run on personal computers (unless users prefer to install packages themselves, of course).

Reproducibility

The iSEEhub package (Rue-Albrecht, 2024) was made possible thanks to:

This package was developed using biocthis.

Code for creating the vignette

## Create the vignette
library("rmarkdown")
system.time(render("iSEEhub.Rmd", "BiocStyle::html_document"))

## Extract the R code
library("knitr")
knit("iSEEhub.Rmd", tangle = TRUE)

Date the vignette was generated.

#> [1] "2024-10-30 08:31:54 UTC"

Wallclock time spent generating the vignette.

#> Time difference of 8.064 secs

R session information.

#> ─ Session info ───────────────────────────────────────────────────────────────────────────────────────────────────────
#>  setting  value
#>  version  R version 4.4.1 (2024-06-14)
#>  os       Ubuntu 24.04.1 LTS
#>  system   x86_64, linux-gnu
#>  ui       X11
#>  language (EN)
#>  collate  C
#>  ctype    en_US.UTF-8
#>  tz       Etc/UTC
#>  date     2024-10-30
#>  pandoc   3.2.1 @ /usr/local/bin/ (via rmarkdown)
#> 
#> ─ Packages ───────────────────────────────────────────────────────────────────────────────────────────────────────────
#>  package              * version date (UTC) lib source
#>  abind                  1.4-8   2024-09-12 [2] RSPM (R 4.4.0)
#>  AnnotationDbi          1.69.0  2024-10-30 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  AnnotationHub        * 3.15.0  2024-10-30 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  backports              1.5.0   2024-05-23 [2] RSPM (R 4.4.0)
#>  bibtex                 0.5.1   2023-01-26 [2] RSPM (R 4.4.0)
#>  Biobase              * 2.67.0  2024-10-30 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  BiocFileCache        * 2.15.0  2024-10-30 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  BiocGenerics         * 0.53.0  2024-10-30 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  BiocManager            1.30.25 2024-08-28 [2] RSPM (R 4.4.0)
#>  BiocStyle            * 2.35.0  2024-10-30 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  BiocVersion            3.21.1  2024-10-30 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  Biostrings             2.75.0  2024-10-30 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  bit                    4.5.0   2024-09-20 [2] RSPM (R 4.4.0)
#>  bit64                  4.5.2   2024-09-22 [2] RSPM (R 4.4.0)
#>  blob                   1.2.4   2023-03-17 [2] RSPM (R 4.4.0)
#>  bslib                  0.8.0   2024-07-29 [2] RSPM (R 4.4.0)
#>  buildtools             1.0.0   2024-10-28 [3] local (/pkg)
#>  cachem                 1.1.0   2024-05-16 [2] RSPM (R 4.4.0)
#>  circlize               0.4.16  2024-02-20 [2] RSPM (R 4.4.0)
#>  cli                    3.6.3   2024-06-21 [2] RSPM (R 4.4.0)
#>  clue                   0.3-65  2023-09-23 [2] RSPM (R 4.4.0)
#>  cluster                2.1.6   2023-12-01 [2] RSPM (R 4.4.0)
#>  codetools              0.2-20  2024-03-31 [2] RSPM (R 4.4.0)
#>  colorspace             2.1-1   2024-07-26 [2] RSPM (R 4.4.0)
#>  colourpicker           1.3.0   2023-08-21 [2] RSPM (R 4.4.0)
#>  ComplexHeatmap         2.23.0  2024-10-30 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  crayon                 1.5.3   2024-06-20 [2] RSPM (R 4.4.0)
#>  curl                   5.2.3   2024-09-20 [2] RSPM (R 4.4.0)
#>  DBI                    1.2.3   2024-06-02 [2] RSPM (R 4.4.0)
#>  dbplyr               * 2.5.0   2024-03-19 [2] RSPM (R 4.4.0)
#>  DelayedArray           0.33.1  2024-10-30 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  digest                 0.6.37  2024-08-19 [2] RSPM (R 4.4.0)
#>  doParallel             1.0.17  2022-02-07 [2] RSPM (R 4.4.0)
#>  dplyr                  1.1.4   2023-11-17 [2] RSPM (R 4.4.0)
#>  DT                     0.33    2024-04-04 [2] RSPM (R 4.4.0)
#>  evaluate               1.0.1   2024-10-10 [2] RSPM (R 4.4.0)
#>  ExperimentHub        * 2.13.1  2024-10-28 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  fansi                  1.0.6   2023-12-08 [2] RSPM (R 4.4.0)
#>  fastmap                1.2.0   2024-05-15 [2] RSPM (R 4.4.0)
#>  filelock               1.0.3   2023-12-11 [2] RSPM (R 4.4.0)
#>  fontawesome            0.5.2   2023-08-19 [2] RSPM (R 4.4.0)
#>  foreach                1.5.2   2022-02-02 [2] RSPM (R 4.4.0)
#>  generics               0.1.3   2022-07-05 [2] RSPM (R 4.4.0)
#>  GenomeInfoDb         * 1.41.2  2024-10-02 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  GenomeInfoDbData       1.2.13  2024-10-30 [2] Bioconductor
#>  GenomicRanges        * 1.57.2  2024-10-29 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  GetoptLong             1.0.5   2020-12-15 [2] RSPM (R 4.4.0)
#>  ggplot2                3.5.1   2024-04-23 [2] RSPM (R 4.4.0)
#>  ggrepel                0.9.6   2024-09-07 [2] RSPM (R 4.4.0)
#>  GlobalOptions          0.1.2   2020-06-10 [2] RSPM (R 4.4.0)
#>  glue                   1.8.0   2024-09-30 [2] RSPM (R 4.4.0)
#>  gtable                 0.3.6   2024-10-25 [2] RSPM (R 4.4.0)
#>  htmltools              0.5.8.1 2024-04-04 [2] RSPM (R 4.4.0)
#>  htmlwidgets            1.6.4   2023-12-06 [2] RSPM (R 4.4.0)
#>  httpuv                 1.6.15  2024-03-26 [2] RSPM (R 4.4.0)
#>  httr                   1.4.7   2023-08-15 [2] RSPM (R 4.4.0)
#>  igraph                 2.1.1   2024-10-19 [2] RSPM (R 4.4.0)
#>  IRanges              * 2.39.2  2024-10-25 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  iSEE                   2.17.4  2024-10-08 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  iSEEhub              * 1.9.0   2024-10-30 [1] https://bioc.r-universe.dev (R 4.4.1)
#>  iterators              1.0.14  2022-02-05 [2] RSPM (R 4.4.0)
#>  jquerylib              0.1.4   2021-04-26 [2] RSPM (R 4.4.0)
#>  jsonlite               1.8.9   2024-09-20 [2] RSPM (R 4.4.0)
#>  KEGGREST               1.45.1  2024-10-16 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  knitr                  1.48    2024-07-07 [2] RSPM (R 4.4.0)
#>  later                  1.3.2   2023-12-06 [2] RSPM (R 4.4.0)
#>  lattice                0.22-6  2024-03-20 [2] RSPM (R 4.4.0)
#>  lifecycle              1.0.4   2023-11-07 [2] RSPM (R 4.4.0)
#>  listviewer             4.0.0   2023-09-30 [2] RSPM (R 4.4.0)
#>  lubridate              1.9.3   2023-09-27 [2] RSPM (R 4.4.0)
#>  magrittr               2.0.3   2022-03-30 [2] RSPM (R 4.4.0)
#>  maketools              1.3.1   2024-10-28 [3] Github (jeroen/maketools@d46f92c)
#>  Matrix                 1.7-1   2024-10-18 [2] RSPM (R 4.4.0)
#>  MatrixGenerics       * 1.17.1  2024-10-23 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  matrixStats          * 1.4.1   2024-09-08 [2] RSPM (R 4.4.0)
#>  memoise                2.0.1   2021-11-26 [2] RSPM (R 4.4.0)
#>  mgcv                   1.9-1   2023-12-21 [2] RSPM (R 4.4.0)
#>  mime                   0.12    2021-09-28 [2] RSPM (R 4.4.0)
#>  miniUI                 0.1.1.1 2018-05-18 [2] RSPM (R 4.4.0)
#>  munsell                0.5.1   2024-04-01 [2] RSPM (R 4.4.0)
#>  nlme                   3.1-166 2024-08-14 [2] RSPM (R 4.4.0)
#>  pillar                 1.9.0   2023-03-22 [2] RSPM (R 4.4.0)
#>  pkgconfig              2.0.3   2019-09-22 [2] RSPM (R 4.4.0)
#>  plyr                   1.8.9   2023-10-02 [2] RSPM (R 4.4.0)
#>  png                    0.1-8   2022-11-29 [2] RSPM (R 4.4.0)
#>  promises               1.3.0   2024-04-05 [2] RSPM (R 4.4.0)
#>  purrr                  1.0.2   2023-08-10 [2] RSPM (R 4.4.0)
#>  R6                     2.5.1   2021-08-19 [2] RSPM (R 4.4.0)
#>  rappdirs               0.3.3   2021-01-31 [2] RSPM (R 4.4.0)
#>  RColorBrewer           1.1-3   2022-04-03 [2] RSPM (R 4.4.0)
#>  Rcpp                   1.0.13  2024-07-17 [2] RSPM (R 4.4.0)
#>  RefManageR           * 1.4.0   2022-09-30 [2] RSPM (R 4.4.0)
#>  rintrojs               0.3.4   2024-01-11 [2] RSPM (R 4.4.0)
#>  rjson                  0.2.23  2024-09-16 [2] RSPM (R 4.4.0)
#>  rlang                  1.1.4   2024-06-04 [2] RSPM (R 4.4.0)
#>  rmarkdown              2.28    2024-08-17 [2] RSPM (R 4.4.0)
#>  RSQLite                2.3.7   2024-05-27 [2] RSPM (R 4.4.0)
#>  S4Arrays               1.5.11  2024-10-29 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  S4Vectors            * 0.43.2  2024-10-17 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  sass                   0.4.9   2024-03-15 [2] RSPM (R 4.4.0)
#>  scales                 1.3.0   2023-11-28 [2] RSPM (R 4.4.0)
#>  sessioninfo          * 1.2.2   2021-12-06 [2] RSPM (R 4.4.0)
#>  shape                  1.4.6.1 2024-02-23 [2] RSPM (R 4.4.0)
#>  shiny                  1.9.1   2024-08-01 [2] RSPM (R 4.4.0)
#>  shinyAce               0.4.3   2024-10-19 [2] RSPM (R 4.4.0)
#>  shinydashboard         0.7.2   2021-09-30 [2] RSPM (R 4.4.0)
#>  shinyjs                2.1.0   2021-12-23 [2] RSPM (R 4.4.0)
#>  shinyWidgets           0.8.7   2024-09-23 [2] RSPM (R 4.4.0)
#>  SingleCellExperiment * 1.27.2  2024-10-26 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  SparseArray            1.5.45  2024-10-29 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  stringi                1.8.4   2024-05-06 [2] RSPM (R 4.4.0)
#>  stringr                1.5.1   2023-11-14 [2] RSPM (R 4.4.0)
#>  SummarizedExperiment * 1.35.5  2024-10-29 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  sys                    3.4.3   2024-10-04 [2] RSPM (R 4.4.0)
#>  tibble                 3.2.1   2023-03-20 [2] RSPM (R 4.4.0)
#>  tidyselect             1.2.1   2024-03-11 [2] RSPM (R 4.4.0)
#>  timechange             0.3.0   2024-01-18 [2] RSPM (R 4.4.0)
#>  UCSC.utils             1.1.0   2024-10-29 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  utf8                   1.2.4   2023-10-22 [2] RSPM (R 4.4.0)
#>  vctrs                  0.6.5   2023-12-01 [2] RSPM (R 4.4.0)
#>  vipor                  0.4.7   2023-12-18 [2] RSPM (R 4.4.0)
#>  viridisLite            0.4.2   2023-05-02 [2] RSPM (R 4.4.0)
#>  withr                  3.0.2   2024-10-28 [2] RSPM (R 4.4.0)
#>  xfun                   0.48    2024-10-03 [2] RSPM (R 4.4.0)
#>  xml2                   1.3.6   2023-12-04 [2] RSPM (R 4.4.0)
#>  xtable                 1.8-4   2019-04-21 [2] RSPM (R 4.4.0)
#>  XVector                0.45.0  2024-10-02 [2] https://bioc.r-universe.dev (R 4.4.1)
#>  yaml                   2.3.10  2024-07-26 [2] RSPM (R 4.4.0)
#>  zlibbioc               1.51.2  2024-10-21 [2] Bioconductor 3.20 (R 4.4.1)
#> 
#>  [1] /tmp/RtmpcEBlFG/Rinst1d3855e216fd
#>  [2] /github/workspace/pkglib
#>  [3] /usr/local/lib/R/site-library
#>  [4] /usr/lib/R/site-library
#>  [5] /usr/lib/R/library
#> 
#> ──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────

Bibliography

This vignette was generated using BiocStyle (Oleś, 2024) with knitr (Xie, 2024) and rmarkdown (Allaire, Xie, Dervieux et al., 2024) running behind the scenes.

Citations made with RefManageR (McLean, 2017).

[1] J. Allaire, Y. Xie, C. Dervieux, et al. rmarkdown: Dynamic Documents for R. R package version 2.28. 2024. URL: https://github.com/rstudio/rmarkdown.

[2] 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.

[3] A. Oleś. BiocStyle: Standard styles for vignettes and other Bioconductor documents. R package version 2.35.0. 2024. URL: https://github.com/Bioconductor/BiocStyle.

[4] R Core Team. R: A Language and Environment for Statistical Computing. R Foundation for Statistical Computing. Vienna, Austria, 2024. URL: https://www.R-project.org/.

[5] K. Rue-Albrecht. iSEEhub: iSEE for the Bioconductor ExperimentHub. R package version 1.9.0. 2024. URL: https://github.com/iSEE/iSEEhub.

[6] H. Wickham. “testthat: Get Started with Testing”. In: The R Journal 3 (2011), pp. 5–10. URL: https://journal.r-project.org/archive/2011-1/RJournal_2011-1_Wickham.pdf.

[7] H. Wickham, W. Chang, R. Flight, et al. sessioninfo: R Session Information. R package version 1.2.2, https://r-lib.github.io/sessioninfo/. 2021. URL: https://github.com/r-lib/sessioninfo#readme.

[8] Y. Xie. knitr: A General-Purpose Package for Dynamic Report Generation in R. R package version 1.48. 2024. URL: https://yihui.org/knitr/.