... | ... |
@@ -23,7 +23,7 @@ cpgDensity<-function(bs,organism,windowLength=1000){ |
23 | 23 |
cpgd<-Repitools::cpgDensityCalc(gr, organism, window = windowLength) |
24 | 24 |
|
25 | 25 |
maxcpgd<-max(cpgd) |
26 |
- cpgdCov<-sapply(1:ncol(cov), function(i) { |
|
26 |
+ cpgdCov<-sapply(seq_len(ncol(cov)), function(i) { |
|
27 | 27 |
cv = as.vector(cov[,i]) |
28 | 28 |
cpgdCell<-cpgd[cv>0 ] |
29 | 29 |
tab <- table(cpgdCell) |
... | ... |
@@ -32,13 +32,6 @@ cpgDensity<-function(bs,organism,windowLength=1000){ |
32 | 32 |
x |
33 | 33 |
}) |
34 | 34 |
|
35 |
- |
|
36 | 35 |
rownames(cpgdCov)<-1:maxcpgd |
37 |
- #cpgdBin<-cut(cpgd,seq(0,max(cpgd),5)) |
|
38 |
- |
|
39 |
- # Need to find a better way to conduct this on-disk |
|
40 |
- #cpgdCov <- by(cov>0, cpgd, colSums) |
|
41 |
- #cpgdCov <- do.call("rbind", cpgdCov) |
|
42 | 36 |
return(cpgdCov) |
43 |
- |
|
44 | 37 |
} |
... | ... |
@@ -45,13 +45,11 @@ cpgDiscretization<-function(bs,subSample=1e6,offset=50000,coverageVec=NULL){ |
45 | 45 |
}else{ |
46 | 46 |
covVec<-coverageVec |
47 | 47 |
} |
48 |
- #methMatrix[methMatrix>=0.8]<-1 |
|
49 |
- #methMatrix[methMatrix<=0.2]<-0 |
|
50 | 48 |
|
51 | 49 |
# Only consider methylation between 0.2 and 0.8 |
52 | 50 |
methCutOff<-c(0.01,0.19,0.79,1.0) |
53 | 51 |
|
54 |
- methylationDistMatrix<-sapply(1:nSamples, function(i) { |
|
52 |
+ methylationDistMatrix<-sapply(seq_len(nSamples), function(i) { |
|
55 | 53 |
mv = as.vector(methMatrix[,i]) |
56 | 54 |
mv<-mv[!is.na(mv)] |
57 | 55 |
mvBin<-cut(mv,methCutOff) |
... | ... |
@@ -60,7 +58,6 @@ cpgDiscretization<-function(bs,subSample=1e6,offset=50000,coverageVec=NULL){ |
60 | 58 |
x |
61 | 59 |
}) |
62 | 60 |
|
63 |
- |
|
64 | 61 |
removedCpGs<-methylationDistMatrix[2,]*(nCpGs/subSample) |
65 | 62 |
removedCpGFrac<-(removedCpGs/(covVec))*100 |
66 | 63 |
returnList<-list('discard' = removedCpGs, |
... | ... |
@@ -37,17 +37,15 @@ downsample <-function(bs,dsRates = c(0.01,0.02,0.05, seq(0.1,0.9,0.1)),subSample |
37 | 37 |
nSamples<-dim(covMatrix)[2] |
38 | 38 |
downSampleMatrix<-matrix(nrow=length(dsRates)+1,ncol=nSamples) |
39 | 39 |
maxCov<-20 |
40 |
- |
|
41 | 40 |
nonZeroProbMatrix<-matrix(nrow=(length(dsRates)+1),ncol=maxCov) |
42 | 41 |
|
43 |
- for (i in 1:length(dsRates)){ |
|
44 |
- nonZeroProbMatrix[i,]<-1 - dbinom(0,1:maxCov,dsRates[i]) |
|
42 |
+ for (i in seq_len(length(dsRates))){ |
|
43 |
+ nonZeroProbMatrix[i,]<-1 - dbinom(0,seq_len(maxCov),dsRates[i]) |
|
45 | 44 |
} |
46 | 45 |
|
47 | 46 |
nonZeroProbMatrix[(length(dsRates)+1),]<-1 |
48 | 47 |
|
49 |
- |
|
50 |
- countMatrix<-sapply(1:ncol(covMatrix), function(i) { |
|
48 |
+ countMatrix<-sapply(seq_len(ncol(covMatrix)), function(i) { |
|
51 | 49 |
cv = as.vector(covMatrix[,i]) |
52 | 50 |
cv[cv>maxCov ] <- maxCov |
53 | 51 |
tab <- table(cv) |
... | ... |
@@ -60,16 +58,6 @@ downsample <-function(bs,dsRates = c(0.01,0.02,0.05, seq(0.1,0.9,0.1)),subSample |
60 | 58 |
downSampleMatrix<-round(nonZeroProbMatrix %*% countMatrix) |
61 | 59 |
downSampleMatrix<-downSampleMatrix*(nCpGs/subSample) |
62 | 60 |
|
63 |
- #for (i in 1:length(dsRates)){ |
|
64 |
- # for (j in 1:nSamples){ |
|
65 |
- # cellCoverage<-as.vector(covMatrix[,j]) |
|
66 |
- # cellNonZeroCoverage<-cellCoverage[cellCoverage>0] |
|
67 |
- # covSubList<-lapply(cellNonZeroCoverage,rbinom,n=1,prob=dsRates[i]) |
|
68 |
- # downSampleMatrix[i,j]<- sum(covSubList>0) |
|
69 |
- |
|
70 |
- # } |
|
71 |
- #} |
|
72 |
- #downSampleMatrix[length(dsRates)+1,]<-DelayedArray::colSums(covMatrix>0) |
|
73 | 61 |
rownames(downSampleMatrix)<-c(dsRates,1) |
74 | 62 |
return(downSampleMatrix) |
75 | 63 |
} |
... | ... |
@@ -28,13 +28,11 @@ |
28 | 28 |
|
29 | 29 |
featureCoverage <-function(bs,features,genomebuild){ |
30 | 30 |
|
31 |
- |
|
32 | 31 |
annotationFeatures<-c() |
33 | 32 |
for (i in features){ |
34 | 33 |
annotationFeatures<-c(paste0(genomebuild,'_',i),annotationFeatures) |
35 | 34 |
} |
36 | 35 |
|
37 |
- |
|
38 | 36 |
annots_gr = annotatr::build_annotations(genome = genomebuild, |
39 | 37 |
annotations = annotationFeatures) |
40 | 38 |
GenomeInfoDb::seqlevelsStyle(bs)<-"UCSC" |
... | ... |
@@ -43,7 +41,7 @@ featureCoverage <-function(bs,features,genomebuild){ |
43 | 41 |
|
44 | 42 |
sumAnnotMatrix<-matrix(nrow=length(features),ncol=nSamples) |
45 | 43 |
featureLabel<-rep(NA,length(features)) |
46 |
- for (i in 1:nSamples){ |
|
44 |
+ for (i in seq_len(nSamples)){ |
|
47 | 45 |
bsCell<-bs[,i] |
48 | 46 |
|
49 | 47 |
# CpGs that are observed |
... | ... |
@@ -59,7 +59,6 @@ mbiasplot<-function(dir=NULL,mbiasFiles=NULL){ |
59 | 59 |
mt<-reshape2::melt(mbiasTableList, |
60 | 60 |
id.vars=c('position', 'X..methylation', 'read')) |
61 | 61 |
|
62 |
- |
|
63 | 62 |
mt$read_rep <- paste(mt$read, mt$L1, sep="_") |
64 | 63 |
sum_mt <- mt %>% dplyr::select('read','position','X..methylation','L1') %>% |
65 | 64 |
dplyr::group_by(position,read) %>% |
... | ... |
@@ -79,7 +78,5 @@ mbiasplot<-function(dir=NULL,mbiasFiles=NULL){ |
79 | 78 |
alpha=0.4) |
80 | 79 |
g<-g+ggplot2::ylim(0,100)+ggplot2::ggtitle('Mbias Plot') |
81 | 80 |
g<-g+ggplot2::ylab('methylation') |
82 |
- |
|
83 |
- |
|
84 | 81 |
return(g) |
85 | 82 |
} |
... | ... |
@@ -40,7 +40,7 @@ methylationDist<-function(bs,subSample=1e6, offset=50000,coverageVec=NULL){ |
40 | 40 |
} |
41 | 41 |
#totCpGs<-DelayedArray::colSums(covMatrix>0) |
42 | 42 |
|
43 |
- methylationDistMatrix<-sapply(1:nSamples, function(i) { |
|
43 |
+ methylationDistMatrix<-sapply(seq_len(nSamples), function(i) { |
|
44 | 44 |
mv = as.vector(methMatrix[,i]) |
45 | 45 |
mv<-mv[!is.na(mv)] |
46 | 46 |
mvBin<-cut(mv,methCutOff) |
... | ... |
@@ -52,17 +52,12 @@ methylationDist<-function(bs,subSample=1e6, offset=50000,coverageVec=NULL){ |
52 | 52 |
methylationDistMatrix<-t(methylationDistMatrix) |
53 | 53 |
methylationDistMatrix<-methylationDistMatrix*(nCpGs/subSample) |
54 | 54 |
|
55 |
- |
|
56 | 55 |
methylationDistMatrix<-apply(methylationDistMatrix,2,function(x) x/totCpGs) |
57 | 56 |
orderdMeth<-order(methylationDistMatrix[,1]) |
58 | 57 |
methylationDistMatrix<-methylationDistMatrix[orderdMeth,] |
59 | 58 |
|
60 | 59 |
colnames(methylationDistMatrix)<-c('[0,0.2]','(0.2,0.4]','(0.4,0.6]','(0.6,0.8]','(0.8,1]') |
61 | 60 |
meltedMDistMatrix<-reshape2::melt(methylationDistMatrix) |
62 |
- |
|
63 |
- |
|
64 |
- |
|
65 | 61 |
return(meltedMDistMatrix) |
66 |
- |
|
67 | 62 |
} |
68 | 63 |
|
... | ... |
@@ -16,7 +16,6 @@ |
16 | 16 |
|
17 | 17 |
|
18 | 18 |
repMask<-function(bs,organism,genome){ |
19 |
- |
|
20 | 19 |
GenomeInfoDb::seqlevelsStyle(bs)<-"UCSC" |
21 | 20 |
hub <- AnnotationHub::AnnotationHub() |
22 | 21 |
repeatGr <- hub[[names(AnnotationHub::query(hub, |
... | ... |
@@ -25,5 +24,4 @@ repMask<-function(bs,organism,genome){ |
25 | 24 |
cov<-bsseq::getCoverage(bs) |
26 | 25 |
covDf <- data.frame(coveredCpgs=DelayedArray::colSums(cov[!rep,]>=1)) |
27 | 26 |
return(covDf) |
28 |
- |
|
29 | 27 |
} |
... | ... |
@@ -23,11 +23,10 @@ scmeth::coverage(bsObject) |
23 | 23 |
## ----fig.width=6,fig.height=3-------------------------------------------- |
24 | 24 |
scmeth::readmetrics(bsObject) |
25 | 25 |
|
26 |
-## ---- warning=FALSE,message=FALSE,eval=FALSE----------------------------- |
|
27 |
-# library(BSgenome.Mmusculus.UCSC.mm10) |
|
28 |
-# #load(system.file("extdata",'bsObject.rda',package='scmeth')) |
|
29 |
-# load('bsObject.rda') |
|
30 |
-# scmeth::repMask(bs,Mmusculus,"mm10") |
|
26 |
+## ---- warning=FALSE,message=FALSE---------------------------------------- |
|
27 |
+library(BSgenome.Mmusculus.UCSC.mm10) |
|
28 |
+load(system.file("extdata",'bsObject.rda',package='scmeth')) |
|
29 |
+scmeth::repMask(bs,Mmusculus,"mm10") |
|
31 | 30 |
|
32 | 31 |
## ---- warning=FALSE------------------------------------------------------ |
33 | 32 |
scmeth::chromosomeCoverage(bsObject) |
... | ... |
@@ -160,10 +160,9 @@ mask regions of the genome **repmask** function will require the organism and |
160 | 160 |
the genome build information. |
161 | 161 |
</p> |
162 | 162 |
|
163 |
-```{r, warning=FALSE,message=FALSE,eval=FALSE} |
|
163 |
+```{r, warning=FALSE,message=FALSE} |
|
164 | 164 |
library(BSgenome.Mmusculus.UCSC.mm10) |
165 | 165 |
load(system.file("extdata",'bsObject.rda',package='scmeth')) |
166 |
-#load('bsObject.rda') |
|
167 | 166 |
scmeth::repMask(bs,Mmusculus,"mm10") |
168 | 167 |
``` |
169 | 168 |
|
... | ... |
@@ -166,9 +166,12 @@ bsObject<-HDF5Array<span class="op">::</span><span class="kw">loadHDF5Summari |
166 | 166 |
CpG Islands are characterized by their high GC content, high level of observed to expected ratio of CpGs and length over 500 bp. However some repeat regions in the genome also fit the same criteria although they are not bona fide CpG Island. Therefore it is important to see how many CpGs are observed in the non repeat regions of the genome. <strong>repMask</strong> functions provide information on the CpG coverage in non repeat regions of the genome. In order to build the repeat mask regions of the genome <strong>repmask</strong> function will require the organism and the genome build information. |
167 | 167 |
</p> |
168 | 168 |
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">library</span>(BSgenome.Mmusculus.UCSC.mm10) |
169 |
-<span class="co">#load(system.file("extdata",'bsObject.rda',package='scmeth'))</span> |
|
170 |
-<span class="kw">load</span>(<span class="st">'bsObject.rda'</span>) |
|
169 |
+<span class="kw">load</span>(<span class="kw">system.file</span>(<span class="st">"extdata"</span>,<span class="st">'bsObject.rda'</span>,<span class="dt">package=</span><span class="st">'scmeth'</span>)) |
|
171 | 170 |
scmeth<span class="op">::</span><span class="kw">repMask</span>(bs,Mmusculus,<span class="st">"mm10"</span>)</code></pre></div> |
171 |
+<pre><code>## coveredCpgs |
|
172 |
+## sc-RRBS_zyg_01_chr1 12208 |
|
173 |
+## sc-RRBS_zyg_02_chr1 3056 |
|
174 |
+## sc-RRBS_zyg_03_chr1 6666</code></pre> |
|
172 | 175 |
</div> |
173 | 176 |
<div id="coverage-by-chromosome" class="section level3"> |
174 | 177 |
<h3>Coverage by Chromosome</h3> |
... | ... |
@@ -191,8 +194,8 @@ Another way to observe the distribution of CpGs is to classify them by the genom |
191 | 194 |
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">library</span>(annotatr) |
192 | 195 |
featureList<-<span class="kw">c</span>(<span class="st">'genes_exons'</span>,<span class="st">'genes_introns'</span>) |
193 | 196 |
DT<span class="op">::</span><span class="kw">datatable</span>(scmeth<span class="op">::</span><span class="kw">featureCoverage</span>(bsObject,<span class="dt">features=</span>featureList,<span class="st">"hg38"</span>))</code></pre></div> |
194 |
-<div id="htmlwidget-33cc698d6a61a45af7a0" style="width:100%;height:auto;" class="datatables html-widget"></div> |
|
195 |
-<script type="application/json" data-for="htmlwidget-33cc698d6a61a45af7a0">{"x":{"filter":"none","data":[["hg38_genes_exons","hg38_genes_introns"],[0.644963144963145,0.248894348894349],[0.580985915492958,0.226525821596244],[0.616113744075829,0.182464454976303]],"container":"<table class=\"display\">\n <thead>\n <tr>\n <th> <\/th>\n <th>2017-08-02_HL2F5BBXX_4_CTCTCTAC_AGAAGG_report.txt<\/th>\n <th>2017-08-02_HL2F5BBXX_4_CGAGGCTG_TGTAGG_report.txt<\/th>\n <th>2017-08-02_HL2F5BBXX_6_CGAGGCTG_AGGATG_report.txt<\/th>\n <\/tr>\n <\/thead>\n<\/table>","options":{"columnDefs":[{"className":"dt-right","targets":[1,2,3]},{"orderable":false,"targets":0}],"order":[],"autoWidth":false,"orderClasses":false},"selection":{"mode":"multiple","selected":null,"target":"row"}},"evals":[],"jsHooks":[]}</script> |
|
197 |
+<div id="htmlwidget-823d9c0ad8f72ea68d3c" style="width:100%;height:auto;" class="datatables html-widget"></div> |
|
198 |
+<script type="application/json" data-for="htmlwidget-823d9c0ad8f72ea68d3c">{"x":{"filter":"none","data":[["hg38_genes_exons","hg38_genes_introns"],[0.644963144963145,0.248894348894349],[0.580985915492958,0.226525821596244],[0.616113744075829,0.182464454976303]],"container":"<table class=\"display\">\n <thead>\n <tr>\n <th> <\/th>\n <th>2017-08-02_HL2F5BBXX_4_CTCTCTAC_AGAAGG_report.txt<\/th>\n <th>2017-08-02_HL2F5BBXX_4_CGAGGCTG_TGTAGG_report.txt<\/th>\n <th>2017-08-02_HL2F5BBXX_6_CGAGGCTG_AGGATG_report.txt<\/th>\n <\/tr>\n <\/thead>\n<\/table>","options":{"columnDefs":[{"className":"dt-right","targets":[1,2,3]},{"orderable":false,"targets":0}],"order":[],"autoWidth":false,"orderClasses":false},"selection":{"mode":"multiple","selected":null,"target":"row"}},"evals":[],"jsHooks":[]}</script> |
|
196 | 199 |
</p> |
197 | 200 |
</div> |
198 | 201 |
<div id="cpgdensity" class="section level3"> |
... | ... |
@@ -202,8 +205,8 @@ CpGs are not distributed across the genome uniformly. Most of the genome contain |
202 | 205 |
</p> |
203 | 206 |
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r"><span class="kw">library</span>(BSgenome.Hsapiens.NCBI.GRCh38) |
204 | 207 |
DT<span class="op">::</span><span class="kw">datatable</span>(scmeth<span class="op">::</span><span class="kw">cpgDensity</span>(bsObject,Hsapiens,<span class="dt">windowLength=</span><span class="dv">1000</span>))</code></pre></div> |
205 |
-<div id="htmlwidget-8df4b711314a2fb8519d" style="width:100%;height:auto;" class="datatables html-widget"></div> |
|
206 |
-<script type="application/json" data-for="htmlwidget-8df4b711314a2fb8519d">{"x":{"filter":"none","data":[["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","31","32","33","34","35","36","37","38","39","40","41","42","43","44","45","46","47","48","49","50","51","52","53","54","55","56","57","58","59","60","61","62","63","64","65","66","67","68","69","70","71","72","73","74","75","76","77","78","79","80","81","82","83","84","85","86","87","88","89","90","91","92","93","94","95","96","97","98","99","100","101","102","103","104","105","106","107","108","109","110","111","112","113","114","115","116","117","118","119","120","121","122","123","124","125","126","127","128","129","130","131","132","133","134","135","136","137","138","139","140","141","142","143","144","145","146","147","148","149","150","151","152","153","154","155","156","157","158","159","160","161","162","163","164","165","166","167","168","169","170","171","172","173","174","175","176","177","178","179","180","181","182","183","184","185","186","187","188","189","190","191","192","193","194","195","196","197","198","199","200","201","202","203","204","205","206","207","208","209"],[0,0,0,1,3,0,1,2,2,4,7,8,7,12,23,20,26,32,40,68,44,68,77,85,97,104,117,125,131,124,113,148,114,98,119,119,115,142,109,99,93,77,60,58,65,53,48,44,51,44,39,34,28,33,25,25,20,18,31,21,19,14,12,8,11,7,15,8,12,6,11,21,6,13,6,6,13,22,19,25,16,19,14,4,11,7,4,7,14,8,21,6,8,8,8,4,3,3,1,1,7,4,5,12,18,15,13,10,11,12,5,3,4,7,4,7,18,11,3,4,5,5,4,3,2,6,5,6,7,9,14,7,12,14,7,6,1,3,0,0,0,1,0,2,0,1,5,2,2,0,0,0,0,1,0,2,2,2,0,5,1,3,4,6,6,0,3,3,6,11,0,3,2,4,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,3,3,2,0,0,0,0,0,0,0,0,0,0],[0,0,1,0,0,0,3,0,0,0,1,4,3,2,6,3,17,13,14,27,9,25,8,17,17,26,24,27,22,19,28,32,34,21,23,32,19,18,31,24,12,12,16,19,16,17,18,13,10,11,8,15,8,4,3,1,5,4,2,0,0,1,1,1,3,2,1,1,1,3,4,1,2,3,0,0,0,1,1,1,1,2,0,0,0,0,0,4,2,4,1,0,3,2,5,1,2,3,1,6,0,1,0,0,0,0,0,1,3,7,0,1,0,0,0,2,5,4,6,4,0,0,0,2,0,2,0,0,1,1,1,0,0,0,1,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],[0,0,0,0,0,0,0,1,1,0,1,0,0,0,2,2,4,3,5,7,8,15,12,9,10,4,13,14,11,15,16,10,17,19,14,17,13,13,14,11,6,4,6,10,5,3,3,4,4,5,3,3,1,0,3,2,0,1,0,0,0,3,3,1,1,0,0,2,2,3,3,2,1,0,1,1,0,1,3,0,1,1,0,0,0,0,0,0,0,1,2,4,6,9,7,0,2,6,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,2,1,1,4,2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]],"container":"<table class=\"display\">\n <thead>\n <tr>\n <th> <\/th>\n <th>V1<\/th>\n <th>V2<\/th>\n <th>V3<\/th>\n <\/tr>\n <\/thead>\n<\/table>","options":{"columnDefs":[{"className":"dt-right","targets":[1,2,3]},{"orderable":false,"targets":0}],"order":[],"autoWidth":false,"orderClasses":false},"selection":{"mode":"multiple","selected":null,"target":"row"}},"evals":[],"jsHooks":[]}</script> |
|
208 |
+<div id="htmlwidget-b6422b8c79b50a20cdfe" style="width:100%;height:auto;" class="datatables html-widget"></div> |
|
209 |
+<script type="application/json" data-for="htmlwidget-b6422b8c79b50a20cdfe">{"x":{"filter":"none","data":[["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","31","32","33","34","35","36","37","38","39","40","41","42","43","44","45","46","47","48","49","50","51","52","53","54","55","56","57","58","59","60","61","62","63","64","65","66","67","68","69","70","71","72","73","74","75","76","77","78","79","80","81","82","83","84","85","86","87","88","89","90","91","92","93","94","95","96","97","98","99","100","101","102","103","104","105","106","107","108","109","110","111","112","113","114","115","116","117","118","119","120","121","122","123","124","125","126","127","128","129","130","131","132","133","134","135","136","137","138","139","140","141","142","143","144","145","146","147","148","149","150","151","152","153","154","155","156","157","158","159","160","161","162","163","164","165","166","167","168","169","170","171","172","173","174","175","176","177","178","179","180","181","182","183","184","185","186","187","188","189","190","191","192","193","194","195","196","197","198","199","200","201","202","203","204","205","206","207","208","209"],[0,0,0,1,3,0,1,2,2,4,7,8,7,12,23,20,26,32,40,68,44,68,77,85,97,104,117,125,131,124,113,148,114,98,119,119,115,142,109,99,93,77,60,58,65,53,48,44,51,44,39,34,28,33,25,25,20,18,31,21,19,14,12,8,11,7,15,8,12,6,11,21,6,13,6,6,13,22,19,25,16,19,14,4,11,7,4,7,14,8,21,6,8,8,8,4,3,3,1,1,7,4,5,12,18,15,13,10,11,12,5,3,4,7,4,7,18,11,3,4,5,5,4,3,2,6,5,6,7,9,14,7,12,14,7,6,1,3,0,0,0,1,0,2,0,1,5,2,2,0,0,0,0,1,0,2,2,2,0,5,1,3,4,6,6,0,3,3,6,11,0,3,2,4,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,3,3,2,0,0,0,0,0,0,0,0,0,0],[0,0,1,0,0,0,3,0,0,0,1,4,3,2,6,3,17,13,14,27,9,25,8,17,17,26,24,27,22,19,28,32,34,21,23,32,19,18,31,24,12,12,16,19,16,17,18,13,10,11,8,15,8,4,3,1,5,4,2,0,0,1,1,1,3,2,1,1,1,3,4,1,2,3,0,0,0,1,1,1,1,2,0,0,0,0,0,4,2,4,1,0,3,2,5,1,2,3,1,6,0,1,0,0,0,0,0,1,3,7,0,1,0,0,0,2,5,4,6,4,0,0,0,2,0,2,0,0,1,1,1,0,0,0,1,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],[0,0,0,0,0,0,0,1,1,0,1,0,0,0,2,2,4,3,5,7,8,15,12,9,10,4,13,14,11,15,16,10,17,19,14,17,13,13,14,11,6,4,6,10,5,3,3,4,4,5,3,3,1,0,3,2,0,1,0,0,0,3,3,1,1,0,0,2,2,3,3,2,1,0,1,1,0,1,3,0,1,1,0,0,0,0,0,0,0,1,2,4,6,9,7,0,2,6,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,2,1,1,4,2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]],"container":"<table class=\"display\">\n <thead>\n <tr>\n <th> <\/th>\n <th>V1<\/th>\n <th>V2<\/th>\n <th>V3<\/th>\n <\/tr>\n <\/thead>\n<\/table>","options":{"columnDefs":[{"className":"dt-right","targets":[1,2,3]},{"orderable":false,"targets":0}],"order":[],"autoWidth":false,"orderClasses":false},"selection":{"mode":"multiple","selected":null,"target":"row"}},"evals":[],"jsHooks":[]}</script> |
|
207 | 210 |
</div> |
208 | 211 |
<div id="downsample" class="section level3"> |
209 | 212 |
<h3>downsample</h3> |
... | ... |
@@ -211,8 +214,8 @@ DT<span class="op">::</span><span class="kw">datatable</span>(scmeth<span class= |
211 | 214 |
In addition to the CpG coverage, methylation data can be assessed via down sampling analysis, methylation bias plot and methylation distribution. Down sampling analysis is a technique to assess whether the sequencing process achieved the saturation level in terms of CpG capture. In order to perform down sampling analysis CpGs that are covered at least will be sampled via binomial random sampling with given probability. At each probability level the number of CpGs captured is assessed. If the number of CpG captured attains a plateau then the sequencing was successful. <strong>downsample</strong> function provides a matrix of CpG coverage for each sample at various down sampling rates. The report renders this information into a plot. Downsampling rate ranges from 0.01 to 1, however users can change the downsampling rates. |
212 | 215 |
</p> |
213 | 216 |
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">DT<span class="op">::</span><span class="kw">datatable</span>(scmeth<span class="op">::</span><span class="kw">downsample</span>(bsObject))</code></pre></div> |
214 |
-<div id="htmlwidget-5f924144d642c7ecf599" style="width:100%;height:auto;" class="datatables html-widget"></div> |
|
215 |
-<script type="application/json" data-for="htmlwidget-5f924144d642c7ecf599">{"x":{"filter":"none","data":[["0.01","0.02","0.05","0.1","0.2","0.3","0.4","0.5","0.6","0.7","0.8","0.9","1"],[8,15.9,38.7,74.2,137,190.4,236.1,275.4,309.3,338.8,364.6,387.1,407],[2.3,4.6,11,20.4,35.9,47.9,57.2,64.7,70.6,75.4,79.3,82.5,85.2],[1.2,2.4,5.7,10.5,18.2,23.9,28.2,31.6,34.4,36.8,38.8,40.6,42.2]],"container":"<table class=\"display\">\n <thead>\n <tr>\n <th> <\/th>\n <th>V1<\/th>\n <th>V2<\/th>\n <th>V3<\/th>\n <\/tr>\n <\/thead>\n<\/table>","options":{"columnDefs":[{"className":"dt-right","targets":[1,2,3]},{"orderable":false,"targets":0}],"order":[],"autoWidth":false,"orderClasses":false},"selection":{"mode":"multiple","selected":null,"target":"row"}},"evals":[],"jsHooks":[]}</script> |
|
217 |
+<div id="htmlwidget-7f1b12fff5e4ec761a40" style="width:100%;height:auto;" class="datatables html-widget"></div> |
|
218 |
+<script type="application/json" data-for="htmlwidget-7f1b12fff5e4ec761a40">{"x":{"filter":"none","data":[["0.01","0.02","0.05","0.1","0.2","0.3","0.4","0.5","0.6","0.7","0.8","0.9","1"],[8,15.9,38.7,74.2,137,190.4,236.1,275.4,309.3,338.8,364.6,387.1,407],[2.3,4.6,11,20.4,35.9,47.9,57.2,64.7,70.6,75.4,79.3,82.5,85.2],[1.2,2.4,5.7,10.5,18.2,23.9,28.2,31.6,34.4,36.8,38.8,40.6,42.2]],"container":"<table class=\"display\">\n <thead>\n <tr>\n <th> <\/th>\n <th>V1<\/th>\n <th>V2<\/th>\n <th>V3<\/th>\n <\/tr>\n <\/thead>\n<\/table>","options":{"columnDefs":[{"className":"dt-right","targets":[1,2,3]},{"orderable":false,"targets":0}],"order":[],"autoWidth":false,"orderClasses":false},"selection":{"mode":"multiple","selected":null,"target":"row"}},"evals":[],"jsHooks":[]}</script> |
|
216 | 219 |
</div> |
217 | 220 |
<div id="mbiasplot" class="section level3"> |
218 | 221 |
<h3>mbiasPlot</h3> |
... | ... |
@@ -253,7 +256,7 @@ scmeth<span class="op">::</span><span class="kw">mbiasplot</span>(<span class="d |
253 | 256 |
Another important metric in methylation analysis is the bisulfite conversion rate. Bisulfite conversion rate indicates out of all the Cytosines in the non CpG context what fraction of them were methylated. Ideally this number should be 1 or 100% indicating none of the non CpG context cytosines are methylated. However in real data this will not be the case, yet bisulfite conversion rate below 95% indicates some problem with sample preparation. <strong>bsConversionPlot</strong> function generates a plot showing this metric for each sample. |
254 | 257 |
</p> |
255 | 258 |
<div class="sourceCode"><pre class="sourceCode r"><code class="sourceCode r">scmeth<span class="op">::</span><span class="kw">bsConversionPlot</span>(bsObject)</code></pre></div> |
256 |
-<p><img src="" /><!-- --></p> |
|
259 |
+<p><img src="" /><!-- --></p> |
|
257 | 260 |
</div> |
258 | 261 |
</div> |
259 | 262 |
|