Description Usage Arguments Details Value Author(s) References See Also Examples
Detecting differential binding of transcription factors with ChIP-seq
1 2 3 4 5 6 | DBChIP(binding.site.list, chip.data.list, conds, input.data.list = NULL,
data.type = c("MCS", "AlignedRead", "BED"), frag.len = 200, chr.vec = NULL,
chr.exclusion = NULL, chr.len.vec = NULL, subtract.input = FALSE, norm.factor.vec = NULL,
in.distance = 100, out.distance = 250, window.size = 250,
dispersion=NULL, common.disp=TRUE, prior.n=10,
two.sample.method="composite.null", allowable.FC=1.5, collapsed.quant=0.5)
|
binding.site.list |
a list of data.frames. Each data.frame corresponds to one condition in comparison and has three fields, chr, pos, and weight, to indicate the binding location and strength. |
chip.data.list |
a list of ChIP data where each list item corresponds to one ChIP library. The name of the items should be unique. Biological replicates should be in separate items. Each item can be one of three accepted data types: MCS, AlignedRead and BED. |
conds |
a vector of conditions of ChIP libraries. Should be the same order as chip.data.list, or the names should be specified as a permutation of the names of chip.data.list. |
input.data.list |
a list of control data. Should have same data type as in chip.data.list. The names of the items should be unique, and each name should be matched to either a ChIP replicate name when the two are paired or a condition name in general. |
data.type |
"MCS", "AlignedRead" or "BED". See Details. |
frag.len |
average fragment length. Default 200 bp. |
chr.vec |
a vector of chromosomes in data. User can specify chr.vec, or it can be computed from the ChIP and control samples. |
chr.exclusion |
user can either specify chr.vec, or specify the chromosomes to exclude through this parameter. |
chr.len.vec |
a vector of chromosome lengths corresponding to chr.vec. Can be specified if known, or will be computed as the largest 5' end position in the data. |
subtract.input |
logical. Whether input will be subtracted from ChIP when counting the binding reads. Default is FALSE. |
norm.factor.vec |
a vector of normalization factors between the ChIP and control libraries when controls are available. Can be specified, or will be computed by DBChIP. |
in.distance |
within cluster distance. If the distance between centroids of two clusters are smaller than this value, the clusters will be merged into one. Default value 100 bp. |
out.distance |
out of cluster distance. If the distance between centroids of two clusters are larger than this value, they are considered different binding sites. Also double-function as the window size to count reads around each site. Default value 250 bp. |
window.size |
the window size to count reads around a binding site. |
dispersion |
The dispersion parameter in Negative Binomial distribution. Could be a numerical value or a vector with a length of the number of consensus sites. |
common.disp |
logical, TRUE (use common dispersion parameter for all sites) or FALSE (use site-specific dispersion). |
prior.n |
a parameter regulate the degree of pooling when using site-specific dispersion ( |
two.sample.method |
the method to use when comparing two condition with no replicates. The default is to test a composite null that allow certain fold change |
allowable.FC |
allowable fold change when testing a composite null. Default value 1.5. |
collapsed.quant |
the quantile to use when testing more than two conditions without replicates. Default value is 0.5, the median. |
The ChIP and control data should be properly filtered before the analysis to avoid artifacts.
For example, reads mapping to mitochondrial DNA, or Y chromosome for female samples will need to be filtered.
Filtering of chromosomes can be achieved through specification of chr.vec
and/or chr.exclusion
. Only reads from chromosomes in chr.vec
but not in chr.exclusion
are utilized in the analysis.
User can include or exclude sex chromosomes in the computation, depending on whether protein-DNA bindings on sex chromosomes are of research interest.
Biological replicates of a ChIP sample should be kept separate so that dispersion can be properly estimated. On the other hand, replicates of a control/input sample should be merged because the purpose of the control samples is to estimate the background for testing and plotting. One exception would be when a control replicate is paired with a ChIP replicate, for example, they are coming from the same batch, a portion of which is used for IP and the other portion is used for control. In such case, the control replicate can be kept separate with the same name of the matching ChIP replicate.
data.type
MCS
Minimum ChIP-Seq format. data.frame with fields: chr (factor), pos (integer) and strand (factor, "+" and "-"). pos is 5' location. This is different from eland default which use 3' location for reverse strand.
AlignedRead
from Bioconductor ShortRead package (with support of commonly used formats, including Eland, MAQ, Bowtie, SOAP and BAM).
BED
with at least first 6 fields (chrom, start, end, name, score and strand), http://genome.ucsc.edu/FAQ/FAQformat.html#format1.
Users are recommended to study the histogram of the $p$-values for model checking. More specifically, the $p$-values between 0.5 and 1 should be roughly uniform. When many replicates are available, users can also randomly split biological replicates of the same condition and perform comparisons through DBChIP using the estimated dispersion parameter to check whether the $p$-values look uniform.
A list with following components:
chip.list |
the list of ChIP data in internal MCS format. |
conds |
vector of conditions of ChIP libraries. |
frag.len |
average fragment length. |
chr.vec |
a vector of chromosomes in data. |
chr.len.vec |
a vector of chromosome lengths corresponding to chr.vec. |
consensus.site |
consensus sites. It is a data.frame, for details, see |
site.count |
a data.frame of read counts at each consensus site. |
test.stat |
a data.frame of test statistics for testing non-differential binding at each site, include p-values and fold changes. |
input.list |
the list of control data. The components from this and below are only available when control data are available. |
matching.input.names |
the matching input names for ChIP libraries. |
norm.factor.vec |
vector of normalization factors between the ChIP and control libraries when controls are available. Can be specified, or will be computed by DBChIP. |
Kun Liang, kliang@stat.wisc.edu
Liang, K and Keles, S (2012). Detecting differential binding of transcription factors with ChIP-seq. Bioinformatics, 28, 121-122.
DBChIP-package
, PHA4
, read.binding.site.list
, site.merge
.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 | data("PHA4")
dat <- DBChIP(binding.site.list, chip.data.list=chip.data.list, input.data.list=input.data.list, conds=conds, data.type="MCS")
rept <- report.peak(dat)
rept
#pdf("Diff.Binding.pdf")
plotPeak(rept, dat)
#dev.off()
## experienced users can proceed in a step by step fashion such that if program
## needs to be run for a different setting, intermediate results can be saved and reused.
data("PHA4")
conds <- factor(c("emb","emb","L1", "L1"), levels=c("emb", "L1"))
bs.list <- read.binding.site.list(binding.site.list)
## compute consensus site
consensus.site <- site.merge(bs.list, in.distance=100, out.distance=250)
dat <- load.data(chip.data.list=chip.data.list, conds=conds, consensus.site=consensus.site, input.data.list=input.data.list, data.type="MCS")
## count ChIP reads around each binding site
dat <- get.site.count(dat, window.size=250)
## test for differential binding
dat <- test.diff.binding(dat)
# report test result and plot the coverage profiles
rept <- report.peak(dat)
rept
plotPeak(rept, dat)
|
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.