-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathhit_svd.R
69 lines (52 loc) · 3.31 KB
/
hit_svd.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
perform_svd <- function(data, colorData, colorDataDim, colorLabel) {
dataMatrix <- read.table(data, row.names = 1)
(s <- svd(dataMatrix))
u <- s$u
v <- s$v
d <- s$d
write.table(u, file = paste(data, ".u", sep = ''))
write.table(v, file = paste(data, ".v", sep = ''))
write.table(d, file = paste(data, ".d", sep = ''))
png(filename = paste(data, ".d.png", sep = ''), res = 600, height = 3, width = 3, units = "in", pointsize = 6)
plot(1:length(s$d), s$d, xlab = "component number", ylab = "singular value", cex.axis = 1.5, cex.lab = 1.5)
dev.off()
setEPS()
postscript(paste(data, ".d.eps", sep = ''))
plot(1:length(s$d), s$d, xlab = "component number", ylab = "singular value", cex.axis = 1.5, cex.lab = 1.5)
dev.off()
png(filename = paste(data, ".v.png", sep = ''), res = 600, height = 3, width = 3, units = "in", pointsize = 6)
plot(s$v[,1], s$v[,2], xlab = "factor 1", ylab = " factor 2", cex.axis = 1.5, cex.lab = 1.5)
dev.off()
setEPS()
postscript(paste(data, ".v.eps", sep = ''))
plot(s$v[,1], s$v[,2], xlab = "factor 1", ylab = " factor 2", cex.axis = 1.5, cex.lab = 1.5)
dev.off()
png(filename = paste(data, ".v_id.png", sep = ''), res = 600, height = 3, width = 3, units = "in", pointsize = 6)
plot(s$v[,1], s$v[,2], xlab = "factor 1", ylab = " factor 2", cex.axis = 1.5, cex.lab = 1.5)
text(s$v[,1], s$v[,2], labels = seq_along(s$v[,1]), pos = 1)
dev.off()
setEPS()
postscript(paste(data, ".v_id.eps", sep = ''))
plot(s$v[,1], s$v[,2], xlab = "factor 1", ylab = " factor 2", cex.axis = 1.5, cex.lab = 1.5)
text(s$v[,1], s$v[,2], labels = seq_along(s$v[,1]), pos = 1)
dev.off()
colorMatrix <- read.csv(colorData, header = FALSE)
png(filename = paste(paste(paste(data, ".v_", sep = ''), colorLabel, sep = ''), ".png", sep = ''), res = 600, height = 3, width = 3, units = "in", pointsize = 6)
plot(s$v[,1], s$v[,2], xlab = "factor 1", ylab = " factor 2", col = rgb(log(1 + (colorMatrix[, colorDataDim] - colorMatrix[, colorDataDim][which.min(colorMatrix[, colorDataDim])])), 0, 0, maxColorValue = log(1 + (colorMatrix[, colorDataDim][which.max(colorMatrix[, colorDataDim])] - colorMatrix[, colorDataDim][which.min(colorMatrix[, colorDataDim])])), alpha = log(1 + (colorMatrix[, colorDataDim] - colorMatrix[, colorDataDim][which.min(colorMatrix[, colorDataDim])]))), pch = 19, cex = 1.5, cex.axis = 1.5, cex.lab = 1.5)
dev.off()
setEPS()
postscript(paste(paste(paste(data, ".v_", sep = ''), colorLabel, sep = ''), ".eps", sep = ''))
plot(s$v[,1], s$v[,2], xlab = "factor 1", ylab = " factor 2", col = rgb(log(1 + (colorMatrix[, colorDataDim] - colorMatrix[, colorDataDim][which.min(colorMatrix[, colorDataDim])])), 0, 0, maxColorValue = log(1 + (colorMatrix[, colorDataDim][which.max(colorMatrix[, colorDataDim])] - colorMatrix[, colorDataDim][which.min(colorMatrix[, colorDataDim])]))), pch = 19, cex = 1.5, cex.axis = 1.5, cex.lab = 1.5)
dev.off()
return (s)
}
arg <- commandArgs(trailingOnly = TRUE)
argLen <- length(arg)
if (argLen == 4) {
rawDataMatrix <- arg[1]
colorData <- arg[2]
colorDataDim <- as.numeric(arg[3])
colorLabel <- arg[4]
print(paste("Applying SVD on ", arg, " data...", sep = ''))
perform_svd(rawDataMatrix, colorData, colorDataDim, colorLabel)
}