Skip to content

R implementation of integration metrics for single-cell data

License

Notifications You must be signed in to change notification settings

carmonalab/scIntegrationMetrics

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

48 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

scIntegrationMetrics

A collection of metrics to evaluate scRNA-seq data integration quality, including LISI, per-cell type LISI, and silhouette average width (ASW).

This package is based on immunogenomics/LISI; it adds new metrics and can be applied directly on Seurat objects. For a description and motivation for the new metrics see sections below and refer to Andreatta et al. (2023) bioRxiv preprint.

Installation

    install.packages("remotes")
    library(remotes)
    remotes::install_github("carmonalab/scIntegrationMetrics")

Usage

To illustrate how to calculate these integration metrics, we will start from a collection of pancreas datasets sequenced with different technologies and distributed with SeuratData.

First, install the data:

devtools::install_github('satijalab/seurat-data')
library(SeuratData)
library(Seurat)

InstallData("panc8")
data("panc8")

panc8 <- panc8 |> NormalizeData() |>
  FindVariableFeatures() |>
  ScaleData() |> RunPCA(npcs=20)

We can calculate metrics for batch mixing and cell type separation on this unintegrated object, by specifying the metadata columns that contain batch and cell type information ("tech" and "celltype" respectively):

library(scIntegrationMetrics)

metrics <- getIntegrationMetrics(panc8, meta.label = "celltype",
                                 meta.batch = "tech",
                                 iLISI_perplexity = 20)

unlist(metrics)
iLISI              1.08611688
norm_iLISI         0.02152922
CiLISI             0.02364108
CiLISI_means       0.08793179
norm_cLISI         0.96961856
norm_cLISI_means   0.87557344
celltype_ASW       0.15838012
celltype_ASW_means 0.21731279

We can apply an integration method such as STACAS to mitigate batch effects:

remotes::install_github("carmonalab/STACAS")
library(STACAS)
panc8.list <- SplitObject(panc8, split.by = "tech")

panc8.stacas <- Run.STACAS(panc8.list)

We can then calculate metrics after integration, and verify whether batch mixing and cell type separation were improved upon integration:

metrics.integrated <- getIntegrationMetrics(panc8.stacas, meta.label = "celltype",
                                 meta.batch = "tech",
                                 iLISI_perplexity = 20)
unlist(metrics.integrated)
iLISI              2.0815327
norm_iLISI         0.2703832
CiLISI             0.2705296
CiLISI_means       0.2886549
norm_cLISI         0.9861910
norm_cLISI_means   0.8945726
celltype_ASW       0.2872263
celltype_ASW_means 0.3309478

Metrics implemented in the package

  • iLISI: Local Inverse Simpson's Index (LISI) for batch mixing, as defined by Korsunsky et al. Nat Methods (2019); it quantifies the effective number of datasets in a local neighborhood, thereby measuring batch mixing.

  • norm_iLISI: iLISI normalized between 0 and 1.

  • CiLISI: iLISI is computed separately for each cell type, and normalized between 0 and 1.

  • CiLISI_means: As CiLISI, but returns the mean of means per cell type instead of global mean.

  • norm_cLISI: LISI is calculated on the cell type labels, quantifying the effective number of cell types in a local neighborhood. We calculate this quantity as norm_cLISI = 1 - normalized cell-type LISI, to vary between 0 (bad cell type separation) to 1 (perfect cell type separation)

  • norm_cLISI_means: As norm_cLISI, but using mean of means per cell type instead of global mean.

  • celltype_ASW: Average Silhouette Width by celltype: it quantifies distances of cells of the same type compared to the distances to cells of other types.

  • celltype_ASW_means: As celltype_ASW, but using mean of means per cell type instead of global mean

References

  • Andreatta, M., Herault, L., Gueguen, P., Gfeller, D., Berenstein, A. J., & Carmona, S. J. (2023). Semi-supervised integration of single-cell transcriptomics data. bioRxiv, 2023-07

  • Korsunsky, I., Millard, N., Fan, J., Slowikowski, K., Zhang, F., Wei, K., ... & Raychaudhuri, S. (2019). Fast, sensitive and accurate integration of single-cell data with Harmony. Nature methods, 16(12), 1289-1296

About

R implementation of integration metrics for single-cell data

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • R 80.6%
  • C++ 19.4%