Using target to predict combined binding

Overview

In this document, we extend the BETA algorithm to predict cooperative and/or competitive binding events of two factors at the same region of interest. This method uses the same theory described in vignette('target') with one modification. Instead of using an individual statistics from a factor perturbation experiment, we use two separate statistics from two comparable factor perturbation experiments to define a regulatory interaction (RI). This regulatory interaction terms are used to calculate rank products of the regions of interest. In addition, we illustrate the use of this method with a simulated dataset and an example of real-world data.

Theory

This method is an extension of the BETA basic algorithm. Briefly, the rank product of a regions of interest (RPg) is the product of two terms; the rank of a statistics from factor perturbation experiment (Rge) and the rank of the regulatory potential (Rgb). The regulatory potential of region of interest (Sg) is the sum of the peaks within a predefined distance:

$$ S_g = \sum_{i=1}^k e^{-(0.5+4\Delta_i)} \quad\text{and}\quad RP_g = \frac{R_{gb}\times R_{ge}}{n^2} $$ Where p is a peak in {1, ..., k} with a distance, Δ, from the center of the region of interest.

Two determine the relation of two factors x and y on a common peak near a region of interest, we define a new term; the regulatory interaction (RI) as the product of two signed statistics from comparable perturbation experiments. The rank of this term is used to calculate a rank product (PRg) for each region of interest as described above

$$ RI_{g} = x_{ge}\times y_{ge} \quad\text{and}\quad RP_g = \frac{R_{gb}\times RI_{ge}}{n^2} $$

This term would represent the interaction magnitude assuming a linear relation between the two factor. The sign of the term would define the direction of the relation were positive means cooperative and negative means competitive.

Example

The target package contain two simulated datasets. sim_peaks is random peaks with random distances from the transcripts of chromosome 1 of the mm10 mouse genome. sim_transcripts is the same transcripts with random singed statistics assigned to each. In the following two examples, we introduce changes in these statistics to simulate conditions where two factors are working cooperatively or competitively on the same transcripts.

# load libraries
library(target)
# load data
data("sim_peaks")
data("sim_transcripts")

To help visualize these cases, a plotting function plot_profiles was constructed to introduce the changes change in the statistics of the transcripts near the n number of peaks. The source code for the function is available in inst/extdata/plot-profiles.R which we source to use here. The output of the function is a series of plots to visualize the statistics of the two factors before and after introducing the changes, the peaks distances and scores and the predicted functions of the factors individually and combined.

# source the plotting function
source(system.file('extdata', 'plot-profiles.R', package = 'target'))

Cooperative factors example

The first two inputs to the plotting function is the simulated peaks and transcripts. We chose to introduce positive changes to the statistics of the transcripts with the top 5000 nearby peaks of the two factors.

# simulate and plot cooperative factors
plot_profiles(sim_peaks,
              sim_transcripts,
              n = 5000,
              change = c(3, 3))

The changes introduced above are illustrated in the right upper quadrant of the scatter plot. The predicted functions of the two factors are similar, as shown by distribution function of the regulatory potential of their targets. Finally, when the targets are predicted based on the two statistics combined, the sign of the statistics product determines the direction of the factor interactions. Here, more higher ranking transcripts had positive/red/ cooperative change associated with the two factors.

Competitive factors example

Similar to the example above, we chose to introduce change to the statistics of the transcripts with nearby peaks for the two factors. To simulate the competitive conditions of the two factors, the changes have opposite signs.

# simulate and plot competitve factors
plot_profiles(sim_peaks,
              sim_transcripts,
              n = 5000,
              change = c(3, -3))

By contrast, the changes associated with each factor are opposite in sign, as shown in the lower right quadrant. The predicted functions of the individual factors are also the opposite. The predicted combined effect of the two factors is negative/green/competitive.

References

Wang S, Sun H, Ma J, et al. Target analysis by integration of transcriptome and ChIP-seq data with BETA. Nat Protoc. 2013;8(12):2502–2515. doi:10.1038/nprot.2013.150

sessionInfo()
#> R version 4.4.2 (2024-10-31)
#> Platform: x86_64-pc-linux-gnu
#> Running under: Ubuntu 24.04.1 LTS
#> 
#> Matrix products: default
#> BLAS:   /usr/lib/x86_64-linux-gnu/openblas-pthread/libblas.so.3 
#> LAPACK: /usr/lib/x86_64-linux-gnu/openblas-pthread/libopenblasp-r0.3.26.so;  LAPACK version 3.12.0
#> 
#> locale:
#>  [1] LC_CTYPE=en_US.UTF-8       LC_NUMERIC=C              
#>  [3] LC_TIME=en_US.UTF-8        LC_COLLATE=C              
#>  [5] LC_MONETARY=en_US.UTF-8    LC_MESSAGES=en_US.UTF-8   
#>  [7] LC_PAPER=en_US.UTF-8       LC_NAME=C                 
#>  [9] LC_ADDRESS=C               LC_TELEPHONE=C            
#> [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C       
#> 
#> time zone: Etc/UTC
#> tzcode source: system (glibc)
#> 
#> attached base packages:
#> [1] stats     graphics  grDevices utils     datasets  methods   base     
#> 
#> other attached packages:
#> [1] target_1.21.0  rmarkdown_2.29
#> 
#> loaded via a namespace (and not attached):
#>  [1] jsonlite_1.8.9          compiler_4.4.2          promises_1.3.2         
#>  [4] Rcpp_1.0.13-1           GenomicRanges_1.59.1    later_1.4.1            
#>  [7] jquerylib_0.1.4         IRanges_2.41.2          yaml_2.3.10            
#> [10] fastmap_1.2.0           mime_0.12               R6_2.5.1               
#> [13] XVector_0.47.0          generics_0.1.3          GenomeInfoDb_1.43.2    
#> [16] knitr_1.49              BiocGenerics_0.53.3     maketools_1.3.1        
#> [19] GenomeInfoDbData_1.2.13 shiny_1.10.0            bslib_0.8.0            
#> [22] rlang_1.1.4             cachem_1.1.0            httpuv_1.6.15          
#> [25] xfun_0.49               sass_0.4.9              sys_3.4.3              
#> [28] cli_3.6.3               magrittr_2.0.3          zlibbioc_1.52.0        
#> [31] digest_0.6.37           xtable_1.8-4            lifecycle_1.0.4        
#> [34] S4Vectors_0.45.2        evaluate_1.0.1          buildtools_1.0.0       
#> [37] stats4_4.4.2            httr_1.4.7              matrixStats_1.4.1      
#> [40] tools_4.4.2             htmltools_0.5.8.1       UCSC.utils_1.3.0