-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathars.R
79 lines (70 loc) · 2.41 KB
/
ars.R
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
##
#Copyright (C) DECLERE 2015
#
#This program is free software; you can redistribute it and/or
#modify it under the terms of the GNU General Public License
#as published by the Free Software Foundation; either version 2
#of the License, or (at your option) any later version.
#
#This program is distributed in the hope that it will be useful,
#but WITHOUT ANY WARRANTY; without even the implied warranty of
#MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
#GNU General Public License for more details.
#
#You should have received a copy of the GNU General Public License
#along with this program; if not, write to the Free Software
#Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#Routines used to predict ARS from DP
library(GenomicRanges)
library(GenomicAlignments)
# listing BAM files
bams = list.files(pattern="*sorted*.bam$")
## Definition of ARS intervals
for (bam in bams) {
# results in file
sink(paste ("ARS_", bam, ".txt" ,sep=""))
aln = readGAlignments(bam)
chrs=names(genome(aln))
cvg = coverage(aln)
lib.mean = mean(mean(coverage(aln)))
for (k in chrs){
cov.k = cvg[k][[1]]
cov.vector = as.vector(cov.k)
pos.ars = which(cov.vector >= 5)
min.ars = pos.ars[1]
last.pos = pos.ars[1]
count =0
# iter on all position
for (pos in pos.ars){
if (pos-last.pos>1){
cat(bam, k, count, min.ars, last.pos, round(mean(cov.vector[min.ars:last.pos])),last.pos-min.ars,"\n", sep="\t")
min.ars = pos
count = count+1
}
last.pos=pos
}
}
sink()
}
## ARS post-traitement
txt = list.files(pattern="*.txt$")
for (t in txt){
ars <- read.table(t)
names(ars) <- c("lib", "k", "ars_id", "start", "end", "cov", "len")
sink(paste(t, "_fused", sep=""))
last <- ars[1,]
for (i in 2:nrow(ars)) {
cur=ars[i,]
if (cur$k != last$k) { last=cur; next};
d = (cur$start - last$end)
if (d <= 20){
new_id = paste(last$ars_id, "+", cur$ars_id, sep="");
#cat(cur$lib, cur$k, new_id , last$start, cur$end, ((cur$cov+last$cov)/2), (cur$len+last$len),"\n", sep="\t");
cur = data.frame(lib=cur$lib, k=cur$k, ars_id=new_id , start=last$start, end=cur$end, cov=((cur$cov+last$cov)/2), len=(cur$len+last$len));
} else {
cat( as.character(last$lib), as.character(last$k), as.character(last$ars_id), last$start, last$end, last$cov,last$len,"\n", sep="\t")
}
last = cur;
}
sink()
}