這看起來很基本,我幾乎不好意思問這個問題,但我無法得到這個工作。什麼是相同的適用於此。這是一個人爲的例子,因爲我想通過它的行和列索引訪問每個單元格的數據,但它很好地代表了這個問題。R:適用於所有矩陣元素
ndat<-matrix(c(1:100), ncol=10)
for (i in 1:nrow(ndat)) {
for (j in 1:ncol(ndat)) {
cat(ndat[i,j]," ")
}
cat("\n")
}
這是實際的問題。我正試圖在網格上繪製矩陣。我知道textplot可以繪製矩陣,但我需要更多的網格控制。文本的位置取決於行和列索引。代碼如下:
plot.new()
tlx <- 0.04
tly <- 0.96
label_shift <- 0.04
text(tlx + label_shift, tly, "Columns", cex=1, adj=c(0,0))
text(tlx, tly - label_shift, "Rows", cex=1, adj=c(0,1), srt=-90)
ndat<-matrix(c(1:100), ncol=10)
dimnames(ndat) <- list(paste("R",1:10,sep=""), paste("C",1:10,sep=""))
row_name_space <- 0.1
col_name_space <- 0.1
data_width <- 0.075
data_height <- 0.075
x1 <- 1.5 * tlx
x2 <- x1 + row_name_space + ncol(ndat) * data_width
y1 <- tly - 0.5*tlx
y2 <- y1 - col_name_space - nrow(ndat) * data_height
lines(c(x1,x1), c(y1,y2))
lines(c(x1,x2), c(y1,y1))
vertical_lseg <- function(n) {
lx <- x1 + row_name_space + (n - 1) * data_width
xv <- c(lx, lx)
yv <- c(y1, y2)
lines (xv, yv)
}
sapply(1:(ncol(ndat)+1), vertical_lseg)
horizontal_lseg <- function(n) {
ly <- y1 - col_name_space - (n - 1) * data_height
xv <- c(x1, x2)
yv <- c(ly, ly)
lines (xv, yv)
}
sapply(1:(nrow(ndat)+1), horizontal_lseg)
sapply(1:nrow(ndat), function(x) text(1.5 * tlx + row_name_space/2, tly - 0.5*tlx - col_name_space - (x - 0.5) * data_height, rownames(ndat)[x], adj=c(0.5,0.5), cex=1))
sapply(1:ncol(ndat), function(x) text(1.5*tlx + col_name_space + (x - 0.5) * data_width, tly - 0.5*tlx - col_name_space /2, colnames(ndat)[x], adj=c(0.5,0.5), cex=1))
# This is where the text would be plotted. The calculation of x and y is right but the number of elements that outer produces seems to be 10,000
# rather than 100
outer(1:nrow(ndat), 1:ncol(ndat), FUN=function(r,c) text(1.5*tlx + col_name_space + (c - 0.5) * data_width,
tly - 0.5*tlx - col_name_space - (r - 0.5) * data_height,
toString(ndat[r,c]), adj=c(0.5,0.5), cex=1))
正確的答案將取決於你正在嘗試做什麼。那麼,你能告訴我們你正在做的沒有人爲的問題嗎? – asb