Skip to main content

Python implementation of the SCENIC pipeline for transcription factor inference from single-cell transcriptomics experiments.

Project description

buildstatus pypipackage docstatus

pySCENIC is a lightning-fast python implementation of the SCENIC pipeline (Single-Cell rEgulatory Network Inference and Clustering) which enables biologists to infer transcription factors, gene regulatory networks and cell types from single-cell RNA-seq data.

The pioneering work was done in R and results were published in Nature Methods [1]. A new and comprehensive description of this Python implementation of the SCENIC pipeline is available in Nature Protocols [5] (see here).

pySCENIC can be run on a single desktop machine but easily scales to multi-core clusters to analyze thousands of cells in no time. The latter is achieved via the dask framework for distributed computing [2].

Full documentation is available on Read the Docs

News and releases

0.11.1 | 2021-02-11

  • Fix bug in motif url construction (#275)

  • Fix for export2loom with sparse dataframe (#278)

  • Fix sklearn t-SNE import (#285)

  • Updates to Docker image (expose port 8787 for Dask dashboard)

0.11.0 | 2021-02-10

Major features:

  • Updated arboreto release (GRN inference step) includes:

    • Support for sparse matrices (using the --sparse flag in pyscenic grn, or passing a sparse matrix to grnboost2/genie3).

    • Fixes to avoid dask metadata mismatch error

  • Updated cisTarget:

    • Fix for metadata mismatch in ctx prune2df step

    • Support for databases Apache Parquet format

    • Faster loading from feather databases

    • Bugfix: loading genes from a database (previously missing the last gene name in the database)

  • Support for Anndata input and output

  • Package updates:

    • Upgrade to newer pandas version

    • Upgrade to newer numba version

    • Upgrade to newer versions of dask, distributed

  • Input checks and more descriptive error messages.

    • Check that regulons loaded are not empty.

  • Bugfixes:

    • In the regulons output from the cisTarget step, the gene weights were incorrectly assigned to their respective target genes (PR #254).

    • Motif url construction fixed when running ctx without pruning

    • Compression of intermediate files in the CLI steps

    • Handle loom files with non-standard gene/cell attribute names

    • Reformat the genesig gmt input/output

    • Fix AUCell output to loom with non-standard loom attributes

0.10.4 | 2020-11-24

  • Included new CLI option to add correlation information to the GRN adjacencies file. This can be called with pyscenic add_cor.

See also the extended Release Notes.

Overview

The pipeline has three steps:

  1. First transcription factors (TFs) and their target genes, together defining a regulon, are derived using gene inference methods which solely rely on correlations between expression of genes across cells. The arboreto package is used for this step.

  2. These regulons are refined by pruning targets that do not have an enrichment for a corresponding motif of the TF effectively separating direct from indirect targets based on the presence of cis-regulatory footprints.

  3. Finally, the original cells are differentiated and clustered on the activity of these discovered regulons.

The most impactful speed improvement is introduced by the arboreto package in step 1. This package provides an alternative to GENIE3 [3] called GRNBoost2. This package can be controlled from within pySCENIC.

All the functionality of the original R implementation is available and in addition:

  1. You can leverage multi-core and multi-node clusters using dask and its distributed scheduler.

  2. We implemented a version of the recovery of input genes that takes into account weights associated with these genes.

  3. Regulons, i.e. the regulatory network that connects a TF with its target genes, with targets that are repressed are now also derived and used for cell enrichment analysis.

Additional resources

For more information, please visit the main SCENIC website. There is a tutorial to create new cisTarget databases. The CLI to pySCENIC has also been streamlined into a pipeline that can be run with a single command, using the Nextflow workflow manager. There are two Nextflow implementations available:

  • SCENICprotocol: A Nextflow DSL1 implementation of pySCENIC alongside a basic “best practices” expression analysis. Includes details on pySCENIC installation, usage, and downstream analysis, along with detailed tutorials.

  • VSNPipelines: A Nextflow DSL2 implementation of pySCENIC with a comprehensive and customizable pipeline for expression analysis. Includes additional pySCENIC features (multi-runs, integrated motif- and track-based regulon pruning, loom file generation).

Acknowledgments

We are grateful to all providers of TF-annotated position weight matrices, in particular Martha Bulyk (UNIPROBE), Wyeth Wasserman and Albin Sandelin (JASPAR), BioBase (TRANSFAC), Scot Wolfe and Michael Brodsky (FlyFactorSurvey) and Timothy Hughes (cisBP).

References

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyscenic-0.11.1.tar.gz (7.0 MB view details)

Uploaded Source

Built Distribution

pyscenic-0.11.1-py3-none-any.whl (7.1 MB view details)

Uploaded Python 3

File details

Details for the file pyscenic-0.11.1.tar.gz.

File metadata

  • Download URL: pyscenic-0.11.1.tar.gz
  • Upload date:
  • Size: 7.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3.post20200330 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.6.8

File hashes

Hashes for pyscenic-0.11.1.tar.gz
Algorithm Hash digest
SHA256 f14efbd46e25d6a2ed691360ec09f9e8b379e137bdf8379aa4dc619741526ad7
MD5 db209e9a00c6c2d519774c389033bb12
BLAKE2b-256 aa2fcdd3095c63a8e893eea8e851e981e42006eaba06e406b428bb3c3e79d0a6

See more details on using hashes here.

File details

Details for the file pyscenic-0.11.1-py3-none-any.whl.

File metadata

  • Download URL: pyscenic-0.11.1-py3-none-any.whl
  • Upload date:
  • Size: 7.1 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3.post20200330 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.6.8

File hashes

Hashes for pyscenic-0.11.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1126618688a0ac339265bf5d95fa7297e274aad887305d6d928e4dde9dccbb7f
MD5 7dbfbb43638112736864f517bf3a3c72
BLAKE2b-256 001d29459ae978084c8145bbbe69c67f6fbe99cc09e1de31bcc59b04c572d9bd

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page