# StabMap: Stabilised mosaic single cell data integration using unshared features
<img src="man/figures/hex.png" align="right" height="250" width="250"/>
## Installation
Install `StabMap` via Bioconductor
``` r
library(BiocManager)
BiocManager::install("StabMap")
```
Install the Github version of StabMap
``` r
BiocManager::install("SydneyBioX/StabMap")
```
## Vignette
You can find the vignette showing how StabMap can be used with PBMC single cell data at this [website](https://marionilab.github.io/StabMap/articles/stabMap_PBMC_Multiome.html).
## Method
<img src="man/figures/method.png" align="middle" width="80%"/>
**Figure: StabMap method overview.**\
a. Example mosaic data integration displaying observed data matrices with varying overlap of features among the datasets. Datasets are summarised using the mosaic data topology (MDT). Cells are then projected onto the common StabMap embedding across all cells.\
b. Cells from all datasets are projected onto the reference space (dark red) by traversing the shortest paths along the MDT. Blue cells are projected directly onto the reference space, whereas yellow cells are first projected onto the space defined by the blue cells, followed by projection to the dark red space. All cells are then combined to yield the common StabMap embedding.\
c. The process described in panel b is performed for various selected reference datasets (default = all), followed by L2-norm re-weighting provided by the user (default = equal weight). These reweighted embeddings are then concatenated to form the StabMap embedding for multiple reference datasets, and can be used for further downstream analysis tasks.
## Contact
shila.ghazanfar \<at\> sydney.edu.au, or marioni \<at\> ebi.ac.uk.