FactorNet: a deep learning framework for predicting cell type specific transcription factor binding from nucleotide-resolution sequential data Github link - https://github.com/uci-cbcl/FactorNet Abststract: Due to the large numbers of transcription factors (TFs) and cell types, querying binding profiles of all TF/cell type pairs is not experimentally feasible, owing to constraints in time and resources. To address this issue, we developed a convolutional-recurrent neural network model, called FactorNet, to computationally impute the missing binding data. FactorNet trains on binding data from reference cell types to make accurate predictions on testing cell types by leveraging a variety of features, including genomic sequences, genome annotations, gene expression, and single-nucleotide resolution sequential signals, such as DNase I cleavage. To the best of our knowledge, this is the first deep learning method to study the rules governing TF binding at such a fine resolution. With FactorNet, a researcher can perform a single sequencing assay, such as DNase-seq, on a cell type and computationally impute dozens of TF binding profiles. This is an integral step for reconstructing the complex networks underlying gene regulation. While neural networks can be computationally expensive to train, we introduce several novel strategies to significantly reduce the overhead. By visualizing the neural network models, we can interpret how the model predicts binding which in turn reveals additional insights into regulatory grammar. We also investigate the variables that affect cross-cell type predictive performance to explain why the model performs better on some TF/cell types than others, and offer insights to improve upon this field. Our method ranked among the top four teams in the ENCODE-DREAM in vivo Transcription Factor Binding Site Prediction Challenge.
kipoi env create FactorNet/NANOG/onePeak_Unique35_DGF
source activate kipoi-FactorNet__NANOG__onePeak_Unique35_DGF
kipoi test FactorNet/NANOG/onePeak_Unique35_DGF --source=kipoi
kipoi get-example FactorNet/NANOG/onePeak_Unique35_DGF -o example
kipoi predict FactorNet/NANOG/onePeak_Unique35_DGF \
--dataloader_args='{"intervals_file": "example/intervals_file", "fasta_file": "example/fasta_file", "dnase_file": "example/dnase_file", "mappability_file": "example/mappability_file"}' \
-o '/tmp/FactorNet|NANOG|onePeak_Unique35_DGF.example_pred.tsv'
# check the results
head '/tmp/FactorNet|NANOG|onePeak_Unique35_DGF.example_pred.tsv'
kipoi env create FactorNet/NANOG/onePeak_Unique35_DGF
source activate kipoi-FactorNet__NANOG__onePeak_Unique35_DGF
import kipoi
model = kipoi.get_model('FactorNet/NANOG/onePeak_Unique35_DGF')
pred = model.pipeline.predict_example(batch_size=4)
# Download example dataloader kwargs
dl_kwargs = model.default_dataloader.download_example('example')
# Get the dataloader and instantiate it
dl = model.default_dataloader(**dl_kwargs)
# get a batch iterator
batch_iterator = dl.batch_iter(batch_size=4)
for batch in batch_iterator:
# predict for a batch
batch_pred = model.predict_on_batch(batch['inputs'])
pred = model.pipeline.predict(dl_kwargs, batch_size=4)
library(reticulate)
kipoi <- import('kipoi')
model <- kipoi$get_model('FactorNet/NANOG/onePeak_Unique35_DGF')
predictions <- model$pipeline$predict_example()
# Download example dataloader kwargs
dl_kwargs <- model$default_dataloader$download_example('example')
# Get the dataloader
dl <- model$default_dataloader(dl_kwargs)
# get a batch iterator
it <- dl$batch_iter(batch_size=4)
# predict for a batch
batch <- iter_next(it)
model$predict_on_batch(batch$inputs)
pred <- model$pipeline$predict(dl_kwargs, batch_size=4)
docker pull kipoi/kipoi-docker:sharedpy3keras2tf1-slim
docker pull kipoi/kipoi-docker:sharedpy3keras2tf1
docker run -it kipoi/kipoi-docker:sharedpy3keras2tf1-slim
docker run kipoi/kipoi-docker:sharedpy3keras2tf1-slim kipoi test FactorNet/NANOG/onePeak_Unique35_DGF --source=kipoi
# Create an example directory containing the data
mkdir -p $PWD/kipoi-example
# You can replace $PWD/kipoi-example with a different absolute path containing the data
docker run -v $PWD/kipoi-example:/app/ kipoi/kipoi-docker:sharedpy3keras2tf1-slim \
kipoi get-example FactorNet/NANOG/onePeak_Unique35_DGF -o /app/example
docker run -v $PWD/kipoi-example:/app/ kipoi/kipoi-docker:sharedpy3keras2tf1-slim \
kipoi predict FactorNet/NANOG/onePeak_Unique35_DGF \
--dataloader_args='{'intervals_file': '/app/example/intervals_file', 'fasta_file': '/app/example/fasta_file', 'dnase_file': '/app/example/dnase_file', 'mappability_file': '/app/example/mappability_file'}' \
-o '/app/FactorNet_NANOG_onePeak_Unique35_DGF.example_pred.tsv'
# check the results
head $PWD/kipoi-example/FactorNet_NANOG_onePeak_Unique35_DGF.example_pred.tsv
https://apptainer.org/docs/user/main/quick_start.html#quick-installation-steps
kipoi get-example FactorNet/NANOG/onePeak_Unique35_DGF -o example
kipoi predict FactorNet/NANOG/onePeak_Unique35_DGF \
--dataloader_args='{"intervals_file": "example/intervals_file", "fasta_file": "example/fasta_file", "dnase_file": "example/dnase_file", "mappability_file": "example/mappability_file"}' \
-o 'FactorNet_NANOG_onePeak_Unique35_DGF.example_pred.tsv' \
--singularity
# check the results
head FactorNet_NANOG_onePeak_Unique35_DGF.example_pred.tsv
Inputs
List of numpy arrays
Name: seq
Doc: DNA sequence and other big-wig channels (mappability and DNAseq)
Name: seq_rc
Doc: Reverse-complemented DNA sequence and reversed other bigwig channels
Defined as: .
Doc: Dataloader for the FactorNet model.
Type: Dataset
License: MIT
Arguments
intervals_file : bed3 file with `chrom start end id score strand`
fasta_file : Reference genome sequence
dnase_file : DNase bigwig file
mappability_file (optional): USCS mappability track - http://hgdownload.cse.ucsc.edu/goldenpath/hg19/encodeDCC/wgEncodeMapability/wgEncodeDukeMapabilityUniqueness35bp.bigWig. by deafult, provide this file with the dataloader, download in background
use_linecache (optional): if True, use linecache https://docs.python.org/3/library/linecache.html to access bed file rows
- python=3.7
- tensorflow>=1.4.1,<2.0.0
- keras>=2.0.4,<2.2.0
- protobuf==3.20
- bioconda::bedtools
- bioconda::pybedtools
- bioconda::genomelake==0.1.4
- numpy
- cython