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/JUND/meta_Unique35_DGF_2
source activate kipoi-FactorNet__JUND__meta_Unique35_DGF_2kipoi test FactorNet/JUND/meta_Unique35_DGF_2 --source=kipoikipoi get-example FactorNet/JUND/meta_Unique35_DGF_2 -o example
kipoi predict FactorNet/JUND/meta_Unique35_DGF_2 \
  --dataloader_args='{"intervals_file": "example/intervals_file", "fasta_file": "example/fasta_file", "dnase_file": "example/dnase_file", "cell_line": "PC-3", "mappability_file": "example/mappability_file"}' \
  -o '/tmp/FactorNet|JUND|meta_Unique35_DGF_2.example_pred.tsv'
# check the results
head '/tmp/FactorNet|JUND|meta_Unique35_DGF_2.example_pred.tsv'
kipoi env create FactorNet/JUND/meta_Unique35_DGF_2
source activate kipoi-FactorNet__JUND__meta_Unique35_DGF_2import kipoi
model = kipoi.get_model('FactorNet/JUND/meta_Unique35_DGF_2')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/JUND/meta_Unique35_DGF_2')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-slimdocker pull kipoi/kipoi-docker:sharedpy3keras2tf1docker run -it kipoi/kipoi-docker:sharedpy3keras2tf1-slimdocker run kipoi/kipoi-docker:sharedpy3keras2tf1-slim kipoi test FactorNet/JUND/meta_Unique35_DGF_2 --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/JUND/meta_Unique35_DGF_2 -o /app/example 
docker run -v $PWD/kipoi-example:/app/ kipoi/kipoi-docker:sharedpy3keras2tf1-slim \
kipoi predict FactorNet/JUND/meta_Unique35_DGF_2 \
--dataloader_args='{'intervals_file': '/app/example/intervals_file', 'fasta_file': '/app/example/fasta_file', 'dnase_file': '/app/example/dnase_file', 'cell_line': 'PC-3', 'mappability_file': '/app/example/mappability_file'}' \
-o '/app/FactorNet_JUND_meta_Unique35_DGF_2.example_pred.tsv' 
# check the results
head $PWD/kipoi-example/FactorNet_JUND_meta_Unique35_DGF_2.example_pred.tsv
    https://apptainer.org/docs/user/main/quick_start.html#quick-installation-stepskipoi get-example FactorNet/JUND/meta_Unique35_DGF_2 -o example
kipoi predict FactorNet/JUND/meta_Unique35_DGF_2 \
--dataloader_args='{"intervals_file": "example/intervals_file", "fasta_file": "example/fasta_file", "dnase_file": "example/dnase_file", "cell_line": "PC-3", "mappability_file": "example/mappability_file"}' \
-o 'FactorNet_JUND_meta_Unique35_DGF_2.example_pred.tsv' \
--singularity 
# check the results
head FactorNet_JUND_meta_Unique35_DGF_2.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
Name: meta_features
Doc: First 8 RNAseq principle-components for the tissue.
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
cell_line (optional): Cell type as a string.
RNAseq_PC_file (optional): file path to a RNAseq PC file computed by https://github.com/davidaknowles/tf_net/blob/master/gene_expression_pca.R. See https://github.com/uci-cbcl/FactorNet/blob/master/data/README.md.
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