/AdaLiftOver

Adaptive LiftOver

Primary LanguageRGNU General Public License v3.0GPL-3.0

AdaLiftOver

AdaLiftOver is a handy R package for adaptively identifying orthologous regions across different species. For each query region, AdaLiftOver outputs a scored and filtered list of candidate target regions that are most similar to the query region in terms of regulatory information.

Installation

AdaLiftOver can be downloaded and installed in R by:

## install.packages("devtools")
devtools::install_github("ThomasDCY/AdaLiftOver", build_vignettes = TRUE)

If the installation fails, make sure you can install the following R packages:

## data.table
install.packages("data.table")

## Matrix
install.packages("Matrix")

## PRROC
install.packages("PRROC")

if (!require("BiocManager", quietly = TRUE))
    install.packages("BiocManager")

## motifmatchr
## See also https://github.com/GreenleafLab/motifmatchr
devtools::install_github("GreenleafLab/motifmatchr")

## rtracklayer
BiocManager::install("rtracklayer")

## GenomicRanges
BiocManager::install("GenomicRanges")

## The BSgenome packages required to run the examples
BiocManager::install("BSgenome.Mmusculus.UCSC.mm10")
BiocManager::install("BSgenome.Hsapiens.UCSC.hg38")

## To build the vignette, we need the following packages
install.packages("rmarkdown")
BiocManager::install("BiocStyle")

A quick start

Download the UCSC chain file from mm10.hg38.rbest.chain.gz and unzip it.

library(AdaLiftOver)

data("data_example")

## load the ENCODE repertoire
data("epigenome_mm10")
data("epigenome_hg38")

## load the UCSC chain file
chain <- rtracklayer::import.chain("mm10.hg38.rbest.chain")

## map the query regions
gr_list <- adaptive_liftover(gr, chain)

## compute epigenome signal similarity
gr_list <- compute_similarity_epigenome(gr, gr_list, epigenome_mm10, epigenome_hg38)

## compute sequence grammar similarity
data("jaspar_pfm_list")
gr_list <- compute_similarity_grammar(gr, gr_list, "mm10", "hg38", jaspar_pfm_list)

## filter target candidate regions
gr_list_filter <- gr_candidate_filter(
    gr_list,
    best_k = 1L,
    threshold = 0.5
)

We might need to learn the parameters for a pair of matched epigenome datasets other than the ENCODE repertoire we provide, especially for model organisms other than mice. AdaLiftOver provides a handy training module to estimate the logistic regression parameters and suggest an optimal score threshold without filtering out too many candidate target regions.

data("training_module_example")
training_module(gr_candidate, gr_true)

For a user defined epigenome repertoire

For other model organisms, e.g. rats, we will need to collect orthologous epigenome repertoire from scratch. We hereby illustrate an example.

We can download the UCSC chain file from rat to human rn6.hg38.rbest.chain.gz and then import the chain file with the following code.

chain <- rtracklayer::import.chain('rn6.hg38.rbest.chain')

Make sure to install the BSgenome object for rat genome as well.

if (!require("BiocManager", quietly = TRUE))
    install.packages("BiocManager")
BiocManager::install("BSgenome.Rnorvegicus.UCSC.rn6")

These datasets are organized as GRangesList objects epigenome_rn6_test, epigenome_hg38_test

data('rat_example')

Please refer to the vignette for the code and more details with leave one out cross validation.

After computing the candidate target regions for each rat epigenome peaks, we first label the candidate target regions in the human genome as positives if they overlap with the corresponding human epigenome peaks and as negatives otherwise. Then, we estimate the parameters with the training_module() function.

tissues <- names(epigenome_rn6_test)
training_result <- rbindlist(
  lapply(tissues, function(tissue) {
    dt <- training_module(
        gr_candidate_list[[tissue]], 
        epigenome_hg38_test[[tissue]], 
        max_filter_proportion = 0.5, 
        interaction = FALSE
    )
    return(dt)
}))
training_result

We can take the averaged logistic regression parameters as default for rat studies.

See the vignette for more information!

browseVignettes("AdaLiftOver")

Reference

C. Dong, and S. Keles, "AdaLiftOver: High-resolution identification of orthologous regulatory elements with adaptive liftOver".