forked from interactivereport/cellxgene_VIP
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDensity2D.R
executable file
·83 lines (79 loc) · 3.17 KB
/
Density2D.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
#!/usr/bin/env Rscript
##Density2D.R
##
args = commandArgs(trailingOnly = TRUE)
if(length(args)<1) q()
libPath = tail(args,1)
if(nchar(libPath)>3){
addPath <- unlist(strsplit(libPath,";"))
addPath <- addPath[sapply(addPath,dir.exists)]
.libPaths(c(addPath,.libPaths()))
}
if(!require(ggplot2,quietly=T) || !require(MASS,quietly=T) || !require(dplyr,quietly=T,warn.conflicts=F)) stop("ggplot2, dplyr and MASS are required R package!")
options(bitmapType='cairo')
get_density = function(x, y, ...) {
dens <- MASS::kde2d(x, y, ...)
ix <- findInterval(x, dens$x)
iy <- findInterval(y, dens$y)
ii <- cbind(ix, iy)
return(dens$z[ii])
}
strCSV = args[1]
strFun <- args[2]
minExpr <- as.numeric(args[3])
bandwidth <- as.numeric(args[4])
if (grepl( "_r", args[5], fixed = TRUE)) {
dir <- -1
} else {
dir <- 1
}
colMap <- switch(sub("_r",'',args[5]),"B",magma="A",inferno="B",plasma="C",viridis="D")
fontsize <- as.numeric(args[6])
dpi <- as.numeric(args[7])
expr <- read.csv(strCSV,row.names=1,as.is=T,check.names=F)#
axisLab <- colnames(expr)
expr <- data.frame(expr,check.names=T)
#minExpr <- apply(expr,2,min)
expr <- expr[apply(expr,1,function(x)return(sum(x>minExpr)))>0,]
if(nrow(expr)<50) stop("Less than 50 cells expression above minimal value in at least one of two genes!")
p <- ggplot(expr,aes_string(colnames(expr)[1],colnames(expr)[2]))+
xlim(-0.5,max(expr))+ylim(-0.5,max(expr))+
ggtitle(paste("Density on",nrow(expr),"cells")) +
geom_hex(bins=bandwidth)+
scale_fill_continuous(type="viridis")+
geom_vline(xintercept = 0, color = "red", linetype = 2) +
geom_hline(yintercept = 0, color = "red", linetype = 2) +
theme_bw()+
theme(axis.text = element_text(face = "bold"),
text=element_text(size=fontsize),
aspect.ratio=1) +
viridis::scale_fill_viridis(option = colMap, direction = dir) +
scale_shape_identity()
if(F){
h <- c(max(bandwidth,MASS::bandwidth.nrd(expr[,1])),
max(bandwidth,MASS::bandwidth.nrd(expr[,2])))
#if(MASS::bandwidth.nrd(expr[,1])<=0 || MASS::bandwidth.nrd(expr[,2])<=0)
# stop(paste("The difference between the first and second quantile of the expression (min=",min(apply(expr,2,min)),") are NOT positive for at least one gene in selected cells! Try to increase the expression cutoff (",minExpr,").",sep=""))
D <- expr %>% dplyr::mutate(density=get_density(expr[,1],expr[,2],h=h,n=min(100,nrow(expr)/10)))
p <- ggplot(D, aes_string(x = colnames(D)[1], y = colnames(D)[2], color = 'density')) +
geom_point(size = 0.4) + theme_classic() + ggtitle(paste("Density on",nrow(expr),"cells")) +
xlab(axisLab[1])+ylab(axisLab[2])+
geom_vline(xintercept = 0, color = "red", linetype = 2) +
geom_hline(yintercept = 0, color = "red", linetype = 2) +
theme(axis.text = element_text(face = "bold"),
text=element_text(size=fontsize)) +
viridis::scale_color_viridis(option = colMap, direction = dir) +
scale_shape_identity()
}
strImg <- gsub("csv$",strFun,strCSV)
f <- get(strFun)
if(sum(strFun%in%c('png','jpeg','tiff'))>0){
f(strImg, width=6.5, height=6.5,units='in',res=dpi)
}else{
f(strImg, width=6.5, height=6.5)
}
print(p)
a <- dev.off()
fig = base64enc::dataURI(file = strImg)
cat(gsub("data:;base64,","",fig))
a <- file.remove(strImg)