DeepBGC - Biosynthetic Gene Cluster detection and classification
Project description
DeepBGC: Biosynthetic Gene Cluster detection and classification
DeepBGC detects BGCs in bacterial and fungal genomes using deep learning. DeepBGC employs a Bidirectional Long Short-Term Memory Recurrent Neural Network and a word2vec-like vector embedding of Pfam protein domains. Product class and activity of detected BGCs is predicted using a Random Forest classifier.
Publications
A deep learning genome-mining strategy for biosynthetic gene cluster prediction
Geoffrey D Hannigan, David Prihoda et al., Nucleic Acids Research, gkz654, https://doi.org/10.1093/nar/gkz654
Install using conda (recommended)
- Install Bioconda by following Step 1 and 2 from: https://bioconda.github.io/
- Run
conda install deepbgc
to install DeepBGC and all of its dependencies
Install using pip (if conda is not available)
If you don't mind installing the HMMER and Prodigal dependencies manually, you can also install DeepBGC using pip:
- Install Python version 3.6 or 3.7 (Note: Python 3.8 is not supported due to Tensorflow < 2.0 dependency)
- Install Prodigal and put the
prodigal
binary it on your PATH: https://github.com/hyattpd/Prodigal/releases - Install HMMER and put the
hmmscan
andhmmpress
binaries on your PATH: http://hmmer.org/download.html - Run
pip install deepbgc
to install DeepBGC
Use DeepBGC
Download models and Pfam database
Before you can use DeepBGC, download trained models and Pfam database:
deepbgc download
You can display downloaded dependencies and models using:
deepbgc info
Detection and classification
Detect and classify BGCs in a genomic sequence. Proteins and Pfam domains are detected automatically if not already annotated (HMMER and Prodigal needed)
# Show command help docs
deepbgc pipeline --help
# Detect and classify BGCs in mySequence.fa using DeepBGC detector.
deepbgc pipeline mySequence.fa
# Detect and classify BGCs in mySequence.fa using custom DeepBGC detector trained on your own data.
deepbgc pipeline --detector path/to/myDetector.pkl mySequence.fa
This will produce a mySequence
directory with multiple files and a README.txt with file descriptions.
See Train DeepBGC on your own data section below for more information about training a custom detector or classifier.
Example output
See the DeepBGC Example Result Notebook. Data can be downloaded on the releases page
Train DeepBGC on your own data
You can train your own BGC detection and classification models, see deepbgc train --help
for documentation and examples.
DeepBGC positives, negatives and other training and validation data can be found in release 0.1.0 and release 0.1.5.
If you have any questions about using or training DeepBGC, feel free to submit an issue.
Preparing training data
The training examples need to be prepared in Pfam TSV format, which can be prepared from your sequence
using deepbgc prepare
. You will need to add an in_cluster
column that will contain 0 for pfams outside a BGC
and 1 for pfams inside a BGC. We recommend preparing a separate negative TSV and positive TSV file,
where the column will be equal to all 0 or 1 respectively. A sequence_id
column should be added,
which will identify a continuous sequence of Pfams from a single sample (BGC or negative sequence).
The samples are shuffled during training to present the model with a random order of positive and negative samples.
Pfams with the same sequence_id
value will be kept together.
! New in version 0.1.17 ! You can now prepare protein FASTA sequences into a Pfam TSV file using deepbgc prepare --protein
.
JSON model training template files
DeepBGC is using JSON template files to define model architecture and training parameters. All templates can be downloaded in release 0.1.0.
JSON template for DeepBGC LSTM detector with pfam2vec is structured as follows:
{
"type": "KerasRNN", - Model architecture (KerasRNN/DiscreteHMM/GeneBorderHMM)
"build_params": { - Parameters for model architecture
"batch_size": 16, - Number of splits of training data that is trained in parallel
"hidden_size": 128, - Size of vector storing the LSTM inner state
"stateful": true - Remember previous sequence when training next batch
},
"fit_params": {
"timesteps": 256, - Number of pfam2vec vectors trained in one batch
"validation_size": 0, - Fraction of training data to use for validation (if validation data is not provided explicitly). Use 0.2 for 20% data used for testing.
"verbose": 1, - Verbosity during training
"num_epochs": 1000, - Number of passes over your training set during training. You probably want to use a lower number if not using early stopping on validation data.
"early_stopping" : { - Stop model training when at certain validation performance
"monitor": "val_auc_roc", - Use validation AUC ROC to observe performance
"min_delta": 0.0001, - Stop training when the improvement in the last epochs did not improve more than 0.0001
"patience": 20, - How many of the last epochs to check for improvement
"mode": "max" - Stop training when given metric stops increasing (use "min" for decreasing metrics like loss)
},
"shuffle": true, - Shuffle samples in each epoch. Will use "sequence_id" field to group pfam vectors belonging to the same sample and shuffle them together
"optimizer": "adam", - Optimizer algorithm
"learning_rate": 0.0001, - Learning rate
"weighted": true - Increase weight of less-represented class. Will give more weight to BGC training samples if the non-BGC set is larger.
},
"input_params": {
"features": [ - Array of features to use in model, see deepbgc/features.py
{
"type": "ProteinBorderTransformer" - Add two binary flags for pfam domains found at beginning or at end of protein
},
{
"type": "Pfam2VecTransformer", - Convert pfam_id field to pfam2vec vector using provided pfam2vec table
"vector_path": "#{PFAM2VEC}" - PFAM2VEC variable is filled in using command line argument --config
}
]
}
}
JSON template for Random Forest classifier is structured as follows:
{
"type": "RandomForestClassifier", - Type of classifier (RandomForestClassifier)
"build_params": {
"n_estimators": 100, - Number of trees in random forest
"random_state": 0 - Random seed used to get same result each time
},
"input_params": {
"sequence_as_vector": true, - Convert each sample into a single vector
"features": [
{
"type": "OneHotEncodingTransformer" - Convert each sequence of Pfams into a single binary vector (Pfam set)
}
]
}
}
Using your trained model
Since version 0.1.10
you can provide a direct path to the detector or classifier model like so:
deepbgc pipeline \
mySequence.fa \
--detector path/to/myDetector.pkl \
--classifier path/to/myClassifier.pkl
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file deepbgc-0.1.22.tar.gz
.
File metadata
- Download URL: deepbgc-0.1.22.tar.gz
- Upload date:
- Size: 49.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | db034abe0efc392c08a2fbebd452885adec11a4b06a5a87f3f4b8a47775239ef |
|
MD5 | d43b12f006f03efdafc454ae0a6f509f |
|
BLAKE2b-256 | 23deaa9eddb8f0494009d3f7b27346f07314eee04549cf42aca0caaaf624be00 |
File details
Details for the file deepbgc-0.1.22-py3-none-any.whl
.
File metadata
- Download URL: deepbgc-0.1.22-py3-none-any.whl
- Upload date:
- Size: 63.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6e7af69a3b2a505d8f024079e46b9567c3ed542d45a7b428fe8eb3c9866d93d1 |
|
MD5 | 8b3ad27517a5960da008ae320ae8aa97 |
|
BLAKE2b-256 | c9f6813b341729421e0f78968a6135040638ceb5c5b92c7ed61efcf36c0fcd53 |