multiHiCcompare
is an extension of the original HiCcompare R package. multiHiCcompare
provides functions for the joint normalization and comparison of complex Hi-C experiments. multiHiCcompare
operates on processed Hi-C data in the form of sparse upper triangular matrices.
multiHiCcompare
accepts four-column text files storing chromatin interaction matrices in a sparse matrix format. There are many sources of public Hi-C data such as the Aiden Lab (.hic
files) and the Mirnylab FTP site (.cool
files). multiHiCcompare
performs differential chromatin interaction analysis between two biological conditions, one or multiple Hi-C matrices per condition.
multiHiCcompare
implements a cyclic loess joint normalization algorithm to remove bias between multiple Hi-C datasets and prepare them for comparison. multiHiCcompare
also provides a general linear model-based difference detection method, implemented in the edgeR
R package.
The main functions of multiHiCcompare
are:
cyclic_loess()
and fastlo()
for performing joint normalization.hic_exactTest()
and hic_glm()
for performing comparisons between experimental conditions.Some example Hi-C data are included in the package. Refer to the multiHiCcompare
vignette for full usage instructions, vignette("multiHiCcompare")
First, make sure you have all dependencies installed in R.
install.packages(c('dplyr', 'data.table', 'devtools', 'qqman', 'metap', 'pheatmap', 'pbapply'))
if (!requireNamespace("BiocManager", quietly = TRUE))
install.packages("BiocManager")
BiocManager::install(c("BiocParallel", "HiCcompare", "edgeR", "GenomicRanges", "GenomeInfoDbData"))
To install multiHiCcompare
from Bioconductor, use the following commands.
# It is recommended to use the GitHub release until the next Bioconductor update
# BiocManager::install("multiHiCcompare")
# library(multiHiCcompare)
Or to install the latest version of multiHiCcompare
directly from the GitHub.
library(devtools)
# Stable release
install_github('dozmorovlab/multiHiCcompare', build_vignettes = TRUE)
# Developmental version
# install_github('jstansfield0/multiHiCcompare', build_vignettes = TRUE)
library(multiHiCcompare)
To use multiHiCcompare
, you will first need to obtain some Hi-C data. Data is available from the sources listed in the overview, along with many others. You will need to extract the data and read it into R as either a 3 column sparse upper triangular matrix and then combine it with an additional column for the chromosome. Hi-C data ready to be used in multiHiCcompare
should look like the following:
chr region1 region2 IF
1 22 16000000 16000000 11
2 22 16100000 16100000 1
3 22 16200000 16200000 3
4 22 16300000 16300000 15
5 22 16400000 16400000 3
6 22 16400000 16500000 1
...
The four columns correspond to the chromosome, the start location of the first interacting region (in base pairs), the start location of the second interacting region, and the interaction frequency (IF) of the interaction.
Below is an example analysis of a Hi-C experiment.
# load data
library(multiHiCcompare)
data("r1", "r2", "r3", "r4")
# make hicexp object
hicexp <- make_hicexp(r1, r2, r3, r4, groups = c(1, 1, 2, 2))
# jointly normalize data
hicexp <- cyclic_loess(hicexp)
# compare groups
hicexp <- hic_exactTest(hicexp)
# view manhattan plot of results
manhattan_hicexp(hicexp)
Stansfield, John C, Kellen G Cresswell, and Mikhail G Dozmorov. MultiHiCcompare: Joint Normalization and Comparative Analysis of Complex Hi-C Experiments. Bioinformatics, January 22, 2019.
Stansfield, John C., Duc Tran, Tin Nguyen, and Mikhail G. Dozmorov. R Tutorial: Detection of Differentially Interacting Chromatin Regions From Multiple Hi-C Datasets. Current Protocols in Bioinformatics, May 2019
HiCcompareWorkshop - "Detection of Differentially Interacting Chromatin Regions From Multiple Hi-C Datasets" workshop presented on Bioconductor 2020 conference
issue for any of these or contact the author directly: @jstansfield0 (stansfieldjc@vcu.edu)
Authors: @jstansfield0 (stansfieldjc@vcu.edu) & @mdozmorov (mikhail.dozmorov@vcuhealth.org)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.