Introduction¶
What is seqgra?¶
Sequence models based on deep neural networks have achieved state-of-the-art performance on regulatory genomics prediction tasks, such as chromatin accessibility and transcription factor binding. But despite their high accuracy, their contributions to a mechanistic understanding of the biology of regulatory elements is often hindered by the complexity of the predictive model and thus poor interpretability of its decision boundaries. To address this, we introduce seqgra, a deep learning pipeline that incorporates the rule-based simulation of biological sequence data and the training and evaluation of models, whose decision boundaries mirror the rules from the simulation process. The method can be used to (1) generate data under the assumption of a hypothesized model of genome regulation, (2) identify neural network architectures capable of recovering the rules of said model, and (3) analyze a model’s predictive performance as a function of training set size, noise level, and the complexity of the rules behind the simulated data.
Installation¶
seqgra is a Python package that is part of PyPI, the package repositories behind pip, respectively.
To install seqgra with pip, run:
pip install seqgra
To install seqgra directly from this repository, run:
git clone https://github.com/gifford-lab/seqgra
cd seqgra
pip install .
System requirements¶
Python 3.7 (or higher)
R 3.5 (or higher)
R package ggplot2 3.3.0 (or higher)
R package gridExtra 2.3 (or higher)
R package scales 1.1.0 (or higher)
Note
The tensorflow
package is only required if TensorFlow models are used
and will not be automatically installed by pip install seqgra
. Same is
true for packages torch
and pytorch-ignite
, which are only
required if PyTorch models are used.
Note
R is a soft dependency, in the sense that it is used to create a number of plots (grammar-model-agreement plots, grammar heatmaps, and motif similarity matrix plots) and if not available, these plots will be skipped.
Note
seqgra depends upon the Python package lxml, which in turn depends on system libraries that are not always present. On a Debian/Ubuntu machine you can satisfy those requirements using:
sudo apt-get install libxml2-dev libxslt-dev
Usage¶
Check out the following help pages:
Usage examples: seqgra example analyses with data definitions and model definitions
Command line utilities: argument descriptions for
seqgra
,seqgras
,seqgrae
, andseqgraa
commandsData definition: detailed description of the data definition language that is used to formalize grammars
Model definition: detailed description of the model definition language that is used to describe neural network architectures and hyperparameters for the optimizer, the loss, and the training process
Simulators, Learners, Evaluators, Comparators: brief descriptions of the most important classes
API reference: detailed description of the seqgra API
Source code: seqgra source code repository on GitHub
Citation¶
If you use seqgra in your work, please cite:
Funding¶
We gratefully acknowledge funding from NIH grants 1R01HG008754 and 1R01NS109217.