-
Notifications
You must be signed in to change notification settings - Fork 9
/
deltaFilter.R
92 lines (58 loc) · 2.55 KB
/
deltaFilter.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
80
81
82
83
84
85
86
87
88
89
90
91
92
#' @title Filterin
#' @description This function filter matrix raw count
#' @param threshold, value to estimate if a gene is significatively expressed
#' @param minDelta, filtering value for the minimun difference value between genes WMT&rib and genes without MT and without RB
#' @param minNGene, filtering value for the minimun number of gene
#' @param original, matrix name without annotation
#' @param menoRibo, matrix name with annotation
#' @param separator, matrix separator value
#' @param format, matrix format
#' @param wf, if this parameter is setted to 0 your filtering will be minDelta and minNGene based, otherwise it will take the top wf cells with the higher number of genes significatively expressed
#' @author Luca Alessandri, alessandri.luca [at] gmail [dot] com, University of Torino
#' @return filtered matrix table
#' @examples
#' \dontrun{
#' TOO BE MADE
#' }
#'
#' @export
deltaFilter <- function(threshold,minDelta,minNGene,original,menoRibo,separator,format,wf){
menoRiboName=menoRibo
mainMatrix=read.table(paste(original,".",format,sep=""),sep=separator,header=TRUE,row.names=1)
menoRibo=read.table(paste(menoRibo,".",format,sep=""),sep=separator,header=TRUE,row.names=1)
if(wf==0){
b=menoRibo
b[b<threshold]=0
b[b>=threshold]=1
yCoord=colSums(b)
#xCoord2=log10(colSums(mainMatrix))
b2=mainMatrix
b2[b2<threshold]=0
b2[b2>=threshold]=1
yCoord2=colSums(b2)
cells=intersect(which(yCoord>=minNGene),which((yCoord2-yCoord)>minDelta))
pdf(paste(menoRiboName,"_geneIntersection.pdf",sep=""))
plot(yCoord,yCoord2-yCoord,cex=0.2,pch=19,col="purple",xlab="# of genes", ylab="genesWMT&rib - genes-MT-RB",main=paste(ncol(menoRibo[,cells])," Cells taken"))
points(yCoord[cells],(yCoord2-yCoord)[cells],cex=0.2,pch=19,col="red")
dev.off()
#////////////////
cat(paste("filtered_",menoRiboName,".",format,sep=""))
write.table(menoRibo[,cells],paste("filtered_",menoRiboName,".",format,sep=""),sep=separator,col.names=NA)
}else{
b=menoRibo
b[b<threshold]=0
b[b>=threshold]=1
yCoord=colSums(b)
b2=mainMatrix
b2[b2<threshold]=0
b2[b2>=threshold]=1
yCoord2=colSums(b2)
sorted=sort(yCoord,decreasing=TRUE,index.return=TRUE)
menoRibo2=menoRibo[,head(sorted$ix,wf)]
write.table(menoRibo2,paste("filtered_",menoRiboName,".",format,sep=""),sep=separator,col.names=NA)
pdf(paste(menoRiboName,"_geneIntersection.pdf",sep=""))
plot(yCoord,yCoord2-yCoord,cex=0.2,pch=19,col="purple",xlab="# of genes", ylab="genesWMT&rib - genes-MT-RB")
points(yCoord[head(sorted$ix,wf)],(yCoord2-yCoord)[head(sorted$ix,wf)],cex=0.2,pch=19,col="red")
dev.off()
}
}