我已经写了下面的代码生成包含什么,对我来说,一个相当复杂的模式矩阵的矩阵。在这种情况下,我通过反复试验确定完成矩阵中有136行。R:创建未知的行数
我可以写一个函数来计算提前矩阵的行数,但功能会有点复杂。在该示例中的行中的矩阵=((4×3 + 1)+(3 * 3 + 1)+(2 * 3 + 1)+(1×3 + 1))* 4
数有没有简单而有效的方法来创建矩阵R中没有硬连线矩阵语句的行数?换句话说,有没有一种简单的方法让R在使用for-loops时根据需要添加一行到矩阵?
我已经提出了一个解决方案,在每次通过循环使用rbind,但似乎有点令人费解,我想知道是否有可能是一个更容易的解决方案。
很抱歉,如果这个问题是多余的前面一个问题。我找不到使用本网站上的搜索功能或今天使用互联网搜索引擎的类似问题,但我认为我在过去的某个地方发现了类似的问题。
下面是2套的实施例的代码,一个使用rbind和其它我曾经试验和误差来设置nrow = 136提前。
感谢您的任何建议。
v1 <- 5
v2 <- 2
v3 <- 2
v4 <- (v1-1)
my.matrix <- matrix(0, nrow=136, ncol=(v1+4))
i = 1
for(a in 1:v2) {
for(b in 1:v3) {
for(c in 1:v4) {
for(d in (c+1):v1) {
if(d == (c+1)) l.s = 4
else l.s = 3
for(e in 1:l.s) {
my.matrix[i,c] = 1
if(d == (c+1)) my.matrix[i,d] = (e-1)
else my.matrix[i,d] = e
my.matrix[i,(v1+1)] = a
my.matrix[i,(v1+2)] = b
my.matrix[i,(v1+3)] = c
my.matrix[i,(v1+4)] = d
i <- i + 1
}
}
}
}
}
my.matrix2 <- matrix(0, nrow=1, ncol=(v1+4))
my.matrix3 <- matrix(0, nrow=1, ncol=(v1+4))
i = 1
for(a in 1:v2) {
for(b in 1:v3) {
for(c in 1:v4) {
for(d in (c+1):v1) {
if(d == (c+1)) l.s = 4
else l.s = 3
for(e in 1:l.s) {
my.matrix2[1,c] = 1
if(d == (c+1)) my.matrix2[1,d] = (e-1)
else my.matrix2[1,d] = e
my.matrix2[1,(v1+1)] = a
my.matrix2[1,(v1+2)] = b
my.matrix2[1,(v1+3)] = c
my.matrix2[1,(v1+4)] = d
i <- i+1
if(i == 2) my.matrix3 <- my.matrix2
else my.matrix3 <- rbind(my.matrix3, my.matrix2)
my.matrix2 <- matrix(0, nrow=1, ncol=(v1+4))
}
}
}
}
}
all.equal(my.matrix, my.matrix3)
这是'The R Inferno'的圈2的主题http://www.burns-stat.com/pages/Tutor/R_inferno.pdf你是对的,以避免不断的绑定或绑定。 – 2012-03-04 15:44:37