Skip to content

Single cell RNA-seq preprocessing tool for gene-by-cell matrices of UMI counts. It is recommended to use the raw spliced and unpliced counts matrices produced by scKB pipeline as the input of copilot.

License

Notifications You must be signed in to change notification settings

ohlerlab/COPILOT

 
 

Repository files navigation

COPILOT (Cell preprOcessing PIpeline kaLlistO busTools)

Single cell RNA-seq preprocessing tool for gene-by-cell matrices of UMI counts. The uitily and summary file offered by this tool is directly comparable to CellRanger 3.1, the tool developed by 10X Genomics. It is recommended to use the raw spliced and unpliced counts matrices produced by scKB pipeline as the input of COPILOT.

Citation

Shahan, R., Hsu, C.-W., Nolan, T.M., Cole, B.J., Taylor, I.W., Greenstreet, L., Zhang, S., Afanassiev, A., Vlot, A.H.C., Schiebinger, G., Benfey, P.N., Ohler, U., 2022. A single-cell Arabidopsis root atlas reveals developmental trajectories in wild-type and cell identity mutants. Developmental Cell S1534580722000338. https://doi.org/10.1016/j.devcel.2022.01.008

Advantages over CellRanger 3.1

  1. Since scKB and COPILOT incorporates kallisto, which is a read aligner using peudoalignment, they are about ~ 30 times faster than CellRanger 3.1 in processing time.

  2. If user wants to calculate RNA velocity or infer trajectory based on splicing dynamics in downstream analysis, then COPILOT along with scKB are the right choice, since together they produce spliced and unspliced quality-filtered count matrices.

  3. If user wants to use specific sets of genes that represent the signal of noise or low quality cells for cell-filtering, COPILOT offers such function.

Dependencies

R (>= 3.6.1)

R packages: Seurat (>= 3.1.4), Matrix, scales, rjson, gridExtra, ggplot2, DoubletFinder, DropletUtils, R2HTML

Python modules: umap-learn (required), leidenalg (optional)

Installation (in R/RStudio)

devtools::install_github('Hsu-Che-Wei/COPILOT')

Docker Image

#Pull image from docker hub   
docker pull cheweihsu/copilot:latest

#Run image
docker run -it -d cheweihsu/copilot:latest

#Check running image ID
docker ps -a

#Enter the container
docker exec -it {image ID} bash

#In the container, activate conda environment "copilot"
conda activate copilot

#Then you can run copilot in R!

Tutorial

0-COPILOT_tutorial

0-COPILOT_tutorial_toy_data

COPILOT summary file

COPILOT_Summary

Please check out examples of COPILOT summary file here, or check out the folder named "COPILOT_summary_file".

Usage

copilot( sample.name, spliced.mtx = NULL, unspliced.mtx = NULL, total.mtx = NULL, filtered.mtx.output.dir = NULL, species.name = "Not Provided", transcriptome.name = "Not Provided", sample.stats = NULL, mt.pattern, mt.threshold = 5, cp.pattern = NULL, top.percent = 1, filtering.ratio = 1, estimate.doublet.rate = TRUE, doublet.rate = NULL, remove.doublet = TRUE, do.seurat = TRUE, do.annotation = FALSE, unwanted.genes = NULL, HVG = FALSE, HVGN = 200, dir_to_bulk = NULL, dir_to_color_scheme = NULL, clustering_alg = 3, res = 0.5, min.UMI.low.quality = 100, min.UMI.high.quality = 300, legend.position = c(0.8, 0.8) )

Arguments

  • sample.name: User defined sample name (character), which should be the same as the name of directory that contains spliced and unspliced matrices if you are following scKB pipeline to produce raw counts matrices.
  • spliced.mtx: Gene by cell matrix of spliced counts, which should have column and row names, Default is NULL.
  • unspliced.mtx: Gene by cell matrix of unspliced counts, which should have column and row names. Default is NULL.
  • total.mtx: Gene by cell matrix of total counts, which should have column and row names. Default is NULL.
  • filtered.mtx.output.dir: Output directory for quality filtered matrices. Default is NULL.
  • species.name: Species name (character). Default is "Not Provided".
  • transcriptome.name: Name of transcriptome annotation file. (e.g. TAIR10 for Arabidopsis). Default is "Not Provided".
  • sample.stats: Meta data of the sample in data.frame format. Default is NULL.
  • mt.pattern: Pattern of mitochondrial gene names/ids (character; e.g. "ATMG") or list of mitochondrial genes (character vector). This argument is required to run copilot.
  • mt.threshold: Threshold of mitochondrial expression percentage. Cell would be treated as dying cell if it has mitochodrial expression percentage higher than this threshold (numeric). Default is 5.
  • cp.pattern: Pattern of chloroplast gene names/ids (character; e.g. "ATCG") or list of chloroplast genes (character vector). Default is NULL.
  • top.percent: Percentage of cells that contain high numer of UMIs filtered (numeric). Default is 1.
  • filtering.ratio: Metric that controls the stringency of cell filtering (lenient: 1; strict:0; moderate: 0 < filtering.ratio < 1; numeric). Default is 1.
  • estimate.doublet.rate: Whether or not to estimate doublet rate according to 10X Genomics' estimation (boolean). Default is TRUE.
  • doublet.rate: User specified doublet rate (numeric). Default is NULL.
  • remove.doublet: Whether or not to remove doublets after quality filtering of gene and cell (boolean). Default is TRUE.
  • do.seurat: Whether or not to perform normalization, PCA, UMAP and clustering using Seurat and output a Seurat object (boolean). Default is TRUE.
  • do.annotation: Whether or not to do annotation (boolean). COPILOT only supports annotation on root of Arabidopsis thaliana. Default is FALSE.
  • unwanted.genes: Gene IDs/names of unwanted genes (character vector, e.g. cell cycle related genes, organelle genes ... etc). Default is NULL.
  • HVG: Whether or not to select highly variable genes (boolean). Default is FALSE.
  • HVGN: Number of highly variable genes selected (numeric). Defalut is 200.
  • dir_to_bulk: Directory to reference expression profile for annotation. Default is NULL.
  • dir_to_color_scheme: Directory to color scheme file for annotation. Default is NULL.
  • clustering_alg: Algorithm for clustering (1 = original Louvain algorithm; 2 = Louvain algorithm with multilevel refinement; 3 = SLM algorithm; 4 = Leiden algorithm, which requires the leidenalg python; numeric). Default is 3.
  • res: Resolution used for clustering (numeric). Default is 0.5.
  • min.UMI.low.quality: Minimum UMIs for a barcode to be considered as cell (numeric). Default is 100.
  • min.UMI.high.quality: Minimum UMIs for a cell to be considered as high quality cell (numeric). Default is 300.
  • legend.position: x y position of the legend on UMI histogram plot (numeric vector of length 2). Default is c(0.8,0.8).

Caution

It is recommended to use the raw spliced and unpliced counts matrices produced by scKB pipeline as the input of copilot, and run copilot in the working directory that contains folder with raw matrices inside. Note that the folder name should be the same as the argument "sample.name". Alternatively, user can directly feed the matrices to copilot in R by filling in the arguments "spliced.mtx", "unspliced.mtx" and "total.mtx". Note that if "total.mtx" is provided, then please let the "spliced.mtx", "unspliced.mtx" remain as NULL, and vise versa.

COPILOT relies on detecting the distribution of cells enriched in mitochondrial expression (putative dying cells) to identify the initial filtering threshold for low quality cells. Thus, even though user is confident that the library does not contain dying cells, it is still required for user to provide list of mitochondrial gene IDs or a character pattern that is shared among those gene IDs (See argument "mt.pattern"). Alternatively, user can provide genes that represent the signal of noise or low quality cells.

If the algorithm detects no putative dying cells, the initial filtering threshold will then be set as what user feed to argument "min.UMI.high.quality". It is recommended to play around with this argument until the number of high quality cell remains after filtering makes sense.

For users that have scRNA-seq data of Arabidopsis thaliana root, and wish to perform correlation-based annotation, please make sure that all necessary files are downloaded from folder named "supp_data".

Application

One can find here codes demonstrating how some typical downstream analysis of scRNA-seq were performed on COPILOT-preprocessed data. The codes also demonstrate how analysis in Shahan & Hsu et al. 2022 were done.

1-Basic_Seurat_Analysis_&_Correlation_Based_Annotation

2-Integration

3-1-novoSpaRc

3-2-novoSpaRc_to_Atlas

4-1-Prepare_SEMITONES_Input

4-2-Prepare_SEMITONES_Input_2

4-3-Marker_Annotation_By_SEMITONES

5-ICI_Computation

6-CytoTRACE

7-Combine_and_Finalize_Annotation

8-Extract_Tissue_Lineage

9-scVelo_Latent_Time

10-Consensus_Time

11_Label_Transfer

12-1-Atlas_FindMarkers

12-2-Endo_Cortex_Heatmap

12-3-WT_SCR_SHR_Heatmap

13-Differential_Abundance_Analysis

14-Ploidy_Annotation

About

Single cell RNA-seq preprocessing tool for gene-by-cell matrices of UMI counts. It is recommended to use the raw spliced and unpliced counts matrices produced by scKB pipeline as the input of copilot.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • HTML 52.3%
  • Jupyter Notebook 47.7%