A computational toolkit in R for the integration, exploration, and analysis of high-dimensional single-cell cytometry and imaging data.
Current version: v1.1.0
Spectre is an R package that enables comprehensive end-to-end integration and analysis of high-dimensional cytometry data from different batches or experiments. Spectre streamlines the analytical stages of raw data pre-processing, batch alignment, data integration, clustering, dimensionality reduction, visualisation and population labelling, as well as quantitative and statistical analysis. To manage large cytometry datasets, Spectre was built on the data.table framework – this simple table-like structure allows for fast and easy processing of large datasets in R. Critically, the design of Spectre allows for a simple, clear, and modular design of analysis workflows, that can be utilised by data and laboratory scientists. Recently we have extended the functionality of Spectre to support the analysis of Imaging Mass Cytometry (IMC) and scRNAseq data. For more information, please see our paper: Ashhurst TM, Marsh-Wakefield F, Putri GH et al. (2021). Cytometry A. DOI: 10.1002/cyto.a.24350.
Spectre was developed by Thomas Ashhurst, Felix Marsh-Wakefield, and Givanna Putri.
If you use Spectre in your work, please consider citing Ashhurst TM, Marsh-Wakefield F, Putri GH et al. (2021). Cytometry A. DOI: 10.1002/cyto.a.24350. To continue providing open-source tools such as Spectre, it helps us if we can demonstrate that our efforts are contributing to analysis efforts in the community. Please also consider citing the authors of the individual packages or tools (e.g. CytoNorm, FlowSOM, tSNE, UMAP, etc) that are critical elements of your analysis work.
Usage instructions and protocols are available from https://immunedynamics.github.io/spectre.
Detailed installation instructions are available from https://immunedynamics.github.io/spectre. Spectre can be installed in R directly, or can be used via a pre-compiled Docker image. Brief instructions below.
In v1.1 we have removed the package dependencies rgeos
and rgdal
as these are no longer available on CRAN. The package should install fine without these dependencies, but some spatial functions may not work properly. If required, one can download the archived packages, unzip them, and then placed them in the R library location.
Install and load the 'devtools' library.
if(!require('devtools')) {install.packages('devtools')}
library('devtools')
Subsequently, use the 'install_github' function to install and load the Spectre package. By default this will load the 'master' branch, which is the same as the latest stable release version (listed at https://github.com/immunedynamics/Spectre/releases). To install a specific release version, see https://cran.r-project.org/web/packages/githubinstall/vignettes/githubinstall.html.
install_github("immunedynamics/spectre")
You will see the following returned. We suggest selecting 'none' (in this example, by entering '3' and pressing return) to avoid updating other packages. You can update your packages after installation.
Downloading GitHub repo immunedynamics/spectre@master
These packages have more recent versions available.
Which would you like to update?
1: All
2: CRAN packages only
3: None
4: data.table (1.12.0 -> 1.12.2) [CRAN]
... etc
If the package is sucessfully installed, you can load the library using:
library("Spectre")
You can then check for whether all of the packages for Spectre have been loaded correctly using the following commands
## Check if all required packages have been installed
Spectre::package.check()
## Load all required packages
Spectre::package.load()
Alternatively, you can go to releases (https://github.com/immunedynamics/spectre/releases) and download the latest stable release -- which can then be installed in R.
Install a 'container' version of Spectre using Docker, that contains a pre-built environment with all the required packages necessary to use Spectre. Please see this page for instructions.
The Spectre package was constructed on the basis of the CAPX workflow in R (https://sydneycytometry.org.au/capx). Along with the various R packages used within Spectre, we would like to acknowledge the Seurat and cytofkit R packages from providing inspiration for elements of the package design.