Skip to content

pinellolab/CRISPR_Pipeline

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

12 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

CRISPR Pipeline

A comprehensive pipeline for single-cell Perturb-Seq analysis that enables robust processing and analysis of CRISPR screening data at single-cell resolution.

Prerequisites

The following dependencies must be installed before running the pipeline:

Nextflow

Workflow manager for executing the pipeline:

conda install bioconda::nextflow

Mamba

Fast package manager for dependency resolution:

conda install conda-forge::mamba

Singularity

Container platform that must be available in your execution environment.

Installation

To install the pipeline:

git clone https://github.com/pinellolab/CRISPR_Pipeline.git

Input Requirements

File Descriptions

FASTQ Files

  • {sample}_R1.fastq.gz: Contains cell barcode and UMI sequences
  • {sample}_R2.fastq.gz: Contains transcript sequences

YAML Configuration Files

  • rna_seqspec.yml: Defines RNA sequencing structure and parameters
  • guide_seqspec.yml: Specifies guide RNA detection parameters
  • hash_seqspec.yml: Defines cell hashing structure (required if using cell hashing)
  • whitelist.txt: List of valid cell barcodes

Metadata Files

  • guide_metadata.tsv: Contains guide RNA information and annotations
  • hash_metadata.tsv: Cell hashing sample information (required if using cell hashing)
  • pairs_to_test.csv: Defines perturbation pairs for comparison analysis (required if testing predefined pairs)

This pipeline requires a specific data structure to function properly. Below is an overview of the required directory organization:

πŸ“ example_data/
   β”‚
   β”œβ”€β”€ πŸ“ fastq_files/
   β”‚   β”œβ”€β”€ πŸ“„ {sample}_R1.fastq.gz
   β”‚   └── πŸ“„ {sample}_R2.fastq.gz
   β”‚
   β”œβ”€β”€ πŸ“ yaml_files/
   β”‚   β”œβ”€β”€ πŸ“„ rna_seqspec.yml
   β”‚   β”œβ”€β”€ πŸ“„ guide_seqspec.yml
   β”‚   β”œβ”€β”€ πŸ“„ hash_seqspec.yml
   β”‚   └── πŸ“„ whitelist.txt
   β”‚
   β”œβ”€β”€ πŸ“„ guide_metadata.tsv
   β”œβ”€β”€ πŸ“„ hash_metadata.tsv
   └── πŸ“„ pairs_to_test.csv

For detailed specifications, see our documentation.

Running the Pipeline

Configuration Steps

1. Pipeline Settings

Make sure to specify your data paths and analysis parameters in configs/pipeline.config.

2. Resource Configuration

Configure input.config to match your computing environment. For example:

withName:process_name {
   cpus = 4               # Number of CPU cores per mapping process (default: 4)
   memory = 64.GB         # RAM allocation per mapping process (default: 64GB)
}

πŸ’‘ Note: Start with these default values and adjust based on your dataset size and system capabilities.

Running the Pipeline

  1. First, make the scripts executable:

    chmod +x bin/*
  2. Launch the pipeline:

    nextflow run main.nf -c input.config

Monitoring and Troubleshooting

During Execution

  • Watch the terminal output for progress updates
  • Check the .nextflow.log file for detailed execution logs

Common Issues and Solutions

  • Memory errors: Increase the memory parameter in input.config
  • Missing files: Double-check paths in configs/pipeline.config and actual files in example_data

Need help? Check our documentation or raise an issue on GitHub.

Output Description

The output files will be generated in the pipeline_outputs and pipeline_dashboard directory.

Generated Files

Within the pipeline_outputs directory, you will find:

  • inference_mudata.h5mu - MuData format output
  • per_element_output.tsv - Per-element analysis
  • per_guide_output.tsv - Per-guide analysis

Structure:

πŸ“ pipeline_outputs/
   β”œβ”€β”€ πŸ“„ inference_mudata.h5mu    
   β”œβ”€β”€ πŸ“„ per_element_output.tsv    
   └── πŸ“„ per_guide_output.tsv     

For details, see our documentation.

Generated Figures

The pipeline produces several figures:

Within the pipeline_dashboard directory, you will find:

  1. Evaluation Output:

    • network_plot.png: Gene interaction networks visualization.
    • volcano_plot.png: gRNA-gene pairs analysis.
    • IGV files (.bedgraph and bedpe): Genome browser visualization files.
  2. Analysis Figures:

    • knee_plot_scRNA.png: Knee plot of UMI counts vs. barcode index.
    • scatterplot_scrna.png: Scatterplot of total counts vs. genes detected, colored by mitochondrial content.
    • violin_plot.png: Distribution of gene counts, total counts, and mitochondrial content.
    • scRNA_barcodes_UMI_thresholds.png: Number of scRNA barcodes using different Total UMI thresholds.
    • guides_per_cell_histogram.png: Histogram of guides per cell.
    • cells_per_guide_histogram.png: Histogram of cells per guide.
    • guides_UMI_thresholds.png: Simulating the final number of cells with assigned guides using different minimal number thresholds (at least one guide > threshold value). (Use it to inspect how many cells would have assigned guides. This can be used to check if the final number of cells with guides fit with your expected number of cells)
    • guides_UMI_thresholds.png: Histogram of the number of sgRNA represented per cell
    • cells_per_htp_barplot.png: Number of Cells across Different HTOs
    • umap_hto.png: UMAP Clustering of Cells Based on HTOs (The dimensions represent the distribution of HTOs in each cell)
    • umap_hto_singlets.png: UMAP Clustering of Cells Based on HTOs (multiplets removed)
  3. seqSpec Plots:

    • seqSpec_check_plots.png: The frequency of each nucleotides along the Read 1 (Use to inspect the expected read parts with their expected signature) and Read 2 (Use to inspect the expected read parts with their expected signature).

Structure:

πŸ“ pipeline_dashboard/
  β”œβ”€β”€ πŸ“„ dashboard.html                         
  β”‚
  β”œβ”€β”€ πŸ“ evaluation_output/                      
  β”‚   β”œβ”€β”€ πŸ–ΌοΈ network_plot.png                   
  β”‚   β”œβ”€β”€ πŸ–ΌοΈ volcano_plot.png                  
  β”‚   β”œβ”€β”€ πŸ“„ igv.bedgraph                     
  β”‚   └── πŸ“„ igv.bedpe                         
  β”‚
  β”œβ”€β”€ πŸ“ figures/
  β”‚   β”œβ”€β”€ πŸ–ΌοΈ knee_plot_scRNA.png                
  β”‚   β”œβ”€β”€ πŸ–ΌοΈ scatterplot_scrna.png              
  β”‚   β”œβ”€β”€ πŸ–ΌοΈ violin_plot.png                    
  β”‚   β”œβ”€β”€ πŸ–ΌοΈ scRNA_barcodes_UMI_thresholds.png  
  β”‚   β”œβ”€β”€ πŸ–ΌοΈ guides_per_cell_histogram.png      
  β”‚   β”œβ”€β”€ πŸ–ΌοΈ cells_per_guide_histogram.png      
  β”‚   β”œβ”€β”€ πŸ–ΌοΈ guides_UMI_thresholds.png          
  β”‚   β”œβ”€β”€ πŸ–ΌοΈ cells_per_htp_barplot.png          
  β”‚   β”œβ”€β”€ πŸ–ΌοΈ umap_hto.png                       
  β”‚   └── πŸ–ΌοΈ umap_hto_singlets.png              
  β”‚
  β”œβ”€β”€ πŸ“ guide_seqSpec_plots/
  β”‚   └── πŸ–ΌοΈ seqSpec_check_plots.png            
  β”‚
  └── πŸ“ hashing_seqSpec_plots/
      └── πŸ–ΌοΈ seqSpec_check_plots.png             

Pipeline Testing Guide

To ensure proper pipeline functionality, we provide two extensively validated datasets for testing purposes.

Available Test Datasets

1. TF_Perturb_Seq_Pilot Dataset (Gary-Hon Lab)

The TF_Perturb_Seq_Pilot dataset was generated by the Gary-Hon Lab and is available through the IGVF Data Portal under Analysis Set ID: IGVFDS4389OUWU. To access the fastq files, you need to:

  1. First, register for an account on the IGVF Data Portal to obtain your access credentials.

  2. Once you have your credentials, you can use our provided Python script to download all necessary FASTQ files:

    cd example_data
    python download_fastq.py \
        --sample per-sample_file.tsv \
        --access-key YOUR_ACCESS_KEY \
        --secret-key YOUR_SECRET_KEY

    πŸ’‘ Note: You'll need to replace YOUR_ACCESS_KEY and YOUR_SECRET_KEY with the credentials from your IGVF portal account. These credentials can be found in your IGVF portal profile settings.

All other required input files for running the pipeline with this dataset are already included in the repository under the example_data directory.

2. Gasperini et al. Dataset

This dataset comes from a large-scale CRISPR screen study published in Cell (Gasperini et al., 2019: "A Genome-wide Framework for Mapping Gene Regulation via Cellular Genetic Screens") and provides an excellent resource for testing the pipeline. The full dataset, including raw sequencing data and processed files, is publicly available through GEO under accession number GSE120861.

Step-by-Step Testing Instructions

  1. Environment Setup

    # Clone and enter the repository
    git clone https://github.com/pinellolab/CRISPR_Pipeline.git
    cd CRISPR_Pipeline
  2. Choose Your Dataset and Follow the Corresponding Instructions:

    Option A: TF_Perturb_Seq_Pilot Dataset

    # Run with default configuration
    nextflow run main.nf -c input.config

    Option B: Gasperini Dataset

    1. Set up the configuration files:

      # Copy configuration files and example data
      cp -r example_gasperini/configs/* configs/
      cp -r example_gasperini/example_data/* example_data/
    2. Obtain sequencing data:

      • Download a subset of the dataset gasperini in your own server.
      • Place files in example_data/fastq_files directory
      NTHREADS=16
      wget https://github.com/10XGenomics/bamtofastq/releases/download/v1.4.1/bamtofastq_linux; chmod +x bamtofastq_linux
      wget https://sra-pub-src-1.s3.amazonaws.com/SRR7967488/pilot_highmoi_screen.1_CGTTACCG.grna.bam.1;mv pilot_highmoi_screen.1_CGTTACCG.grna.bam.1 pilot_highmoi_screen.1_CGTTACCG.grna.bam
      ./bamtofastq_linux --nthreads="$NTHREADS" pilot_highmoi_screen.1_CGTTACCG.grna.bam bam_pilot_guide_1
      
      wget https://sra-pub-src-1.s3.amazonaws.com/SRR7967482/pilot_highmoi_screen.1_SI_GA_G1.bam.1;mv pilot_highmoi_screen.1_SI_GA_G1.bam.1 pilot_highmoi_screen.1_SI_GA_G1.bam
      ./bamtofastq_linux --nthreads="$NTHREADS" pilot_highmoi_screen.1_SI_GA_G1.bam bam_pilot_scrna_1
      
    3. Prepare the whitelist:

      # Extract the compressed whitelist file
      gunzip example_data/yaml_files/3M-february-2018.txt.zip
    4. Launch the pipeline:

      # Run with Gasperini configuration
      nextflow run main.nf -c input.config

Expected Outputs

The pipeline generates two directories upon completion:

  • pipeline_outputs: Contains all analysis results
  • pipeline_dashboard: Houses interactive visualization reports

Troubleshooting

If you encounter any issues during testing:

  1. Review log files and intermediate results in the work/ directory
  2. Verify that all input files meet the required format specifications

For additional support or questions, please open an issue on our GitHub repository.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published